blob: 2522a69e7f0e59c776be86663b0f85abcd658f2e [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
reed@android.com8a1c16f2008-12-17 15:59:43 +00002/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00003 * Copyright 2007 The Android Open Source Project
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
8
reed@android.com8a1c16f2008-12-17 15:59:43 +00009
10#ifndef SkBitmapProcState_DEFINED
11#define SkBitmapProcState_DEFINED
12
13#include "SkBitmap.h"
humper@google.comb0889472013-07-09 21:37:14 +000014#include "SkBitmapFilter.h"
reed@android.com8a1c16f2008-12-17 15:59:43 +000015#include "SkMatrix.h"
reed@google.com602a1d72013-07-23 19:13:54 +000016#include "SkScaledImageCache.h"
reed@android.com8a1c16f2008-12-17 15:59:43 +000017
reed@google.com77613a52012-03-14 12:21:17 +000018#define FractionalInt_IS_64BIT
reed@google.com4bc0a9d2012-03-07 21:47:41 +000019
20#ifdef FractionalInt_IS_64BIT
21 typedef SkFixed48 SkFractionalInt;
22 #define SkScalarToFractionalInt(x) SkScalarToFixed48(x)
23 #define SkFractionalIntToFixed(x) SkFixed48ToFixed(x)
reed@google.com411215a2012-03-08 20:13:46 +000024 #define SkFixedToFractionalInt(x) SkFixedToFixed48(x)
reed@google.com4bc0a9d2012-03-07 21:47:41 +000025 #define SkFractionalIntToInt(x) SkFixed48ToInt(x)
26#else
27 typedef SkFixed SkFractionalInt;
28 #define SkScalarToFractionalInt(x) SkScalarToFixed(x)
29 #define SkFractionalIntToFixed(x) (x)
reed@google.com411215a2012-03-08 20:13:46 +000030 #define SkFixedToFractionalInt(x) (x)
reed@google.com4bc0a9d2012-03-07 21:47:41 +000031 #define SkFractionalIntToInt(x) ((x) >> 16)
32#endif
33
reed@android.com8a1c16f2008-12-17 15:59:43 +000034class SkPaint;
humper@google.comdd850882013-07-19 20:52:12 +000035struct SkConvolutionProcs;
reed@android.com8a1c16f2008-12-17 15:59:43 +000036
37struct SkBitmapProcState {
skia.committer@gmail.comfa1bd5f2013-07-13 07:00:56 +000038
reed@google.com602a1d72013-07-23 19:13:54 +000039 SkBitmapProcState(): fScaledCacheID(NULL), fBitmapFilter(NULL) {}
reed@google.com1e182252013-07-24 20:10:42 +000040 ~SkBitmapProcState();
commit-bot@chromium.orge81d1bc2013-07-10 20:42:12 +000041
reed@android.com7a99eb12009-07-16 01:13:14 +000042 typedef void (*ShaderProc32)(const SkBitmapProcState&, int x, int y,
43 SkPMColor[], int count);
44
45 typedef void (*ShaderProc16)(const SkBitmapProcState&, int x, int y,
46 uint16_t[], int count);
47
reed@android.com8a1c16f2008-12-17 15:59:43 +000048 typedef void (*MatrixProc)(const SkBitmapProcState&,
49 uint32_t bitmapXY[],
50 int count,
51 int x, int y);
rmistry@google.comfbfcd562012-08-23 18:09:54 +000052
reed@android.com8a1c16f2008-12-17 15:59:43 +000053 typedef void (*SampleProc32)(const SkBitmapProcState&,
54 const uint32_t[],
55 int count,
56 SkPMColor colors[]);
57
58 typedef void (*SampleProc16)(const SkBitmapProcState&,
59 const uint32_t[],
60 int count,
61 uint16_t colors[]);
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +000062
reed@android.com8a1c16f2008-12-17 15:59:43 +000063 typedef U16CPU (*FixedTileProc)(SkFixed); // returns 0..0xFFFF
reed@google.comf444e8c2012-03-09 19:59:46 +000064 typedef U16CPU (*FixedTileLowBitsProc)(SkFixed, int); // returns 0..0xF
reed@android.com07d1f002009-08-13 19:35:48 +000065 typedef U16CPU (*IntTileProc)(int value, int count); // returns 0..count-1
reed@android.com7a99eb12009-07-16 01:13:14 +000066
humper@google.com9c96d4b2013-07-14 01:44:59 +000067 const SkBitmap* fBitmap; // chooseProcs - orig or scaled
68 SkMatrix fInvMatrix; // chooseProcs
reed@android.comeef375b2009-08-03 14:45:45 +000069 SkMatrix::MapXYProc fInvProc; // chooseProcs
70
reed@google.com4bc0a9d2012-03-07 21:47:41 +000071 SkFractionalInt fInvSxFractionalInt;
reed@google.com411215a2012-03-08 20:13:46 +000072 SkFractionalInt fInvKyFractionalInt;
rmistry@google.comfbfcd562012-08-23 18:09:54 +000073
reed@android.com8a1c16f2008-12-17 15:59:43 +000074 FixedTileProc fTileProcX; // chooseProcs
75 FixedTileProc fTileProcY; // chooseProcs
reed@google.comf444e8c2012-03-09 19:59:46 +000076 FixedTileLowBitsProc fTileLowBitsProcX; // chooseProcs
77 FixedTileLowBitsProc fTileLowBitsProcY; // chooseProcs
reed@android.com07d1f002009-08-13 19:35:48 +000078 IntTileProc fIntTileProcY; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000079 SkFixed fFilterOneX;
80 SkFixed fFilterOneY;
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +000081
reed@android.com8a1c16f2008-12-17 15:59:43 +000082 SkPMColor fPaintPMColor; // chooseProcs - A8 config
reed@android.comeef375b2009-08-03 14:45:45 +000083 SkFixed fInvSx; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000084 SkFixed fInvKy; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000085 uint16_t fAlphaScale; // chooseProcs
86 uint8_t fInvType; // chooseProcs
87 uint8_t fTileModeX; // CONSTRUCTOR
88 uint8_t fTileModeY; // CONSTRUCTOR
reed@google.com9cfc83c2013-07-22 17:18:18 +000089 uint8_t fFilterLevel; // chooseProcs
humper@google.com9c96d4b2013-07-14 01:44:59 +000090
91 /** The shader will let us know when we can release some of our resources
92 * like scaled bitmaps.
93 */
94
95 void endContext();
reed@android.com8a1c16f2008-12-17 15:59:43 +000096
reed@android.comc9a1d4b2009-08-03 15:05:55 +000097 /** Platforms implement this, and can optionally overwrite only the
98 following fields:
99
100 fShaderProc32
101 fShaderProc16
102 fMatrixProc
103 fSampleProc32
104 fSampleProc32
105
106 They will already have valid function pointers, so a platform that does
107 not have an accelerated version can just leave that field as is. A valid
108 implementation can do nothing (see SkBitmapProcState_opts_none.cpp)
109 */
110 void platformProcs();
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +0000111
humper@google.com138ebc32013-07-19 20:20:04 +0000112 /** Platforms can also optionally overwrite the convolution functions
113 if we have SIMD versions of them.
114 */
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +0000115
reed@google.comfed04b32013-09-05 20:31:17 +0000116 void platformConvolutionProcs(SkConvolutionProcs*);
reed@google.com4c69a062013-05-23 20:11:56 +0000117
reed@android.com258cb222010-04-14 13:36:33 +0000118 /** Given the byte size of the index buffer to be passed to the matrix proc,
119 return the maximum number of resulting pixels that can be computed
120 (i.e. the number of SkPMColor values to be written by the sample proc).
121 This routine takes into account that filtering and scale-vs-affine
122 affect the amount of buffer space needed.
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000123
reed@android.com4c128c42009-08-14 13:54:37 +0000124 Only valid to call after chooseProcs (setContext) has been called. It is
125 safe to call this inside the shader's shadeSpan() method.
126 */
127 int maxCountForBufferSize(size_t bufferSize) const;
128
reed@google.com9fe287b2012-03-27 15:54:28 +0000129 // If a shader proc is present, then the corresponding matrix/sample procs
130 // are ignored
131 ShaderProc32 getShaderProc32() const { return fShaderProc32; }
132 ShaderProc16 getShaderProc16() const { return fShaderProc16; }
skia.committer@gmail.com9e1ec1a2013-07-10 07:00:58 +0000133
humper@google.comb0889472013-07-09 21:37:14 +0000134 SkBitmapFilter* getBitmapFilter() const { return fBitmapFilter; }
reed@google.com9fe287b2012-03-27 15:54:28 +0000135
136#ifdef SK_DEBUG
137 MatrixProc getMatrixProc() const;
138#else
139 MatrixProc getMatrixProc() const { return fMatrixProc; }
140#endif
141 SampleProc32 getSampleProc32() const { return fSampleProc32; }
142 SampleProc16 getSampleProc16() const { return fSampleProc16; }
143
reed@android.com8a1c16f2008-12-17 15:59:43 +0000144private:
reed@android.comeef375b2009-08-03 14:45:45 +0000145 friend class SkBitmapProcShader;
146
reed@google.com9fe287b2012-03-27 15:54:28 +0000147 ShaderProc32 fShaderProc32; // chooseProcs
148 ShaderProc16 fShaderProc16; // chooseProcs
149 // These are used if the shaderproc is NULL
150 MatrixProc fMatrixProc; // chooseProcs
151 SampleProc32 fSampleProc32; // chooseProcs
152 SampleProc16 fSampleProc16; // chooseProcs
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000153
reed@android.comeef375b2009-08-03 14:45:45 +0000154 SkBitmap fOrigBitmap; // CONSTRUCTOR
humper@google.com9c96d4b2013-07-14 01:44:59 +0000155 SkBitmap fScaledBitmap; // chooseProcs
reed@android.comeef375b2009-08-03 14:45:45 +0000156
reed@google.com602a1d72013-07-23 19:13:54 +0000157 SkScaledImageCache::ID* fScaledCacheID;
158
reed@android.com07d1f002009-08-13 19:35:48 +0000159 MatrixProc chooseMatrixProc(bool trivial_matrix);
reed@android.comeef375b2009-08-03 14:45:45 +0000160 bool chooseProcs(const SkMatrix& inv, const SkPaint&);
reed@google.com9a4c7462012-10-12 18:21:37 +0000161 ShaderProc32 chooseShaderProc32();
skia.committer@gmail.comfa1bd5f2013-07-13 07:00:56 +0000162
humper@google.com9c96d4b2013-07-14 01:44:59 +0000163 void possiblyScaleImage();
164
humper@google.com138ebc32013-07-19 20:20:04 +0000165 SkBitmapFilter* fBitmapFilter;
skia.committer@gmail.comb0a327e2012-11-21 02:02:25 +0000166
mtklein@google.com0dc546c2013-08-26 16:21:35 +0000167 // If supported, sets fShaderProc32 and fShaderProc16 and returns true,
168 // otherwise returns false.
169 bool setBitmapFilterProcs();
skia.committer@gmail.com3e2345a2013-05-24 07:01:26 +0000170
reed@google.com6bb92bc2012-11-20 19:45:16 +0000171 // Return false if we failed to setup for fast translate (e.g. overflow)
172 bool setupForTranslate();
reed@google.com9fe287b2012-03-27 15:54:28 +0000173
174#ifdef SK_DEBUG
175 static void DebugMatrixProc(const SkBitmapProcState&,
176 uint32_t[], int count, int x, int y);
177#endif
reed@android.com8a1c16f2008-12-17 15:59:43 +0000178};
179
reed@android.com07d1f002009-08-13 19:35:48 +0000180/* Macros for packing and unpacking pairs of 16bit values in a 32bit uint.
181 Used to allow access to a stream of uint16_t either one at a time, or
182 2 at a time by unpacking a uint32_t
183 */
184#ifdef SK_CPU_BENDIAN
185 #define PACK_TWO_SHORTS(pri, sec) ((pri) << 16 | (sec))
186 #define UNPACK_PRIMARY_SHORT(packed) ((uint32_t)(packed) >> 16)
187 #define UNPACK_SECONDARY_SHORT(packed) ((packed) & 0xFFFF)
188#else
189 #define PACK_TWO_SHORTS(pri, sec) ((pri) | ((sec) << 16))
190 #define UNPACK_PRIMARY_SHORT(packed) ((packed) & 0xFFFF)
191 #define UNPACK_SECONDARY_SHORT(packed) ((uint32_t)(packed) >> 16)
192#endif
193
194#ifdef SK_DEBUG
195 static inline uint32_t pack_two_shorts(U16CPU pri, U16CPU sec) {
196 SkASSERT((uint16_t)pri == pri);
197 SkASSERT((uint16_t)sec == sec);
198 return PACK_TWO_SHORTS(pri, sec);
199 }
200#else
201 #define pack_two_shorts(pri, sec) PACK_TWO_SHORTS(pri, sec)
202#endif
203
senorblanco@chromium.orgdc7de742009-11-30 20:00:29 +0000204// These functions are generated via macros, but are exposed here so that
205// platformProcs may test for them by name.
206void S32_opaque_D32_filter_DX(const SkBitmapProcState& s, const uint32_t xy[],
207 int count, SkPMColor colors[]);
senorblanco@chromium.orgf3f0bd72009-12-10 22:46:31 +0000208void S32_alpha_D32_filter_DX(const SkBitmapProcState& s, const uint32_t xy[],
209 int count, SkPMColor colors[]);
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000210void S32_opaque_D32_filter_DXDY(const SkBitmapProcState& s,
mtklein@google.com0dc546c2013-08-26 16:21:35 +0000211 const uint32_t xy[], int count, SkPMColor colors[]);
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000212void S32_alpha_D32_filter_DXDY(const SkBitmapProcState& s,
mtklein@google.com0dc546c2013-08-26 16:21:35 +0000213 const uint32_t xy[], int count, SkPMColor colors[]);
tomhudson@google.com06a73132012-02-22 18:30:43 +0000214void ClampX_ClampY_filter_scale(const SkBitmapProcState& s, uint32_t xy[],
215 int count, int x, int y);
216void ClampX_ClampY_nofilter_scale(const SkBitmapProcState& s, uint32_t xy[],
217 int count, int x, int y);
tomhudson@google.com5efaf262012-02-28 15:41:49 +0000218void ClampX_ClampY_filter_affine(const SkBitmapProcState& s,
219 uint32_t xy[], int count, int x, int y);
220void ClampX_ClampY_nofilter_affine(const SkBitmapProcState& s,
221 uint32_t xy[], int count, int x, int y);
reed@google.com78662282012-07-24 13:53:23 +0000222void S32_D16_filter_DX(const SkBitmapProcState& s,
mtklein@google.com0dc546c2013-08-26 16:21:35 +0000223 const uint32_t* xy, int count, uint16_t* colors);
senorblanco@chromium.orgdc7de742009-11-30 20:00:29 +0000224
mtklein@google.com0dc546c2013-08-26 16:21:35 +0000225void highQualityFilter32(const SkBitmapProcState &s, int x, int y,
226 SkPMColor *SK_RESTRICT colors, int count);
227void highQualityFilter16(const SkBitmapProcState &s, int x, int y,
228 uint16_t *SK_RESTRICT colors, int count);
skia.committer@gmail.com9e1ec1a2013-07-10 07:00:58 +0000229
humper@google.comb0889472013-07-09 21:37:14 +0000230
reed@android.com8a1c16f2008-12-17 15:59:43 +0000231#endif