Krita Source Code Documentation
Loading...
Searching...
No Matches
HistogramComputationStrokeStrategy Class Reference

#include <HistogramComputationStrokeStrategy.h>

+ Inheritance diagram for HistogramComputationStrokeStrategy:

Classes

struct  Private
 

Signals

void computationResultReady (HistogramData data)
 
- Signals inherited from KisIdleTaskStrokeStrategy
void sigIdleTaskFinished ()
 

Public Member Functions

 HistogramComputationStrokeStrategy (KisImageSP image)
 
 ~HistogramComputationStrokeStrategy () override
 
- Public Member Functions inherited from KisIdleTaskStrokeStrategy
KisStrokeStrategycreateLodClone (int levelOfDetail) override
 
QWeakPointer< boost::none_t > idleTaskCookie ()
 
 KisIdleTaskStrokeStrategy (const QLatin1String &id, const KUndo2MagicString &name=KUndo2MagicString())
 
 ~KisIdleTaskStrokeStrategy ()
 
- Public Member Functions inherited from KisRunnableBasedStrokeStrategy
void doStrokeCallback (KisStrokeJobData *data) override
 
 KisRunnableBasedStrokeStrategy (const KisRunnableBasedStrokeStrategy &rhs)
 
 KisRunnableBasedStrokeStrategy (const QLatin1String &id, const KUndo2MagicString &name=KUndo2MagicString())
 
KisRunnableStrokeJobsInterfacerunnableJobsInterface () const
 
 ~KisRunnableBasedStrokeStrategy ()
 
- Public Member Functions inherited from KisSimpleStrokeStrategy
virtual void cancelStrokeCallback ()
 
KisStrokeJobDatacreateCancelData () override
 
KisStrokeJobStrategycreateCancelStrategy () override
 
KisStrokeJobStrategycreateDabStrategy () override
 
KisStrokeJobDatacreateFinishData () override
 
KisStrokeJobStrategycreateFinishStrategy () override
 
KisStrokeJobDatacreateInitData () override
 
KisStrokeJobStrategycreateInitStrategy () override
 
KisStrokeJobDatacreateResumeData () override
 
KisStrokeJobStrategycreateResumeStrategy () override
 
KisStrokeJobDatacreateSuspendData () override
 
KisStrokeJobStrategycreateSuspendStrategy () override
 
 KisSimpleStrokeStrategy (const QLatin1String &id, const KUndo2MagicString &name=KUndo2MagicString())
 
virtual void resumeStrokeCallback ()
 
virtual void suspendStrokeCallback ()
 
- Public Member Functions inherited from KisStrokeStrategy
qreal balancingRatioOverride () const
 
bool canForgetAboutMe () const
 
bool clearsRedoOnStart () const
 
KisLodPreferences currentLodPreferences () const
 
bool forceLodModeIfPossible () const
 
QString id () const
 
bool isAsynchronouslyCancellable () const
 
bool isExclusive () const
 
 KisStrokeStrategy (const QLatin1String &id, const KUndo2MagicString &name=KUndo2MagicString())
 
KUndo2MagicString name () const
 
bool needsExplicitCancel () const
 
virtual void notifyUserEndedStroke ()
 
virtual void notifyUserStartedStroke ()
 
bool requestsOtherStrokesToEnd () const
 
void setForceLodModeIfPossible (bool forceLodModeIfPossible)
 
void setMutatedJobsInterface (KisStrokesQueueMutatedJobInterface *mutatedJobsInterface, KisStrokeId strokeId)
 
bool supportsWrapAroundMode () const
 
virtual void tryCancelCurrentStrokeJobAsync ()
 tryCancelCurrentStrokeJobAsync is called by the strokes queue when the stroke is being cancelled. The stroke strategy may or may not handle this request and cancel the currently running long action.
 
virtual ~KisStrokeStrategy ()
 

Private Member Functions

void doStrokeCallback (KisStrokeJobData *data) override
 
void finishStrokeCallback () override
 
void initiateVector (HistVector &vec, const KoColorSpace *colorSpace)
 
void initStrokeCallback () override
 

Private Attributes

const QScopedPointer< Privatem_d
 

Additional Inherited Members

- Public Types inherited from KisSimpleStrokeStrategy
enum  JobType {
  JOB_INIT = 0 , JOB_CANCEL , JOB_FINISH , JOB_DOSTROKE ,
  JOB_SUSPEND , JOB_RESUME , NJOBS
}
 
