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

#include <KoCompositeOpDissolve.h>

+ Inheritance diagram for KoCompositeOpDissolve< 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
 
 KoCompositeOpDissolve (const KoColorSpace *cs, const QString &category)
 
- 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
 

Private Attributes

QThreadStorage< KisRandomSourcem_randomGenerator
 

Static Private Attributes

static const qint32 alpha_pos = Traits::alpha_pos
 
static const qint32 channels_nb = Traits::channels_nb
 

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 KoCompositeOpDissolve< Traits >

Definition at line 17 of file KoCompositeOpDissolve.h.

Member Typedef Documentation

◆ channels_type

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

Definition at line 19 of file KoCompositeOpDissolve.h.

Constructor & Destructor Documentation

◆ KoCompositeOpDissolve()

template<class Traits >
KoCompositeOpDissolve< Traits >::KoCompositeOpDissolve ( const KoColorSpace * cs,
const QString & category )
inline

Definition at line 27 of file KoCompositeOpDissolve.h.

29 {
30 }
const QString COMPOSITE_DISSOLVE

Member Function Documentation

◆ composite() [1/3]

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

Same as previous, but uses a parameter structure

Initialize local per-thread random generator from the global one, it will reduce contestion over the global generator in the main compositing loop.

KisRandomSource is automatically initialized from QRandomGenerator::global() internally.

Reimplemented from KoCompositeOp.

Definition at line 34 of file KoCompositeOpDissolve.h.

34 {
42 if (!m_randomGenerator.hasLocalData()) {
43 m_randomGenerator.setLocalData(KisRandomSource());
44 }
45
46 const QBitArray& flags = params.channelFlags.isEmpty() ? QBitArray(channels_nb,true) : params.channelFlags;
47 bool alphaLocked = (alpha_pos != -1) && !flags.testBit(alpha_pos);
48
49 using namespace Arithmetic;
50
51// quint32 ctr = quint32(reinterpret_cast<quint64>(dstRowStart) % 256);
52 qint32 srcInc = (params.srcRowStride == 0) ? 0 : channels_nb;
53 bool useMask = params.maskRowStart != 0;
56
57 const quint8 *srcRowStart = params.srcRowStart;
58 quint8 *dstRowStart = params.dstRowStart;
59 const quint8 *maskRowStart = params.maskRowStart;
60
61 qint32 rows = params.rows;
62
63 for(; rows>0; --rows) {
64 const channels_type* src = reinterpret_cast<const channels_type*>(srcRowStart);
65 channels_type* dst = reinterpret_cast<channels_type*>(dstRowStart);
66 const quint8* mask = maskRowStart;
67
68 for(qint32 c=params.cols; c>0; --c) {
69 channels_type srcAlpha = (alpha_pos == -1) ? unitValue : src[alpha_pos];
70 channels_type dstAlpha = (alpha_pos == -1) ? unitValue : dst[alpha_pos];
71 channels_type blend = useMask ? mul(opacity, scale<channels_type>(*mask), srcAlpha) : mul(opacity, srcAlpha);
72
73 if (m_randomGenerator.localData().generate(0, 255) <= scale<quint8>(blend)
75 for(qint32 i=0; i <channels_nb; i++) {
76 if(i != alpha_pos && flags.testBit(i))
77 dst[i] = src[i];
78 }
79
80 if(alpha_pos != -1)
81 dst[alpha_pos] = alphaLocked ? dstAlpha : unitValue;
82 }
83
84 src += srcInc;
85 dst += channels_nb;
86// ctr = (ctr + 1) % 256;
87 if (mask) {
88 ++mask;
89 }
90 }
91
92 srcRowStart += params.srcRowStride;
93 dstRowStart += params.dstRowStride;
94 if (maskRowStart) {
95 maskRowStart += params.maskRowStride;
96 }
97 }
98 }
static _Tdst scaleToA(_T a)
QThreadStorage< KisRandomSource > m_randomGenerator
Traits::channels_type channels_type
static const qint32 channels_nb
static const qint32 alpha_pos
T mul(T a, T b)
T blend(T src, T srcAlpha, T dst, T dstAlpha, T cfValue)

References KoCompositeOpDissolve< Traits >::alpha_pos, KoCompositeOp::ParameterInfo::channelFlags, KoCompositeOpDissolve< Traits >::channels_nb, KoCompositeOp::ParameterInfo::cols, KoCompositeOp::ParameterInfo::dstRowStart, KoCompositeOp::ParameterInfo::dstRowStride, KoCompositeOpDissolve< Traits >::m_randomGenerator, KoCompositeOp::ParameterInfo::maskRowStart, KoCompositeOp::ParameterInfo::maskRowStride, KoCompositeOp::ParameterInfo::opacity, KoCompositeOp::ParameterInfo::rows, KoColorSpaceMaths< _T, _Tdst >::scaleToA(), KoCompositeOp::ParameterInfo::srcRowStart, and KoCompositeOp::ParameterInfo::srcRowStride.

◆ 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}

Member Data Documentation

◆ alpha_pos

template<class Traits >
const qint32 KoCompositeOpDissolve< Traits >::alpha_pos = Traits::alpha_pos
staticprivate

Definition at line 22 of file KoCompositeOpDissolve.h.

◆ channels_nb

template<class Traits >
const qint32 KoCompositeOpDissolve< Traits >::channels_nb = Traits::channels_nb
staticprivate

Definition at line 21 of file KoCompositeOpDissolve.h.

◆ m_randomGenerator

template<class Traits >
QThreadStorage<KisRandomSource> KoCompositeOpDissolve< Traits >::m_randomGenerator
mutableprivate

Definition at line 24 of file KoCompositeOpDissolve.h.


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