12#include <klocalizedstring.h>
29 addStandardCompositeOps<KoXyzF16Traits>(
this);
30 addStandardDitherOps<KoXyzF16Traits>(
this);
49 const KoXyzF16Traits::Pixel *
p =
reinterpret_cast<const KoXyzF16Traits::Pixel *
>(pixel);
50 QDomElement labElt = doc.createElement(
"XYZ");
55 colorElt.appendChild(labElt);
60 KoXyzF16Traits::Pixel *
p =
reinterpret_cast<KoXyzF16Traits::Pixel *
>(pixel);
69 qreal xyx, xyy, xyY = 0.0;
70 XYZToxyY(channelValues[0],channelValues[1],channelValues[2], &xyx, &xyy, &xyY);
71 LabToLCH(xyY,xyx,xyY, hue, sat, luma);
76 QVector <double> channelValues(4);
77 qreal xyx, xyy, xyY = 0.0;
78 LCHToLab(*luma, *sat, *hue, &xyY,&xyx,&xyy);
79 xyYToXYZ(xyx, xyy, xyY, &channelValues[0],&channelValues[1],&channelValues[2]);
86 XYZToxyY(channelValues[0],channelValues[1],channelValues[2],
u,
v, y);
91 QVector <double> channelValues(4);
92 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)
#define TYPE_XYZA_HALF_FLT
@ ALPHA
The channel represents the opacity of a pixel.
@ COLOR
The channel represents a color.
@ FLOAT16
use this for a float 16bits channel
static _Tdst scaleToA(_T a)
virtual void addChannel(KoChannelInfo *ci)
const KoColorProfile * profile() const override
XyzF16ColorSpace(const QString &name, KoColorProfile *p)
QVector< double > fromHSY(qreal *hue, qreal *sat, qreal *luma) const override
bool willDegrade(ColorSpaceIndependence independence) const override
void toYUV(const QVector< double > &channelValues, qreal *y, qreal *u, qreal *v) const override
QVector< double > fromYUV(qreal *y, qreal *u, qreal *v) const override
void colorToXML(const quint8 *pixel, QDomDocument &doc, QDomElement &colorElt) const override
virtual KoColorSpace * clone() const
void toHSY(const QVector< double > &channelValues, qreal *hue, qreal *sat, qreal *luma) const override
void colorFromXML(quint8 *pixel, const QDomElement &elt) const override
double toDouble(const QString &str, bool *ok=nullptr)
QString toString(const QString &value)