- Static Public Member Functions inherited from KisIdleTaskStrokeStrategy
static int preferredIdleTaskMaximumTime ()
 
static int preferredIdleWatcherInterval ()
 
- Static Public Member Functions inherited from KisSimpleStrokeStrategy
static QLatin1String jobTypeToString (JobType type)
 
- Protected Member Functions inherited from KisIdleTaskStrokeStrategy
void finishStrokeCallback () override
 
void initStrokeCallback () override
 
- Protected Member Functions inherited from KisSimpleStrokeStrategy
void enableJob (JobType type, bool enable=true, KisStrokeJobData::Sequentiality sequentiality=KisStrokeJobData::SEQUENTIAL, KisStrokeJobData::Exclusivity exclusivity=KisStrokeJobData::NORMAL)
 
 KisSimpleStrokeStrategy (const KisSimpleStrokeStrategy &rhs)
 
- Protected Member Functions inherited from KisStrokeStrategy
void addMutatedJob (KisStrokeJobData *data)
 
void addMutatedJobs (const QVector< KisStrokeJobData * > list)
 
 KisStrokeStrategy (const KisStrokeStrategy &rhs)
 
void setAsynchronouslyCancellable (bool value)
 
void setBalancingRatioOverride (qreal value)
 
void setCanForgetAboutMe (bool value)
 
void setClearsRedoOnStart (bool value)
 
void setExclusive (bool value)
 
void setNeedsExplicitCancel (bool value)
 
void setRequestsOtherStrokesToEnd (bool value)
 
void setSupportsWrapAroundMode (bool value)
 

Detailed Description

Definition at line 26 of file HistogramComputationStrokeStrategy.h.

Constructor & Destructor Documentation

◆ HistogramComputationStrokeStrategy()

HistogramComputationStrokeStrategy::HistogramComputationStrokeStrategy ( KisImageSP image)

Definition at line 36 of file HistogramComputationStrokeStrategy.cpp.

37 : KisIdleTaskStrokeStrategy(QLatin1String("ComputeHistogram"), kundo2_i18n("Update histogram"))
38 , m_d(new Private)
39{
40 m_d->image = image;
41}
KisIdleTaskStrokeStrategy(const QLatin1String &id, const KUndo2MagicString &name=KUndo2MagicString())
KUndo2MagicString kundo2_i18n(const char *text)

References m_d.

◆ ~HistogramComputationStrokeStrategy()

HistogramComputationStrokeStrategy::~HistogramComputationStrokeStrategy ( )
override

Definition at line 43 of file HistogramComputationStrokeStrategy.cpp.

44{
45}

Member Function Documentation

◆ computationResultReady

void HistogramComputationStrokeStrategy::computationResultReady ( HistogramData data)
signal

◆ doStrokeCallback()

void HistogramComputationStrokeStrategy::doStrokeCallback ( KisStrokeJobData * data)
overrideprivatevirtual

Reimplemented from KisSimpleStrokeStrategy.

Definition at line 63 of file HistogramComputationStrokeStrategy.cpp.

64{
65 Private::ProcessData *d_pd = dynamic_cast<Private::ProcessData*>(data);
66
67 if (!d_pd) {
69 return;
70 }
71
72 QRect calculate = d_pd->rectToCalculate;
73
74 KisPaintDeviceSP m_dev = m_d->image->projection();
75 QRect imageBounds = m_d->image->bounds();
76
77 const KoColorSpace *cs = m_dev->colorSpace();
78 quint32 channelCount = m_dev->channelCount();
79 quint32 pixelSize = m_dev->pixelSize();
80
81 int imageSize = imageBounds.width() * imageBounds.height();
82 int nSkip = 1 + (imageSize >> 20); //for speed use about 1M pixels for computing histograms
83
84 if (calculate.isEmpty())
85 return;
86
87 initiateVector(m_d->results[d_pd->jobId], cs);
88
89 quint32 toSkip = nSkip;
90
91 KisSequentialConstIterator it(m_dev, calculate);
92
93 int numConseqPixels = it.nConseqPixels();
94 while (it.nextPixels(numConseqPixels)) {
95
96 numConseqPixels = it.nConseqPixels();
97 const quint8* pixel = it.rawDataConst();
98 for (int k = 0; k < numConseqPixels; ++k) {
99 if (--toSkip == 0) {
100 for (int chan = 0; chan < (int)channelCount; ++chan) {
101 m_d->results[d_pd->jobId][chan][cs->scaleToU8(pixel, chan)]++;
102 }
103 toSkip = nSkip;
104 }
105 pixel += pixelSize;
106 }
107 }
108}
void initiateVector(HistVector &vec, const KoColorSpace *colorSpace)
quint32 pixelSize() const
quint32 channelCount() const
const KoColorSpace * colorSpace() const
virtual void doStrokeCallback(KisStrokeJobData *data)
virtual quint8 scaleToU8(const quint8 *srcPixel, qint32 channelPos) const =0

