2016-10-06 00:33:02 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2016 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SkBlendMode_DEFINED
|
|
|
|
#define SkBlendMode_DEFINED
|
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/core/SkTypes.h"
|
2016-11-16 18:13:16 +00:00
|
|
|
|
2016-10-06 00:33:02 +00:00
|
|
|
enum class SkBlendMode {
|
2018-07-13 12:21:59 +00:00
|
|
|
kClear, //!< replaces destination with zero: fully transparent
|
|
|
|
kSrc, //!< replaces destination
|
|
|
|
kDst, //!< preserves destination
|
|
|
|
kSrcOver, //!< source over destination
|
|
|
|
kDstOver, //!< destination over source
|
|
|
|
kSrcIn, //!< source trimmed inside destination
|
|
|
|
kDstIn, //!< destination trimmed by source
|
|
|
|
kSrcOut, //!< source trimmed outside destination
|
|
|
|
kDstOut, //!< destination trimmed outside source
|
|
|
|
kSrcATop, //!< source inside destination blended with destination
|
|
|
|
kDstATop, //!< destination inside source blended with source
|
|
|
|
kXor, //!< each of source and destination trimmed outside the other
|
|
|
|
kPlus, //!< sum of colors
|
|
|
|
kModulate, //!< product of premultiplied colors; darkens destination
|
|
|
|
kScreen, //!< multiply inverse of pixels, inverting result; brightens destination
|
|
|
|
kLastCoeffMode = kScreen, //!< last porter duff blend mode
|
|
|
|
kOverlay, //!< multiply or screen, depending on destination
|
|
|
|
kDarken, //!< darker of source and destination
|
|
|
|
kLighten, //!< lighter of source and destination
|
|
|
|
kColorDodge, //!< brighten destination to reflect source
|
|
|
|
kColorBurn, //!< darken destination to reflect source
|
|
|
|
kHardLight, //!< multiply or screen, depending on source
|
|
|
|
kSoftLight, //!< lighten or darken, depending on source
|
|
|
|
kDifference, //!< subtract darker from lighter with higher contrast
|
|
|
|
kExclusion, //!< subtract darker from lighter with lower contrast
|
|
|
|
kMultiply, //!< multiply source with destination, darkening image
|
|
|
|
kLastSeparableMode = kMultiply, //!< last blend mode operating separately on components
|
|
|
|
kHue, //!< hue of source with saturation and luminosity of destination
|
|
|
|
kSaturation, //!< saturation of source with hue and luminosity of destination
|
|
|
|
kColor, //!< hue and saturation of source with luminosity of destination
|
|
|
|
kLuminosity, //!< luminosity of source with hue and saturation of destination
|
|
|
|
kLastMode = kLuminosity, //!< last valid value
|
2016-10-06 00:33:02 +00:00
|
|
|
};
|
|
|
|
|
2019-11-04 20:01:52 +00:00
|
|
|
/**
|
|
|
|
* For Porter-Duff SkBlendModes (those <= kLastCoeffMode), these coefficients describe the blend
|
|
|
|
* equation used. Coefficient-based blend modes specify an equation:
|
|
|
|
* ('dstCoeff' * dst + 'srcCoeff' * src), where the coefficient values are constants, functions of
|
|
|
|
* the src or dst alpha, or functions of the src or dst color.
|
|
|
|
*/
|
|
|
|
enum class SkBlendModeCoeff {
|
|
|
|
kZero, /** 0 */
|
|
|
|
kOne, /** 1 */
|
|
|
|
kSC, /** src color */
|
|
|
|
kISC, /** inverse src color (i.e. 1 - sc) */
|
|
|
|
kDC, /** dst color */
|
|
|
|
kIDC, /** inverse dst color (i.e. 1 - dc) */
|
|
|
|
kSA, /** src alpha */
|
|
|
|
kISA, /** inverse src alpha (i.e. 1 - sa) */
|
|
|
|
kDA, /** dst alpha */
|
|
|
|
kIDA, /** inverse dst alpha (i.e. 1 - da) */
|
|
|
|
|
|
|
|
kCoeffCount
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if 'mode' is a coefficient-based blend mode (<= kLastCoeffMode). If true is
|
|
|
|
* returned, the mode's src and dst coefficient functions are set in 'src' and 'dst'.
|
|
|
|
*/
|
|
|
|
SK_API bool SkBlendMode_AsCoeff(SkBlendMode mode, SkBlendModeCoeff* src, SkBlendModeCoeff* dst);
|
|
|
|
|
|
|
|
|
2018-07-13 12:21:59 +00:00
|
|
|
/** Returns name of blendMode as null-terminated C string.
|
|
|
|
|
|
|
|
@return C string
|
|
|
|
*/
|
2018-06-27 15:00:21 +00:00
|
|
|
SK_API const char* SkBlendMode_Name(SkBlendMode blendMode);
|
2016-11-16 18:13:16 +00:00
|
|
|
|
2016-10-06 00:33:02 +00:00
|
|
|
#endif
|