Krita Source Code Documentation
Loading...
Searching...
No Matches
KoCompositeOpMarker< Traits > Class Template Reference

#include <KoCompositeOpMarker.h>

+ Inheritance diagram for KoCompositeOpMarker< Traits >:

Public Member Functions

void composite (const KoCompositeOp::ParameterInfo &params) const override
 
virtual void composite (const ParameterInfo &params) const
 
void composite (quint8 *dstRowStart, qint32 dstRowStride, const quint8 *srcRowStart, qint32 srcRowStride, const quint8 *maskRowStart, qint32 maskRowStride, qint32 rows, qint32 numColumns, float opacity, const QBitArray &channelFlags=QBitArray()) const
 
template<bool useMask, bool alphaLocked, bool allChannelFlags>
void genericComposite (const KoCompositeOp::ParameterInfo &params, const QBitArray *channelFlags) const
 
 KoCompositeOpMarker (const KoColorSpace *cs)
 
- Public Member Functions inherited from KoCompositeOp
QString category () const
 
const KoColorSpacecolorSpace () const
 
void composite (quint8 *dstRowStart, qint32 dstRowStride, const quint8 *srcRowStart, qint32 srcRowStride, const quint8 *maskRowStart, qint32 maskRowStride, qint32 rows, qint32 numColumns, float opacity, const QBitArray &channelFlags=QBitArray()) const
 
QString description () const
 
QString id () const
 
 KoCompositeOp (const KoColorSpace *cs, const QString &id, const QString &category=KoCompositeOp::categoryMisc())
 
virtual ~KoCompositeOp ()
 
- Public Member Functions inherited from Private
 Private (KisCanvas2 *c)
 

Private Types

typedef Traits::channels_type channels_type
 

Static Private Attributes

static constexpr qint32 alpha_pos = Traits::alpha_pos
 
static constexpr qint32 channels_nb = Traits::channels_nb
 
static constexpr qint32 pixel_size = Traits::pixelSize
 

Additional Inherited Members

- Static Public Member Functions inherited from KoCompositeOp
static QString categoryArithmetic ()
 
static QString categoryBinary ()
 
static QString categoryDark ()
 
static QString categoryHSI ()
 
static QString categoryHSL ()
 
static QString categoryHSV ()
 
static QString categoryHSY ()
 
static QString categoryLight ()
 
static QString categoryMisc ()
 
static QString categoryMix ()
 
static QString categoryModulo ()
 
static QString categoryNegative ()
 
static QString categoryQuadratic ()
 
- Public Attributes inherited from KoCompositeOp
QString category
 
const KoColorSpacecolorSpace
 
QBitArray defaultChannelFlags
 
QString description
 
QString id
 
- Public Attributes inherited from Private
KisCanvas2canvas
 
int displayedFrame
 
int intendedFrame
 

Detailed Description

template<class Traits>
class KoCompositeOpMarker< Traits >

Definition at line 16 of file KoCompositeOpMarker.h.

Member Typedef Documentation

◆ channels_type

template<class Traits >
typedef Traits::channels_type KoCompositeOpMarker< Traits >::channels_type
private

Definition at line 18 of file KoCompositeOpMarker.h.

Constructor & Destructor Documentation

◆ KoCompositeOpMarker()

template<class Traits >
KoCompositeOpMarker< Traits >::KoCompositeOpMarker ( const KoColorSpace * cs)
inline

Definition at line 25 of file KoCompositeOpMarker.h.

27 {
28 }
const QString COMPOSITE_MARKER
static QString categoryMix()

Member Function Documentation

◆ composite() [1/3]

template<class Traits >
void KoCompositeOpMarker< Traits >::composite ( const KoCompositeOp::ParameterInfo & params) const
inlineoverridevirtual

Same as previous, but uses a parameter structure

Reimplemented from KoCompositeOp.

Definition at line 32 of file KoCompositeOpMarker.h.

