12#include <klocalizedstring.h>
25 Q_ASSERT(uiRanges.size() == 3);
33 addStandardCompositeOps<KoXyzF32Traits>(
this);
34 addStandardDitherOps<KoXyzF32Traits>(
this);
53 const KoXyzF32Traits::Pixel *
p =
reinterpret_cast<const KoXyzF32Traits::Pixel *
>(pixel);
54 QDomElement labElt = doc.createElement(
"XYZ");
59 colorElt.appendChild(labElt);
64 KoXyzF32Traits::Pixel *
p =
reinterpret_cast<KoXyzF32Traits::Pixel *
>(pixel);
73 qreal xyx, xyy, xyY = 0.0;
74 XYZToxyY(channelValues[0],channelValues[1],channelValues[2], &xyx, &xyy, &xyY);
75 LabToLCH(xyY,xyx,xyY, hue, sat, luma);
80 QVector <double> channelValues(4);
81 qreal xyx, xyy, xyY = 0.0;
82 LCHToLab(*luma, *sat, *hue, &xyY,&xyx,&xyy);
83 xyYToXYZ(xyx, xyy, xyY, &channelValues[0],&channelValues[1],&channelValues[2]);
90 XYZToxyY(channelValues[0],channelValues[1],channelValues[2],
u,
v, y);
95 QVector <double> channelValues(4);
96 xyYToXYZ(*
u, *
v, *y, &channelValues[0],&channelValues[1],&channelValues[2]);
void LabToLCH(const qreal l, const qreal a, const qreal b, qreal *L, qreal *C, qreal *H)
void XYZToxyY(const qreal X, const qreal Y, const qreal Z, qreal *x, qreal *y, qreal *yY)
void LCHToLab(const qreal L, const qreal C, const qreal H, qreal *l, qreal *a, qreal *b)
void xyYToXYZ(const qreal x, const qreal y, const qreal yY, qreal *X, qreal *Y, qreal *Z)
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 colorFromXML(quint8 *pixel, const QDomElement &elt) const override
void colorToXML(const quint8 *pixel, QDomDocument &doc, QDomElement &colorElt) const override
void toYUV(const QVector< double > &channelValues, qreal *y, qreal *u, qreal *v) const override
XyzF32ColorSpace(const QString &name, KoColorProfile *p)
bool willDegrade(ColorSpaceIndependence independence) const override
void toHSY(const QVector< double > &channelValues, qreal *hue, qreal *sat, qreal *luma) const override
QVector< double > fromHSY(qreal *hue, qreal *sat, qreal *luma) const override
virtual KoColorSpace * clone() const
QVector< double > fromYUV(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
static const qint32 x_pos
static const qint32 z_pos
static const qint32 y_pos