blob: e138ed269864c3c5b0453593514b1ec6b6daa877 [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
humper@google.com138ebc32013-07-19 20:20:04 +000082 SkConvolutionProcs* fConvolutionProcs; // possiblyScaleImage
reed@android.com8a1c16f2008-12-17 15:59:43 +000083
reed@android.com8a1c16f2008-12-17 15:59:43 +000084 SkPMColor fPaintPMColor; // chooseProcs - A8 config
reed@android.comeef375b2009-08-03 14:45:45 +000085 SkFixed fInvSx; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000086 SkFixed fInvKy; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000087 uint16_t fAlphaScale; // chooseProcs
88 uint8_t fInvType; // chooseProcs
89 uint8_t fTileModeX; // CONSTRUCTOR
90 uint8_t fTileModeY; // CONSTRUCTOR
reed@google.com9cfc83c2013-07-22 17:18:18 +000091 uint8_t fFilterLevel; // chooseProcs
humper@google.com9c96d4b2013-07-14 01:44:59 +000092
93 /** The shader will let us know when we can release some of our resources
94 * like scaled bitmaps.
95 */
96
97 void endContext();
reed@android.com8a1c16f2008-12-17 15:59:43 +000098
reed@android.comc9a1d4b2009-08-03 15:05:55 +000099 /** Platforms implement this, and can optionally overwrite only the
100 following fields:
101
102 fShaderProc32
103 fShaderProc16
104 fMatrixProc
105 fSampleProc32
106 fSampleProc32
107
108 They will already have valid function pointers, so a platform that does
109 not have an accelerated version can just leave that field as is. A valid
110 implementation can do nothing (see SkBitmapProcState_opts_none.cpp)
111 */
112 void platformProcs();
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +0000113
humper@google.com138ebc32013-07-19 20:20:04 +0000114 /** Platforms can also optionally overwrite the convolution functions
115 if we have SIMD versions of them.
116 */
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +0000117
humper@google.com138ebc32013-07-19 20:20:04 +0000118 void platformConvolutionProcs();
reed@google.com4c69a062013-05-23 20:11:56 +0000119
reed@android.com258cb222010-04-14 13:36:33 +0000120 /** Given the byte size of the index buffer to be passed to the matrix proc,
121 return the maximum number of resulting pixels that can be computed
122 (i.e. the number of SkPMColor values to be written by the sample proc).
123 This routine takes into account that filtering and scale-vs-affine
124 affect the amount of buffer space needed.
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000125
reed@android.com4c128c42009-08-14 13:54:37 +0000126 Only valid to call after chooseProcs (setContext) has been called. It is
127 safe to call this inside the shader's shadeSpan() method.
128 */
129 int maxCountForBufferSize(size_t bufferSize) const;
130
reed@google.com9fe287b2012-03-27 15:54:28 +0000131 // If a shader proc is present, then the corresponding matrix/sample procs
132 // are ignored
133 ShaderProc32 getShaderProc32() const { return fShaderProc32; }
134 ShaderProc16 getShaderProc16() const { return fShaderProc16; }
skia.committer@gmail.com9e1ec1a2013-07-10 07:00:58 +0000135
humper@google.comb0889472013-07-09 21:37:14 +0000136 SkBitmapFilter* getBitmapFilter() const { return fBitmapFilter; }
reed@google.com9fe287b2012-03-27 15:54:28 +0000137
138#ifdef SK_DEBUG
139 MatrixProc getMatrixProc() const;
140#else
141 MatrixProc getMatrixProc() const { return fMatrixProc; }
142#endif
143 SampleProc32 getSampleProc32() const { return fSampleProc32; }
144 SampleProc16 getSampleProc16() const { return fSampleProc16; }
145
reed@android.com8a1c16f2008-12-17 15:59:43 +0000146private:
reed@android.comeef375b2009-08-03 14:45:45 +0000147 friend class SkBitmapProcShader;
148
reed@google.com9fe287b2012-03-27 15:54:28 +0000149 ShaderProc32 fShaderProc32; // chooseProcs
150 ShaderProc16 fShaderProc16; // chooseProcs
151 // These are used if the shaderproc is NULL
152 MatrixProc fMatrixProc; // chooseProcs
153 SampleProc32 fSampleProc32; // chooseProcs
154 SampleProc16 fSampleProc16; // chooseProcs
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000155
reed@android.comeef375b2009-08-03 14:45:45 +0000156 SkBitmap fOrigBitmap; // CONSTRUCTOR
humper@google.com9c96d4b2013-07-14 01:44:59 +0000157 SkBitmap fScaledBitmap; // chooseProcs
reed@android.comeef375b2009-08-03 14:45:45 +0000158
reed@google.com602a1d72013-07-23 19:13:54 +0000159 SkScaledImageCache::ID* fScaledCacheID;
160
reed@android.com07d1f002009-08-13 19:35:48 +0000161 MatrixProc chooseMatrixProc(bool trivial_matrix);
reed@android.comeef375b2009-08-03 14:45:45 +0000162 bool chooseProcs(const SkMatrix& inv, const SkPaint&);
reed@google.com9a4c7462012-10-12 18:21:37 +0000163 ShaderProc32 chooseShaderProc32();
skia.committer@gmail.comfa1bd5f2013-07-13 07:00:56 +0000164
humper@google.com9c96d4b2013-07-14 01:44:59 +0000165 void possiblyScaleImage();
166
humper@google.com138ebc32013-07-19 20:20:04 +0000167 SkBitmapFilter* fBitmapFilter;
skia.committer@gmail.comb0a327e2012-11-21 02:02:25 +0000168
humper@google.com9c96d4b2013-07-14 01:44:59 +0000169 ShaderProc32 chooseBitmapFilterProc();
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,
211 const uint32_t xy[], int count, SkPMColor colors[]);
212void S32_alpha_D32_filter_DXDY(const SkBitmapProcState& s,
tomhudson@google.comae29b882012-03-06 14:59:04 +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,
223 const uint32_t* xy, int count, uint16_t* colors);
senorblanco@chromium.orgdc7de742009-11-30 20:00:29 +0000224
humper@google.comb0889472013-07-09 21:37:14 +0000225void highQualityFilter(const SkBitmapProcState &s, int x, int y,
226 SkPMColor *SK_RESTRICT colors, int count);
skia.committer@gmail.com9e1ec1a2013-07-10 07:00:58 +0000227
humper@google.comb0889472013-07-09 21:37:14 +0000228
reed@android.com8a1c16f2008-12-17 15:59:43 +0000229#endif