33 {
34 bool useMask = params.maskRowStart != 0;
35 const QBitArray &flags = params.channelFlags.isEmpty() ? QBitArray(channels_nb, true) : params.channelFlags;
36 bool allChannelFlags = params.channelFlags.isEmpty() || params.channelFlags == QBitArray(channels_nb, true);
37 bool alphaLocked = (alpha_pos != -1) && !flags.testBit(alpha_pos);
38 if (useMask) {
39 if (alphaLocked) {
40 if (allChannelFlags) {
41 genericComposite<true, true, true>(params, &flags);
42 } else {
43 genericComposite<true, true, false>(params, &flags);
44 }
45 } else {
46 if (allChannelFlags) {
47 genericComposite<true, false, true>(params, &flags);
48 } else {
49 genericComposite<true, false, false>(params, &flags);
50 }
51 }
52 } else {
53 if (alphaLocked) {
54 if (allChannelFlags) {
55 genericComposite<false, true, true>(params, &flags);
56 } else {
57 genericComposite<false, true, false>(params, &flags);
58 }
59 } else {
60 if (allChannelFlags) {
61 genericComposite<false, false, true>(params, &flags);
62 } else {
63 genericComposite<false, false, false>(params, &flags);
64 }
65 }
66 }
67 }
static constexpr qint32 alpha_pos
static constexpr qint32 channels_nb

References KoCompositeOpMarker< Traits >::alpha_pos, KoCompositeOp::ParameterInfo::channelFlags, KoCompositeOpMarker< Traits >::channels_nb, and KoCompositeOp::ParameterInfo::maskRowStart.

◆ composite() [2/3]

template<class Traits >
void KoCompositeOp::composite ( const ParameterInfo & params) const
virtual

Same as previous, but uses a parameter structure

Reimplemented from KoCompositeOp.

Definition at line 123 of file KoCompositeOp.cpp.

160{
161 composite(params.dstRowStart , params.dstRowStride ,
162 params.srcRowStart , params.srcRowStride ,
163 params.maskRowStart , params.maskRowStride,
164 params.rows , params.cols ,
165 params.opacity, params.channelFlags );
166}
void composite(const KoCompositeOp::ParameterInfo &params) const override

◆ composite() [3/3]

template<class Traits >
void KoCompositeOp::composite ( quint8 * dstRowStart,
qint32 dstRowStride,
const quint8 * srcRowStart,
qint32 srcRowStride,
const quint8 * maskRowStart,
qint32 maskRowStride,
qint32 rows,
qint32 numColumns,
float opacity,
const QBitArray & channelFlags = QBitArray() ) const
Parameters
dstRowStartpointer to the start of the byte array we will composite the source on
dstRowStridelength of the rows of the block of destination pixels in bytes
srcRowStartpointer to the start of the byte array we will mix with dest
srcRowStridelength of the rows of the block of src in bytes pixels (may be different from the rowstride of the dst pixels, in which case the smaller value is used). If srcRowStride is null it is assumed that the source is a constant color.
maskRowStartstart of the byte mask that determines whether and if so, then how much of src is used for blending
maskRowStridelength of the mask scanlines in bytes
rowsnumber of scanlines to blend
numColumnslength of the row of pixels in pixels
opacitytransparency with which to blend
channelFlagsa bit array that determines which channels should be processed (channels are in the order of the channels in the colorspace)

Definition at line 113 of file KoCompositeOp.cpp.

142{
144 params.dstRowStart = dstRowStart;
145 params.dstRowStride = dstRowStride;
146 params.srcRowStart = srcRowStart;
147 params.srcRowStride = srcRowStride;
148 params.maskRowStart = maskRowStart;
149 params.maskRowStride = maskRowStride;
150 params.rows = rows;
151 params.cols = numColumns;
152 params.opacity = opacity;
153 params.flow = 1.0f;
154 params.channelFlags = channelFlags;
155 composite(params);
156}

◆ genericComposite()

template<class Traits >
template<bool useMask, bool alphaLocked, bool allChannelFlags>
void KoCompositeOpMarker< Traits >::genericComposite ( const KoCompositeOp::ParameterInfo & params,
const QBitArray * channelFlags ) const
inline

Definition at line 70 of file KoCompositeOpMarker.h.

