2
* Copyright (c) 2004-2006 Cyrille Berger <cberger@cberger.net>
4
* This program is free software; you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License as published by
6
* the Free Software Foundation; either version 2 of the License, or
7
* (at your option) any later version.
9
* This program is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
14
* You should have received a copy of the GNU General Public License
15
* along with this program; if not, write to the Free Software
16
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18
#ifndef KIS_GRAY_COLORSPACE_H_
19
#define KIS_GRAY_COLORSPACE_H_
22
#include <pigment_gray_u8_export.h>
23
#include <KoLcmsColorSpace.h>
24
#include <KoColorSpaceTraits.h>
25
#include "KoColorModelStandardIds.h"
27
typedef KoColorSpaceTrait<quint8, 2, 1> GrayAU8Traits;
29
class PIGMENT_GRAY_U8_EXPORT KisGrayAU8ColorSpace : public KoLcmsColorSpace<GrayAU8Traits>
32
KisGrayAU8ColorSpace(KoColorProfile *p);
33
virtual bool willDegrade(ColorSpaceIndependence ) const { return false; }
34
virtual KoID colorModelId() const { return GrayAColorModelID; }
35
virtual KoID colorDepthId() const { return Integer8BitsColorDepthID; }
36
virtual KoColorSpace* clone() const;
37
virtual void colorToXML( const quint8* pixel, QDomDocument& doc, QDomElement& colorElt) const;
38
virtual void colorFromXML( quint8* pixel, const QDomElement& elt) const;
41
class KisGrayAU8ColorSpaceFactory : public KoLcmsColorSpaceFactory
44
KisGrayAU8ColorSpaceFactory() : KoLcmsColorSpaceFactory(TYPE_GRAYA_8, icSigGrayData )
47
virtual QString id() const { return "GRAYA"; }
48
virtual QString name() const { return i18n("Grayscale (8-bit integer/channel)"); }
49
virtual KoID colorModelId() const { return GrayAColorModelID; }
50
virtual KoID colorDepthId() const { return Integer8BitsColorDepthID; }
51
virtual int referenceDepth() const { return 8; }
52
virtual bool userVisible() const { return true; }
54
virtual KoColorSpace *createColorSpace( const KoColorProfile *p) const { return new KisGrayAU8ColorSpace( p->clone()); }
56
virtual QString defaultProfile() const { return "gray built-in - (lcms internal)"; }
59
#endif // KIS_STRATEGY_COLORSPACE_GRAYSCALE_H_