Krita Source Code Documentation
Loading...
Searching...
No Matches
YCbCrF32ColorSpace.cpp
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2007 Cyrille Berger (cberger@cberger.net)
3 * SPDX-FileCopyrightText: 2021 L. E. Segovia <amy@amyspark.me>
4 *
5 * SPDX-License-Identifier: LGPL-2.1-or-later
6 */
7
9#include <QDomElement>
10
11#include <QDebug>
12#include <klocalizedstring.h>
13
16#include <KoColorConversions.h>
17#include <kis_dom_utils.h>
18
20 : LcmsColorSpace<KoYCbCrF32Traits>(colorSpaceId(), name, TYPE_YCbCrA_FLT, cmsSigYCbCrData, p)
21{
22 const IccColorProfile *icc_p = dynamic_cast<const IccColorProfile *>(p);
23 Q_ASSERT(icc_p);
25 Q_ASSERT(uiRanges.size() == 3);
26
27 addChannel(new KoChannelInfo(i18n("Y"), KoYCbCrF32Traits::Y_pos * sizeof(float), KoYCbCrF32Traits::Y_pos, KoChannelInfo::COLOR, KoChannelInfo::FLOAT32, sizeof(float), Qt::cyan, uiRanges[0]));
28 addChannel(new KoChannelInfo(i18n("Cb"), KoYCbCrF32Traits::Cb_pos * sizeof(float), KoYCbCrF32Traits::Cb_pos, KoChannelInfo::COLOR, KoChannelInfo::FLOAT32, sizeof(float), Qt::magenta, uiRanges[1]));
29 addChannel(new KoChannelInfo(i18n("Cr"), KoYCbCrF32Traits::Cr_pos * sizeof(float), KoYCbCrF32Traits::Cr_pos, KoChannelInfo::COLOR, KoChannelInfo::FLOAT32, sizeof(float), Qt::yellow, uiRanges[2]));
31
32 init();
33
34 addStandardCompositeOps<KoYCbCrF32Traits>(this);
35 addStandardDitherOps<KoYCbCrF32Traits>(this);
36}
37
39{
40 if (independence == TO_RGBA16) {
41 return true;
42 } else {
43 return false;
44 }
45
46}
47
52
53void YCbCrF32ColorSpace::colorToXML(const quint8 *pixel, QDomDocument &doc, QDomElement &colorElt) const
54{
55 const KoYCbCrF32Traits::Pixel *p = reinterpret_cast<const KoYCbCrF32Traits::Pixel *>(pixel);
56 QDomElement labElt = doc.createElement("YCbCr");
60 labElt.setAttribute("space", profile()->name());
61 colorElt.appendChild(labElt);
62}
63
64void YCbCrF32ColorSpace::colorFromXML(quint8 *pixel, const QDomElement &elt) const
65{
66 KoYCbCrF32Traits::Pixel *p = reinterpret_cast<KoYCbCrF32Traits::Pixel *>(pixel);
70 p->alpha = 1.0;
71}
72
73void YCbCrF32ColorSpace::toHSY(const QVector<double> &channelValues, qreal *hue, qreal *sat, qreal *luma) const
74{
75 LabToLCH(channelValues[0],channelValues[1],channelValues[2], luma, sat, hue);
76}
77
78QVector <double> YCbCrF32ColorSpace::fromHSY(qreal *hue, qreal *sat, qreal *luma) const
79{
80 QVector <double> channelValues(4);
81 LCHToLab(*luma, *sat, *hue, &channelValues[0],&channelValues[1],&channelValues[2]);
82 channelValues[3]=1.0;
83 return channelValues;
84}
85
86void YCbCrF32ColorSpace::toYUV(const QVector<double> &channelValues, qreal *y, qreal *u, qreal *v) const
87{
88 *y =channelValues[0];
89 *u=channelValues[1];
90 *v=channelValues[2];
91}
92
93QVector <double> YCbCrF32ColorSpace::fromYUV(qreal *y, qreal *u, qreal *v) const
94{
95 QVector <double> channelValues(4);
96 channelValues[0]=*y;
97 channelValues[1]=*u;
98 channelValues[2]=*v;
99 channelValues[3]=1.0;
100 return channelValues;
101}
const Params2D p
qreal v
qreal u
void LabToLCH(const qreal l, const qreal a, const qreal b, qreal *L, qreal *C, qreal *H)
void LCHToLab(const qreal L, const qreal C, const qreal H, qreal *l, qreal *a, qreal *b)
ColorSpaceIndependence
@ TO_RGBA16
#define TYPE_YCbCrA_FLT
const QVector< KoChannelInfo::DoubleRange > & getFloatUIMinMax(void) const
@ ALPHA
The channel represents the opacity of a pixel.
@ COLOR
The channel represents a color.
@ FLOAT32
use this for a float 32bits channel
static _Tdst scaleToA(_T a)
virtual void addChannel(KoChannelInfo *ci)
const KoColorProfile * profile() const override
void toHSY(const QVector< double > &channelValues, qreal *hue, qreal *sat, qreal *luma) const override
void colorToXML(const quint8 *pixel, QDomDocument &doc, QDomElement &colorElt) const override
YCbCrF32ColorSpace(const QString &name, KoColorProfile *p)
QVector< double > fromHSY(qreal *hue, qreal *sat, qreal *luma) const override
void colorFromXML(quint8 *pixel, const QDomElement &elt) const override
bool willDegrade(ColorSpaceIndependence independence) const override
virtual KoColorSpace * clone() const
QVector< double > fromYUV(qreal *y, qreal *u, qreal *v) const override
void toYUV(const QVector< double > &channelValues, qreal *y, qreal *u, qreal *v) const override
double toDouble(const QString &str, bool *ok=nullptr)
QString toString(const QString &value)
static const qint32 alpha_pos