References KisPaintDevice::channelCount(), KisPaintDevice::colorSpace(), KisSimpleStrokeStrategy::doStrokeCallback(), initiateVector(), HistogramComputationStrokeStrategy::Private::ProcessData::jobId, m_d, KisSequentialIteratorBase< IteratorPolicy, SourcePolicy, ProgressPolicy >::nConseqPixels(), KisSequentialIteratorBase< IteratorPolicy, SourcePolicy, ProgressPolicy >::nextPixels(), KisPaintDevice::pixelSize(), KisSequentialIteratorBase< IteratorPolicy, SourcePolicy, ProgressPolicy >::rawDataConst(), HistogramComputationStrokeStrategy::Private::ProcessData::rectToCalculate, and KoColorSpace::scaleToU8().

◆ finishStrokeCallback()

void HistogramComputationStrokeStrategy::finishStrokeCallback ( )
overrideprivatevirtual

Reimplemented from KisSimpleStrokeStrategy.

Definition at line 110 of file HistogramComputationStrokeStrategy.cpp.

111{
112 HistogramData hisData;
113 hisData.colorSpace = m_d->image->projection()->colorSpace();
114
115 if (m_d->results.size() == 1) {
116 hisData.bins = m_d->results[0];
117 Q_EMIT computationResultReady(hisData);
118 } else {
119
120 quint32 channelCount = m_d->image->projection()->channelCount();
121
122 initiateVector(hisData.bins, hisData.colorSpace);
123
124 for (int chan = 0; chan < (int)channelCount; chan++) {
125 int bsize = hisData.bins[chan].size();
126
127 for (int bi = 0; bi < bsize; bi++) {
128 hisData.bins[chan][bi] = 0;
129 for (int i = 0; i < (int)m_d->results.size(); i++) {
130 hisData.bins[chan][bi] += m_d->results[i][chan][bi];
131 }
132 }
133 }
134
135 Q_EMIT computationResultReady(hisData);
136 }
137
139}
void computationResultReady(HistogramData data)

References HistogramData::bins, HistogramData::colorSpace, computationResultReady(), KisIdleTaskStrokeStrategy::finishStrokeCallback(), initiateVector(), and m_d.

◆ initiateVector()

void HistogramComputationStrokeStrategy::initiateVector ( HistVector & vec,
const KoColorSpace * colorSpace )
private

Definition at line 141 of file HistogramComputationStrokeStrategy.cpp.

142{
143 vec.resize(colorSpace->channelCount());
144 for (auto &bin : vec) {
145 bin.resize(std::numeric_limits<quint8>::max() + 1);
146 }
147}
virtual quint32 channelCount() const =0

References KoColorSpace::channelCount().

◆ initStrokeCallback()

void HistogramComputationStrokeStrategy::initStrokeCallback ( )
overrideprivatevirtual

Reimplemented from KisSimpleStrokeStrategy.

Definition at line 47 of file HistogramComputationStrokeStrategy.cpp.

48{
50
52 int i = 0;
54 m_d->results.resize(tileRects.size());
55
56 Q_FOREACH (const QRect &tileRectangle, tileRects) {
57 jobsData << new HistogramComputationStrokeStrategy::Private::ProcessData(tileRectangle, i);
58 i++;
59 }
60 addMutatedJobs(jobsData);
61}
void addMutatedJobs(const QVector< KisStrokeJobData * > list)
QVector< QRect > splitRectIntoPatches(const QRect &rc, const QSize &patchSize)
QSize optimalPatchSize()

References KisStrokeStrategy::addMutatedJobs(), KisIdleTaskStrokeStrategy::initStrokeCallback(), m_d, KritaUtils::optimalPatchSize(), and KritaUtils::splitRectIntoPatches().

Member Data Documentation

◆ m_d

const QScopedPointer<Private> HistogramComputationStrokeStrategy::m_d
private

Definition at line 46 of file HistogramComputationStrokeStrategy.h.


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