Krita Source Code Documentation
Loading...
Searching...
No Matches
colorsfilters.cpp
Go to the documentation of this file.
1/*
2 * This file is part of Krita
3 *
4 * SPDX-FileCopyrightText: 2004 Cyrille Berger <cberger@cberger.net>
5 *
6 * SPDX-License-Identifier: GPL-2.0-or-later
7 */
8
9#include "colorsfilters.h"
10
11
12#include <math.h>
13
14#include <stdlib.h>
15#include <string.h>
16
17#include <QSlider>
18#include <QPoint>
19#include <QColor>
20
21#include <klocalizedstring.h>
22
23#include <kis_debug.h>
24#include <kpluginfactory.h>
25
27#include <KoColorSpace.h>
31#include <kis_paint_device.h>
33#include <KisDocument.h>
34#include <kis_image.h>
35#include <kis_layer.h>
36#include <kis_global.h>
37#include <kis_types.h>
38#include <kis_selection.h>
39#include <kis_histogram.h>
41#include <kis_painter.h>
42#include <KoUpdater.h>
44#include <KoCompositeOp.h>
46
47
53
54K_PLUGIN_FACTORY_WITH_JSON(ColorsFiltersFactory, "kritacolorsfilter.json", registerPlugin<ColorsFilters>();)
55
56ColorsFilters::ColorsFilters(QObject *parent, const QVariantList &)
57 : QObject(parent)
58{
60 manager->add(new KisAutoContrast());
61 manager->add(new KisPerChannelFilter());
62 manager->add(new KisCrossChannelFilter());
63 manager->add(new KisDesaturateFilter());
64 manager->add(new KisHSVAdjustmentFilter());
65 manager->add(new KisColorBalanceFilter());
66
67}
68
72
73
74//==================================================================
75
76
85
87 const QRect& applyRect,
88 const KisFilterConfigurationSP config,
89 KoUpdater* progressUpdater) const
90{
91 Q_ASSERT(device != 0);
92 Q_UNUSED(config);
93 // initialize
95 KisHistogram histogram(device, applyRect, producer, LINEAR);
96 int minvalue = int(255 * histogram.calculations().getMin() + 0.5);
97 int maxvalue = int(255 * histogram.calculations().getMax() + 0.5);
98
99 if (maxvalue > 255)
100 maxvalue = 255;
101
102 histogram.setChannel(0);
103 int twoPercent = int(0.005 * histogram.calculations().getCount());
104 int pixCount = 0;
105 int binnum = 0;
106
107 while (binnum < histogram.producer()->numberOfBins()) {
108 pixCount += histogram.getValue(binnum);
109 if (pixCount > twoPercent) {
110 minvalue = binnum;
111 break;
112 }
113 binnum++;
114 }
115 pixCount = 0;
116 binnum = histogram.producer()->numberOfBins() - 1;
117 while (binnum > 0) {
118 pixCount += histogram.getValue(binnum);
119 if (pixCount > twoPercent) {
120 maxvalue = binnum;
121 break;
122 }
123 binnum--;
124 }
125 // build the transferfunction
126 int diff = maxvalue - minvalue;
127
128 QScopedArrayPointer<quint16> transfer(new quint16[256]);
129 for (int i = 0; i < 255; i++)
130 transfer[i] = 0xFFFF;
131
132 if (diff != 0) {
133 for (int i = 0; i < minvalue; i++)
134 transfer[i] = 0x0;
135 for (int i = minvalue; i < maxvalue; i++) {
136 qint32 val = int((0xFFFF * (i - minvalue)) / diff);
137 if (val > 0xFFFF)
138 val = 0xFFFF;
139 if (val < 0)
140 val = 0;
141
142 transfer[i] = val;
143 }
144 for (int i = maxvalue; i < 256; i++)
145 transfer[i] = 0xFFFF;
146 }
147 // apply
148 QScopedPointer<KoColorTransformation> adj(device->colorSpace()->createBrightnessContrastAdjustment(transfer.data()));
150
151 KisSequentialIteratorProgress it(device, applyRect, progressUpdater);
152
153 quint32 npix = it.nConseqPixels();
154 while(it.nextPixels(npix)) {
155
156 // adjust
157 npix = it.nConseqPixels();
158 adj->transform(it.oldRawData(), it.rawData(), npix);
159 }
160}
161
162#include "colorsfilters.moc"
@ TO_LAB16
~ColorsFilters() override
ColorsFilters(QObject *parent, const QVariantList &)
void processImpl(KisPaintDeviceSP device, const QRect &applyRect, const KisFilterConfigurationSP config, KoUpdater *progressUpdater) const override
void add(KisFilterSP item)
static KisFilterRegistry * instance()
quint32 getCount()
This function return the number of pixels used by the histogram.
void setChannel(qint32 channel)
quint32 getValue(quint8 i)
KoHistogramProducer * producer()
Calculations calculations()
const KoColorSpace * colorSpace() const
ALWAYS_INLINE quint8 * rawData()
ALWAYS_INLINE const quint8 * oldRawData() const
virtual KoColorTransformation * createBrightnessContrastAdjustment(const quint16 *transferValues) const =0
virtual qint32 numberOfBins()=0
K_PLUGIN_FACTORY_WITH_JSON(KritaASCCDLFactory, "kritaasccdl.json", registerPlugin< KritaASCCDL >();) KritaASCCDL
#define KIS_SAFE_ASSERT_RECOVER_RETURN(cond)
Definition kis_assert.h:128
const KoID FiltersCategoryAdjustId("adjust_filters", ki18nc("The category of color adjustment filters, like levels. Verb.", "Adjust"))
@ LINEAR
Definition nugrid.h:26
void setSupportsThreading(bool v)
void setShowConfigurationWidget(bool v)
void setSupportsAdjustmentLayers(bool v)
void setSupportsPainting(bool v)
void setColorSpaceIndependence(ColorSpaceIndependence v)