71 {
72 using namespace Arithmetic;
73
74 KoAlphaDarkenParamsWrapperCreamy paramsWrapper(params);
75
76 qint32 srcInc = (params.srcRowStride == 0) ? 0 : channels_nb;
77 channels_type flow = scale<channels_type>(paramsWrapper.flow);
78 channels_type opacity = scale<channels_type>(paramsWrapper.opacity);
79 quint8 *dstRowStart = params.dstRowStart;
80 const quint8 *srcRowStart = params.srcRowStart;
81 const quint8 *maskRowStart = params.maskRowStart;
82
83 for (qint32 r = params.rows; r > 0; --r) {
84 const channels_type *src = reinterpret_cast<const channels_type *>(srcRowStart);
85 channels_type *dst = reinterpret_cast<channels_type *>(dstRowStart);
86 const quint8 *mask = maskRowStart;
87
88 for (qint32 c = params.cols; c > 0; --c) {
89 channels_type srcAlpha = (alpha_pos == -1) ? unitValue<channels_type>() : src[alpha_pos];
90 channels_type dstAlpha = (alpha_pos == -1) ? unitValue<channels_type>() : dst[alpha_pos];
91 channels_type mskAlpha = useMask ? mul(scale<channels_type>(*mask), srcAlpha) : srcAlpha;
92
93 srcAlpha = mul(mskAlpha, opacity);
94
95 if (dstAlpha != zeroValue<channels_type>()) {
98 for (qint32 i = 0; i < channels_nb; i++) {
99 if (i != alpha_pos && (allChannelFlags || channelFlags->testBit(i))) {
100 dst[i] = lerp(dst[i], src[i], t);
101 }
102 }
103 } else {
104 if constexpr (!allChannelFlags) {
105 memset(reinterpret_cast<quint8 *>(dst), 0, pixel_size);
106 }
107 for (qint32 i = 0; i < channels_nb; i++) {
108 if (i != alpha_pos && (allChannelFlags || channelFlags->testBit(i))) {
109 dst[i] = src[i];
110 }
111 }
112 }
113
114 if constexpr (alpha_pos != -1 && !alphaLocked) {
116 params,
117 paramsWrapper,
118 flow,
119 opacity,
120 srcAlpha,
121 dstAlpha,
122 mskAlpha);
123 }
124
125 src += srcInc;
126 dst += channels_nb;
127
128 if constexpr (useMask) {
129 ++mask;
130 }
131 }
132
133 srcRowStart += params.srcRowStride;
134 dstRowStart += params.dstRowStride;
135 maskRowStart += params.maskRowStride;
136 }
137 }
QPointF lerp(const QPointF &p1, const QPointF &p2, qreal t)
static _Tdst clampAfterScale(dst_compositetype val)
static channels_type calculateAlpha(const KoCompositeOp::ParameterInfo &params, const ParamsWrapper &paramsWrapper, channels_type flow, channels_type opacity, channels_type srcAlpha, channels_type dstAlpha, channels_type mskAlpha)
static constexpr qint32 pixel_size
Traits::channels_type channels_type
T mul(T a, T b)

References KoCompositeOpMarker< Traits >::alpha_pos, KoCompositeOpAlphaDarken< Traits, ParamsWrapper >::calculateAlpha(), KoCompositeOpMarker< Traits >::channels_nb, KoColorSpaceMaths< _T, _Tdst >::clampAfterScale(), KoCompositeOp::ParameterInfo::cols, KoCompositeOp::ParameterInfo::dstRowStart, KoCompositeOp::ParameterInfo::dstRowStride, KoAlphaDarkenParamsWrapperCreamy::flow, lerp(), KoCompositeOp::ParameterInfo::maskRowStart, KoCompositeOp::ParameterInfo::maskRowStride, KoAlphaDarkenParamsWrapperCreamy::opacity, KoCompositeOpMarker< Traits >::pixel_size, KoCompositeOp::ParameterInfo::rows, KoCompositeOp::ParameterInfo::srcRowStart, and KoCompositeOp::ParameterInfo::srcRowStride.

Member Data Documentation

◆ alpha_pos

template<class Traits >
constexpr qint32 KoCompositeOpMarker< Traits >::alpha_pos = Traits::alpha_pos
staticconstexprprivate

Definition at line 21 of file KoCompositeOpMarker.h.

◆ channels_nb

template<class Traits >
constexpr qint32 KoCompositeOpMarker< Traits >::channels_nb = Traits::channels_nb
staticconstexprprivate

Definition at line 20 of file KoCompositeOpMarker.h.

◆ pixel_size

template<class Traits >
constexpr qint32 KoCompositeOpMarker< Traits >::pixel_size = Traits::pixelSize
staticconstexprprivate

Definition at line 22 of file KoCompositeOpMarker.h.


The documentation for this class was generated from the following file: