Make UEFI boot-platform build again
[haiku.git] / headers / libs / print / libprint / Halftone.h
blobf72691a8f6ab83d7f12440aa67a4ed06b55afe4b
1 /*
2 * Halftone.h
3 * Copyright 1999-2000 Y.Takagi. All Rights Reserved.
4 */
6 #ifndef __HALFTONE_H
7 #define __HALFTONE_H
9 #include <GraphicsDefs.h>
11 // definition for B_RGB32 (=B_RGB32_LITTLE) and B_RGBA32
12 typedef struct {
13 uchar blue;
14 uchar green;
15 uchar red;
16 uchar alpha; // unused in B_RGB32
17 } ColorRGB32Little;
19 // definition for B_RGB32_BIG and B_RGBA32_BIG
20 typedef struct {
21 uchar alpha; // unused in B_RGB32_BIG
22 uchar red;
23 uchar green;
24 uchar blue;
25 } ColorRGB32Big;
27 typedef union {
28 ColorRGB32Little little;
29 ColorRGB32Big big;
30 } ColorRGB32;
32 class Halftone;
34 typedef void (Halftone::*PFN_dither)(uchar* destination, const uchar* source,
35 int x, int y, int width);
37 typedef uint (*PFN_gray)(ColorRGB32 c);
39 class Halftone {
40 public:
41 enum DitherType {
42 kType1,
43 kType2,
44 kType3,
45 kTypeFloydSteinberg,
48 enum GrayFunction {
49 kMixToGray,
50 kRedChannel,
51 kGreenChannel,
52 kBlueChannel
55 enum Planes {
56 kPlaneMonochrome1, // 1 bit depth (0 white, 1 black)
57 kPlaneRGB1, // 3 planes, 1 bit depth (0 black, 7 white)
60 enum BlackValue {
61 kHighValueMeansBlack,
62 kLowValueMeansBlack,
65 Halftone(color_space colorSpace, double gamma = 1.4,
66 double min = 0.0,
67 DitherType dither_type = kTypeFloydSteinberg);
68 ~Halftone();
70 void SetPlanes(Planes planes);
71 void SetBlackValue(BlackValue blackValue);
73 void Dither(uchar *destination, const uchar *source, int x,
74 int y, int width);
76 int GetPixelDepth() const;
78 const uchar* GetPattern() const;
79 void SetPattern(const uchar *pattern);
81 protected:
82 Halftone(const Halftone &);
84 Halftone& operator=(const Halftone &);
86 // PFN_gray: return value of 0 means low density (or black) and
87 // value of 255 means high density (or white)
88 PFN_gray GetGrayFunction() const;
89 void SetGrayFunction(PFN_gray gray);
90 void SetGrayFunction(GrayFunction grayFunction);
92 void CreateGammaTable(double gamma, double min);
93 void InitElements(int x, int y, uchar* elements);
94 uint GetDensity(ColorRGB32 c) const;
95 uchar ConvertUsingBlackValue(uchar byte) const;
96 void DitherRGB32(uchar* destination, const uchar* source,
97 int x, int y, int width);
99 void InitFloydSteinberg();
100 void DeleteErrorTables();
101 void UninitFloydSteinberg();
102 void SetupErrorBuffer(int x, int y, int width);
103 void DitherFloydSteinberg(uchar* destination,
104 const uchar* source, int x, int y, int width);
106 private:
107 enum {
108 kGammaTableSize = 256,
109 kMaxNumberOfPlanes = 3
112 PFN_dither fDither;
113 PFN_gray fGray;
114 int fPixelDepth;
115 Planes fPlanes;
116 BlackValue fBlackValue;
117 const uchar* fPattern;
118 uint fGammaTable[kGammaTableSize];
119 int fNumberOfPlanes;
120 int fCurrentPlane;
121 // fields used for floyd-steinberg dithering
122 int fX;
123 int fY;
124 int fWidth;
125 int* fErrorTables[kMaxNumberOfPlanes];
129 inline int
130 Halftone::GetPixelDepth() const
132 return fPixelDepth;
136 inline const uchar*
137 Halftone::GetPattern() const
139 return fPattern;
143 inline void
144 Halftone::SetPattern(const uchar* pattern)
146 fPattern = pattern;
150 inline PFN_gray
151 Halftone::GetGrayFunction() const
153 return fGray;
157 inline void
158 Halftone::SetGrayFunction(PFN_gray gray)
160 fGray = gray;
164 inline uint
165 Halftone::GetDensity(ColorRGB32 c) const
167 return fGammaTable[fGray(c)];
171 inline uchar
172 Halftone::ConvertUsingBlackValue(uchar byte) const
174 // bits with value = '1' in byte mean black
175 if (fBlackValue == kHighValueMeansBlack)
176 return byte;
178 return ~byte;
182 #endif /* __HALFTONE_H */