Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(730)

Side by Side Diff: core/fxge/dib/fx_dib_convert.cpp

Issue 1809943007: Remove unused FXDIB_PALETTE_ options (Closed) Base URL: https://pdfium.googlesource.com/pdfium.git@master
Patch Set: Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | core/include/fxge/fx_dib.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 PDFium Authors. All rights reserved. 1 // Copyright 2014 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6 6
7 #include "core/include/fxcodec/fx_codec.h" 7 #include "core/include/fxcodec/fx_codec.h"
8 #include "core/include/fxge/fx_dib.h" 8 #include "core/include/fxge/fx_dib.h"
9 #include "core/include/fxge/fx_ge.h" 9 #include "core/include/fxge/fx_ge.h"
10 10
11 const FX_DWORD g_dwWinPalette[256] = {
12 0xff000000, 0xff800000, 0xff008000, 0xff808000, 0xff000080, 0xff800080,
13 0xff008080, 0xff808080, 0xffC0DCC0, 0xffA6CAF0, 0xff2A3FAA, 0xff2A3FFF,
14 0xff2A5F00, 0xff2A5F55, 0xff2A5FAA, 0xff2A5FFF, 0xff2A7F00, 0xff2A7F55,
15 0xff2A7FAA, 0xff2A7FFF, 0xff2A9F00, 0xff2A9F55, 0xff2A9FAA, 0xff2A9FFF,
16 0xff2ABF00, 0xff2ABF55, 0xff2ABFAA, 0xff2ABFFF, 0xff2ADF00, 0xff2ADF55,
17 0xff2ADFAA, 0xff2ADFFF, 0xff2AFF00, 0xff2AFF55, 0xff2AFFAA, 0xff2AFFFF,
18 0xff550000, 0xff550055, 0xff5500AA, 0xff5500FF, 0xff551F00, 0xff551F55,
19 0xff551FAA, 0xff551FFF, 0xff553F00, 0xff553F55, 0xff553FAA, 0xff553FFF,
20 0xff555F00, 0xff555F55, 0xff555FAA, 0xff555FFF, 0xff557F00, 0xff557F55,
21 0xff557FAA, 0xff557FFF, 0xff559F00, 0xff559F55, 0xff559FAA, 0xff559FFF,
22 0xff55BF00, 0xff55BF55, 0xff55BFAA, 0xff55BFFF, 0xff55DF00, 0xff55DF55,
23 0xff55DFAA, 0xff55DFFF, 0xff55FF00, 0xff55FF55, 0xff55FFAA, 0xff55FFFF,
24 0xff7F0000, 0xff7F0055, 0xff7F00AA, 0xff7F00FF, 0xff7F1F00, 0xff7F1F55,
25 0xff7F1FAA, 0xff7F1FFF, 0xff7F3F00, 0xff7F3F55, 0xff7F3FAA, 0xff7F3FFF,
26 0xff7F5F00, 0xff7F5F55, 0xff7F5FAA, 0xff7F5FFF, 0xff7F7F00, 0xff7F7F55,
27 0xff7F7FAA, 0xff7F7FFF, 0xff7F9F00, 0xff7F9F55, 0xff7F9FAA, 0xff7F9FFF,
28 0xff7FBF00, 0xff7FBF55, 0xff7FBFAA, 0xff7FBFFF, 0xff7FDF00, 0xff7FDF55,
29 0xff7FDFAA, 0xff7FDFFF, 0xff00FF7F, 0xff7FFF55, 0xff7FFFAA, 0xff7FFFFF,
30 0xffAA0000, 0xffAA0055, 0xffAA00AA, 0xffAA00FF, 0xffAA1F00, 0xffAA1F55,
31 0xffAA1FAA, 0xffAA1FFF, 0xffAA3F00, 0xffAA3F55, 0xffAA3FAA, 0xffAA3FFF,
32 0xffAA5F00, 0xffAA5F55, 0xffAA5FAA, 0xffAA5FFF, 0xffAA7F00, 0xffAA7F55,
33 0xffAA7FAA, 0xffAA7FFF, 0xffAA9F00, 0xffAA9F55, 0xffAA9FAA, 0xffAA9FFF,
34 0xffAABF00, 0xffAABF55, 0xffAABFAA, 0xffAABFFF, 0xffAADF00, 0xffAADF55,
35 0xffAADFAA, 0xffAADFFF, 0xffAAFF00, 0xffAAFF55, 0xffAAFFAA, 0xffAAFFFF,
36 0xffD40000, 0xffD40055, 0xffD400AA, 0xffD400FF, 0xffD41F00, 0xffD41F55,
37 0xffD41FAA, 0xffD41FFF, 0xffD43F00, 0xffD43F55, 0xffD43FAA, 0xffD43FFF,
38 0xffD45F00, 0xffD45F55, 0xffD45FAA, 0xffD45FFF, 0xffD47F00, 0xffD47F55,
39 0xffD47FAA, 0xffD4F7FF, 0xffD49F00, 0xffD49F55, 0xffD49FAA, 0xffD49FFF,
40 0xffD4BF00, 0xffD4BF55, 0xffD4BFAA, 0xffD4BFFF, 0xffD4DF00, 0xffD4DF55,
41 0xffD4DFAA, 0xffD4DFFF, 0xffD4FF00, 0xffD4FF55, 0xffD4FFAA, 0xffD4FFFF,
42 0xffFF0055, 0xffFF00AA, 0xffFF1F00, 0xffFF1F55, 0xffFF1FAA, 0xffFF1FFF,
43 0xffFF3F00, 0xffFF3F55, 0xffFF3FAA, 0xffFF3FFF, 0xffFF5F00, 0xffFF5F55,
44 0xffFF5FAA, 0xffFF5FFF, 0xffFF7F00, 0xffFF7F55, 0xffFF7FAA, 0xffFF7FFF,
45 0xffFF9F00, 0xffFF9F55, 0xffFF9FAA, 0xffFF9FFF, 0xffFFBF00, 0xffFFBF55,
46 0xffFFBFAA, 0xffFFBFFF, 0xffFFDF00, 0xffFFDF55, 0xffFFDFAA, 0xffFFDFFF,
47 0xffFFFF55, 0xffFFFFAA, 0xffCCCCFF, 0xffFFCCFF, 0xff33FFFF, 0xff66FFFF,
48 0xff99FFFF, 0xffCCFFFF, 0xff007F00, 0xff007F55, 0xff007FAA, 0xff007FFF,
49 0xff009F00, 0xff009F55, 0xff009FAA, 0xff009FFF, 0xff00BF00, 0xff00BF55,
50 0xff00BFAA, 0xff00BFFF, 0xff00DF00, 0xff00DF55, 0xff00DFAA, 0xff00DFFF,
51 0xff00FF55, 0xff00FFAA, 0xff2A0000, 0xff2A0055, 0xff2A00AA, 0xff2A00FF,
52 0xff2A1F00, 0xff2A1F55, 0xff2A1FAA, 0xff2A1FFF, 0xff2A3F00, 0xff2A3F55,
53 0xffFFFBF0, 0xffA0A0A4, 0xff808080, 0xffFF0000, 0xff00FF00, 0xffFF0000,
54 0xff0000FF, 0xffFF00FF, 0xff00FFFF, 0xffFFFFFF};
55 const FX_DWORD g_dwMacPalette[256] = {
56 0xffFFFFFF, 0xffFFFFCC, 0xffFFFF99, 0xffFFFF66, 0xffFFFF33, 0xffFFFF00,
57 0xffFFCCFF, 0xffFFCCCC, 0xffFFCC99, 0xffFFCC66, 0xffFFCC33, 0xffFFCC00,
58 0xffFF99FF, 0xffFF99CC, 0xffFF9999, 0xffFF9966, 0xffFF9933, 0xffFF9900,
59 0xffFF66FF, 0xffFF66CC, 0xffFF6699, 0xffFF6666, 0xffFF6633, 0xffFF6600,
60 0xffFF33FF, 0xffFF33CC, 0xffFF3399, 0xffFF3366, 0xffFF3333, 0xffFF3300,
61 0xffFF00FF, 0xffFF00CC, 0xffFF0099, 0xffFF0066, 0xffFF0033, 0xffFF0000,
62 0xffCCFFFF, 0xffCCFFCC, 0xffCCFF99, 0xffCCFF66, 0xffCCFF33, 0xffCCFF00,
63 0xffCCCCFF, 0xffCCCCCC, 0xffCCCC99, 0xffCCCC66, 0xffCCCC33, 0xffCCCC00,
64 0xffCC99FF, 0xffCC99CC, 0xffCC9999, 0xffCC9966, 0xffCC9933, 0xffCC9900,
65 0xffCC66FF, 0xffCC66CC, 0xffCC6699, 0xffCC6666, 0xffCC6633, 0xffCC6600,
66 0xffCC33FF, 0xffCC33CC, 0xffCC3399, 0xffCC3366, 0xffCC3333, 0xffCC3300,
67 0xffCC00FF, 0xffCC00CC, 0xffCC0099, 0xffCC0066, 0xffCC0033, 0xffCC0000,
68 0xff99FFFF, 0xff99FFCC, 0xff99FF99, 0xff99FF66, 0xff99FF33, 0xff99FF00,
69 0xff99CCFF, 0xff99CCCC, 0xff99CC99, 0xff99CC66, 0xff99CC33, 0xff99CC00,
70 0xff9999FF, 0xff9999CC, 0xff999999, 0xff999966, 0xff999933, 0xff999900,
71 0xff9966FF, 0xff9966CC, 0xff996699, 0xff996666, 0xff996633, 0xff996600,
72 0xff9933FF, 0xff9933CC, 0xff993399, 0xff993366, 0xff993333, 0xff993300,
73 0xff9900FF, 0xff9900CC, 0xff990099, 0xff990066, 0xff990033, 0xff990000,
74 0xff66FFFF, 0xff66FFCC, 0xff66FF99, 0xff66FF66, 0xff66FF33, 0xff66FF00,
75 0xff66CCFF, 0xff66CCCC, 0xff66CC99, 0xff66CC66, 0xff66CC33, 0xff66CC00,
76 0xff6699FF, 0xff6699CC, 0xff669999, 0xff669966, 0xff669933, 0xff669900,
77 0xff6666FF, 0xff6666CC, 0xff666699, 0xff666666, 0xff666633, 0xff666600,
78 0xff6633FF, 0xff6633CC, 0xff663399, 0xff663366, 0xff663333, 0xff663300,
79 0xff6600FF, 0xff6600CC, 0xff660099, 0xff660066, 0xff660033, 0xff660000,
80 0xff33FFFF, 0xff33FFCC, 0xff33FF99, 0xff33FF66, 0xff33FF33, 0xff33FF00,
81 0xff33CCFF, 0xff33CCCC, 0xff33CC99, 0xff33CC66, 0xff33CC33, 0xff33CC00,
82 0xff3399FF, 0xff3399CC, 0xff339999, 0xff339966, 0xff339933, 0xff339900,
83 0xff3366FF, 0xff3366CC, 0xff336699, 0xff336666, 0xff336633, 0xff336600,
84 0xff3333FF, 0xff3333CC, 0xff333399, 0xff333366, 0xff333333, 0xff333300,
85 0xff3300FF, 0xff3300CC, 0xff330099, 0xff330066, 0xff330033, 0xff330000,
86 0xff00FFFF, 0xff00FFCC, 0xff00FF99, 0xff00FF66, 0xff00FF33, 0xff00FF00,
87 0xff00CCFF, 0xff00CCCC, 0xff00CC99, 0xff00CC66, 0xff00CC33, 0xff00CC00,
88 0xff0099FF, 0xff0099CC, 0xff009999, 0xff009966, 0xff009933, 0xff009900,
89 0xff0066FF, 0xff0066CC, 0xff006699, 0xff006666, 0xff006633, 0xff006600,
90 0xff0033FF, 0xff0033CC, 0xff003399, 0xff003366, 0xff003333, 0xff003300,
91 0xff0000FF, 0xff0000CC, 0xff000099, 0xff000066, 0xff000033, 0xffEE0000,
92 0xffDD0000, 0xffBB0000, 0xffAA0000, 0xff880000, 0xff770000, 0xff550000,
93 0xff440000, 0xff220000, 0xff110000, 0xff00EE00, 0xff00DD00, 0xff00BB00,
94 0xff00AA00, 0xff008800, 0xff007700, 0xff005500, 0xff004400, 0xff002200,
95 0xff001100, 0xff0000EE, 0xff0000DD, 0xff0000BB, 0xff0000AA, 0xff000088,
96 0xff000077, 0xff000055, 0xff000044, 0xff000022, 0xff000011, 0xffEEEEEE,
97 0xffDDDDDD, 0xffBBBBBB, 0xffAAAAAA, 0xff888888, 0xff777777, 0xff555555,
98 0xff444444, 0xff222222, 0xff111111, 0xff000000};
99 class CFX_Palette { 11 class CFX_Palette {
100 public: 12 public:
101 CFX_Palette(); 13 CFX_Palette();
102 ~CFX_Palette(); 14 ~CFX_Palette();
103 15
104 public: 16 FX_BOOL BuildPalette(const CFX_DIBSource* pBitmap);
105 FX_BOOL BuildPalette(const CFX_DIBSource* pBitmap, int dwPaletteType);
106 FX_DWORD* GetPalette() const { return m_pPalette; } 17 FX_DWORD* GetPalette() const { return m_pPalette; }
107
108 FX_DWORD* GetColorLut() const { return m_cLut; } 18 FX_DWORD* GetColorLut() const { return m_cLut; }
109 FX_DWORD* GetAmountLut() const { return m_aLut; } 19 FX_DWORD* GetAmountLut() const { return m_aLut; }
110 int32_t Getlut() const { return m_lut; } 20 int32_t Getlut() const { return m_lut; }
111 21
112 protected: 22 protected:
113 FX_DWORD* m_pPalette; 23 FX_DWORD* m_pPalette;
114 FX_DWORD* m_cLut; 24 FX_DWORD* m_cLut;
115 FX_DWORD* m_aLut; 25 FX_DWORD* m_aLut;
116 int m_lut; 26 int m_lut;
117 }; 27 };
(...skipping 28 matching lines...) Expand all
146 } 56 }
147 } 57 }
148 void _ColorDecode(FX_DWORD pal_v, uint8_t& r, uint8_t& g, uint8_t& b) { 58 void _ColorDecode(FX_DWORD pal_v, uint8_t& r, uint8_t& g, uint8_t& b) {
149 r = (uint8_t)((pal_v & 0xf00) >> 4); 59 r = (uint8_t)((pal_v & 0xf00) >> 4);
150 g = (uint8_t)(pal_v & 0x0f0); 60 g = (uint8_t)(pal_v & 0x0f0);
151 b = (uint8_t)((pal_v & 0x00f) << 4); 61 b = (uint8_t)((pal_v & 0x00f) << 4);
152 } 62 }
153 void _Obtain_Pal(FX_DWORD* aLut, 63 void _Obtain_Pal(FX_DWORD* aLut,
154 FX_DWORD* cLut, 64 FX_DWORD* cLut,
155 FX_DWORD* dest_pal, 65 FX_DWORD* dest_pal,
156 int pal_type,
157 FX_DWORD* win_mac_pal,
158 FX_DWORD lut) { 66 FX_DWORD lut) {
159 int row, col;
160 FX_DWORD lut_1 = lut - 1; 67 FX_DWORD lut_1 = lut - 1;
161 if (pal_type == FXDIB_PALETTE_LOC) { 68 for (int row = 0; row < 256; row++) {
162 for (row = 0; row < 256; row++) { 69 int lut_offset = lut_1 - row;
163 int lut_offset = lut_1 - row; 70 if (lut_offset < 0) {
164 if (lut_offset < 0) { 71 lut_offset += 256;
165 lut_offset += 256;
166 }
167 FX_DWORD color = cLut[lut_offset];
168 uint8_t r, g, b;
169 _ColorDecode(color, r, g, b);
170 dest_pal[row] = ((FX_DWORD)r << 16) | ((FX_DWORD)g << 8) | b | 0xff000000;
171 aLut[lut_offset] = row;
172 } 72 }
173 } else { 73 FX_DWORD color = cLut[lut_offset];
174 for (row = 0; row < 256; row++) { 74 uint8_t r;
175 int lut_offset = lut_1 - row; 75 uint8_t g;
176 if (lut_offset < 0) { 76 uint8_t b;
177 lut_offset += 256; 77 _ColorDecode(color, r, g, b);
178 } 78 dest_pal[row] = ((FX_DWORD)r << 16) | ((FX_DWORD)g << 8) | b | 0xff000000;
179 uint8_t r, g, b; 79 aLut[lut_offset] = row;
180 _ColorDecode(cLut[lut_offset], r, g, b);
181 int error, min_error = 1000000;
182 int c_index = 0;
183 for (col = 0; col < 256; col++) {
184 FX_DWORD p_color = win_mac_pal[col];
185 int d_r = r - (uint8_t)(p_color >> 16);
186 int d_g = g - (uint8_t)(p_color >> 8);
187 int d_b = b - (uint8_t)p_color;
188 error = d_r * d_r + d_g * d_g + d_b * d_b;
189 if (error < min_error) {
190 min_error = error;
191 c_index = col;
192 }
193 }
194 dest_pal[row] = win_mac_pal[c_index];
195 aLut[lut_offset] = row;
196 }
197 } 80 }
198 } 81 }
82
199 CFX_Palette::CFX_Palette() { 83 CFX_Palette::CFX_Palette() {
200 m_pPalette = NULL; 84 m_pPalette = NULL;
201 m_cLut = NULL; 85 m_cLut = NULL;
202 m_aLut = NULL; 86 m_aLut = NULL;
203 m_lut = 0; 87 m_lut = 0;
204 } 88 }
205 CFX_Palette::~CFX_Palette() { 89 CFX_Palette::~CFX_Palette() {
206 FX_Free(m_pPalette); 90 FX_Free(m_pPalette);
207 FX_Free(m_cLut); 91 FX_Free(m_cLut);
208 FX_Free(m_aLut); 92 FX_Free(m_aLut);
209 m_lut = 0; 93 m_lut = 0;
210 } 94 }
211 FX_BOOL CFX_Palette::BuildPalette(const CFX_DIBSource* pBitmap, int pal_type) { 95 FX_BOOL CFX_Palette::BuildPalette(const CFX_DIBSource* pBitmap) {
212 if (!pBitmap) { 96 if (!pBitmap) {
213 return FALSE; 97 return FALSE;
214 } 98 }
215 FX_Free(m_pPalette); 99 FX_Free(m_pPalette);
216 m_pPalette = FX_Alloc(FX_DWORD, 256); 100 m_pPalette = FX_Alloc(FX_DWORD, 256);
217 int bpp = pBitmap->GetBPP() / 8; 101 int bpp = pBitmap->GetBPP() / 8;
218 int width = pBitmap->GetWidth(); 102 int width = pBitmap->GetWidth();
219 int height = pBitmap->GetHeight(); 103 int height = pBitmap->GetHeight();
220 FX_Free(m_cLut); 104 FX_Free(m_cLut);
221 m_cLut = NULL; 105 m_cLut = NULL;
(...skipping 15 matching lines...) Expand all
237 } 121 }
238 } 122 }
239 for (row = 0; row < 4096; row++) { 123 for (row = 0; row < 4096; row++) {
240 if (m_aLut[row] != 0) { 124 if (m_aLut[row] != 0) {
241 m_aLut[m_lut] = m_aLut[row]; 125 m_aLut[m_lut] = m_aLut[row];
242 m_cLut[m_lut] = row; 126 m_cLut[m_lut] = row;
243 m_lut++; 127 m_lut++;
244 } 128 }
245 } 129 }
246 _Qsort(m_aLut, m_cLut, 0, m_lut - 1); 130 _Qsort(m_aLut, m_cLut, 0, m_lut - 1);
247 FX_DWORD* win_mac_pal = NULL; 131 _Obtain_Pal(m_aLut, m_cLut, m_pPalette, m_lut);
248 if (pal_type == FXDIB_PALETTE_WIN) {
249 win_mac_pal = (FX_DWORD*)g_dwWinPalette;
250 } else if (pal_type == FXDIB_PALETTE_MAC) {
251 win_mac_pal = (FX_DWORD*)g_dwMacPalette;
252 }
253 _Obtain_Pal(m_aLut, m_cLut, m_pPalette, pal_type, win_mac_pal, m_lut);
254 return TRUE; 132 return TRUE;
255 } 133 }
256 FX_BOOL ConvertBuffer_1bppMask2Gray(uint8_t* dest_buf, 134 FX_BOOL ConvertBuffer_1bppMask2Gray(uint8_t* dest_buf,
257 int dest_pitch, 135 int dest_pitch,
258 int width, 136 int width,
259 int height, 137 int height,
260 const CFX_DIBSource* pSrcBitmap, 138 const CFX_DIBSource* pSrcBitmap,
261 int src_left, 139 int src_left,
262 int src_top) { 140 int src_top) {
263 uint8_t set_gray, reset_gray; 141 uint8_t set_gray, reset_gray;
(...skipping 286 matching lines...) Expand 10 before | Expand all | Expand 10 after
550 int dest_pitch, 428 int dest_pitch,
551 int width, 429 int width,
552 int height, 430 int height,
553 const CFX_DIBSource* pSrcBitmap, 431 const CFX_DIBSource* pSrcBitmap,
554 int src_left, 432 int src_left,
555 int src_top, 433 int src_top,
556 FX_DWORD* dst_plt) { 434 FX_DWORD* dst_plt) {
557 int bpp = pSrcBitmap->GetBPP() / 8; 435 int bpp = pSrcBitmap->GetBPP() / 8;
558 int row, col; 436 int row, col;
559 CFX_Palette palette; 437 CFX_Palette palette;
560 palette.BuildPalette(pSrcBitmap, FXDIB_PALETTE_LOC); 438 palette.BuildPalette(pSrcBitmap);
561 FX_DWORD* cLut = palette.GetColorLut(); 439 FX_DWORD* cLut = palette.GetColorLut();
562 FX_DWORD* aLut = palette.GetAmountLut(); 440 FX_DWORD* aLut = palette.GetAmountLut();
563 if (!cLut || !aLut) { 441 if (!cLut || !aLut) {
564 return FALSE; 442 return FALSE;
565 } 443 }
566 int lut = palette.Getlut(); 444 int lut = palette.Getlut();
567 FX_DWORD* pPalette = palette.GetPalette(); 445 FX_DWORD* pPalette = palette.GetPalette();
568 if (lut > 256) { 446 if (lut > 256) {
569 int err, min_err; 447 int err, min_err;
570 int lut_256 = lut - 256; 448 int lut_256 = lut - 256;
(...skipping 647 matching lines...) Expand 10 before | Expand all | Expand 10 after
1218 if (!m_bExtBuf) { 1096 if (!m_bExtBuf) {
1219 FX_Free(m_pBuffer); 1097 FX_Free(m_pBuffer);
1220 } 1098 }
1221 m_bExtBuf = FALSE; 1099 m_bExtBuf = FALSE;
1222 m_pBuffer = dest_buf; 1100 m_pBuffer = dest_buf;
1223 m_bpp = (uint8_t)dest_format; 1101 m_bpp = (uint8_t)dest_format;
1224 m_AlphaFlag = (uint8_t)(dest_format >> 8); 1102 m_AlphaFlag = (uint8_t)(dest_format >> 8);
1225 m_Pitch = dest_pitch; 1103 m_Pitch = dest_pitch;
1226 return TRUE; 1104 return TRUE;
1227 } 1105 }
OLDNEW
« no previous file with comments | « no previous file | core/include/fxge/fx_dib.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698