blob: 70d7c0cb04e1c4eb586b6cc1fd0094580b02294e [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) {}
commit-bot@chromium.orge81d1bc2013-07-10 20:42:12 +000040 ~SkBitmapProcState() {
reed@google.com602a1d72013-07-23 19:13:54 +000041 SkASSERT(NULL == fScaledCacheID);
commit-bot@chromium.orge81d1bc2013-07-10 20:42:12 +000042 SkDELETE(fBitmapFilter);
43 }
44
reed@android.com7a99eb12009-07-16 01:13:14 +000045 typedef void (*ShaderProc32)(const SkBitmapProcState&, int x, int y,
46 SkPMColor[], int count);
47
48 typedef void (*ShaderProc16)(const SkBitmapProcState&, int x, int y,
49 uint16_t[], int count);
50
reed@android.com8a1c16f2008-12-17 15:59:43 +000051 typedef void (*MatrixProc)(const SkBitmapProcState&,
52 uint32_t bitmapXY[],
53 int count,
54 int x, int y);
rmistry@google.comfbfcd562012-08-23 18:09:54 +000055
reed@android.com8a1c16f2008-12-17 15:59:43 +000056 typedef void (*SampleProc32)(const SkBitmapProcState&,
57 const uint32_t[],
58 int count,
59 SkPMColor colors[]);
60
61 typedef void (*SampleProc16)(const SkBitmapProcState&,
62 const uint32_t[],
63 int count,
64 uint16_t colors[]);
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +000065
reed@android.com8a1c16f2008-12-17 15:59:43 +000066 typedef U16CPU (*FixedTileProc)(SkFixed); // returns 0..0xFFFF
reed@google.comf444e8c2012-03-09 19:59:46 +000067 typedef U16CPU (*FixedTileLowBitsProc)(SkFixed, int); // returns 0..0xF
reed@android.com07d1f002009-08-13 19:35:48 +000068 typedef U16CPU (*IntTileProc)(int value, int count); // returns 0..count-1
reed@android.com7a99eb12009-07-16 01:13:14 +000069
humper@google.com9c96d4b2013-07-14 01:44:59 +000070 const SkBitmap* fBitmap; // chooseProcs - orig or scaled
71 SkMatrix fInvMatrix; // chooseProcs
reed@android.comeef375b2009-08-03 14:45:45 +000072 SkMatrix::MapXYProc fInvProc; // chooseProcs
73
reed@google.com4bc0a9d2012-03-07 21:47:41 +000074 SkFractionalInt fInvSxFractionalInt;
reed@google.com411215a2012-03-08 20:13:46 +000075 SkFractionalInt fInvKyFractionalInt;
rmistry@google.comfbfcd562012-08-23 18:09:54 +000076
reed@android.com8a1c16f2008-12-17 15:59:43 +000077 FixedTileProc fTileProcX; // chooseProcs
78 FixedTileProc fTileProcY; // chooseProcs
reed@google.comf444e8c2012-03-09 19:59:46 +000079 FixedTileLowBitsProc fTileLowBitsProcX; // chooseProcs
80 FixedTileLowBitsProc fTileLowBitsProcY; // chooseProcs
reed@android.com07d1f002009-08-13 19:35:48 +000081 IntTileProc fIntTileProcY; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000082 SkFixed fFilterOneX;
83 SkFixed fFilterOneY;
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +000084
humper@google.com138ebc32013-07-19 20:20:04 +000085 SkConvolutionProcs* fConvolutionProcs; // possiblyScaleImage
reed@android.com8a1c16f2008-12-17 15:59:43 +000086
reed@android.com8a1c16f2008-12-17 15:59:43 +000087 SkPMColor fPaintPMColor; // chooseProcs - A8 config
reed@android.comeef375b2009-08-03 14:45:45 +000088 SkFixed fInvSx; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000089 SkFixed fInvKy; // chooseProcs
reed@android.com8a1c16f2008-12-17 15:59:43 +000090 uint16_t fAlphaScale; // chooseProcs
91 uint8_t fInvType; // chooseProcs
92 uint8_t fTileModeX; // CONSTRUCTOR
93 uint8_t fTileModeY; // CONSTRUCTOR
reed@google.com9cfc83c2013-07-22 17:18:18 +000094 uint8_t fFilterLevel; // chooseProcs
humper@google.com9c96d4b2013-07-14 01:44:59 +000095
96 /** The shader will let us know when we can release some of our resources
97 * like scaled bitmaps.
98 */
99
100 void endContext();
reed@android.com8a1c16f2008-12-17 15:59:43 +0000101
reed@android.comc9a1d4b2009-08-03 15:05:55 +0000102 /** Platforms implement this, and can optionally overwrite only the
103 following fields:
104
105 fShaderProc32
106 fShaderProc16
107 fMatrixProc
108 fSampleProc32
109 fSampleProc32
110
111 They will already have valid function pointers, so a platform that does
112 not have an accelerated version can just leave that field as is. A valid
113 implementation can do nothing (see SkBitmapProcState_opts_none.cpp)
114 */
115 void platformProcs();
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +0000116
humper@google.com138ebc32013-07-19 20:20:04 +0000117 /** Platforms can also optionally overwrite the convolution functions
118 if we have SIMD versions of them.
119 */
skia.committer@gmail.com1f3c7382013-07-20 07:00:58 +0000120
humper@google.com138ebc32013-07-19 20:20:04 +0000121 void platformConvolutionProcs();
reed@google.com4c69a062013-05-23 20:11:56 +0000122
reed@android.com258cb222010-04-14 13:36:33 +0000123 /** Given the byte size of the index buffer to be passed to the matrix proc,
124 return the maximum number of resulting pixels that can be computed
125 (i.e. the number of SkPMColor values to be written by the sample proc).
126 This routine takes into account that filtering and scale-vs-affine
127 affect the amount of buffer space needed.
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000128
reed@android.com4c128c42009-08-14 13:54:37 +0000129 Only valid to call after chooseProcs (setContext) has been called. It is
130 safe to call this inside the shader's shadeSpan() method.
131 */
132 int maxCountForBufferSize(size_t bufferSize) const;
133
reed@google.com9fe287b2012-03-27 15:54:28 +0000134 // If a shader proc is present, then the corresponding matrix/sample procs
135 // are ignored
136 ShaderProc32 getShaderProc32() const { return fShaderProc32; }
137 ShaderProc16 getShaderProc16() const { return fShaderProc16; }
skia.committer@gmail.com9e1ec1a2013-07-10 07:00:58 +0000138
humper@google.comb0889472013-07-09 21:37:14 +0000139 SkBitmapFilter* getBitmapFilter() const { return fBitmapFilter; }
reed@google.com9fe287b2012-03-27 15:54:28 +0000140
141#ifdef SK_DEBUG
142 MatrixProc getMatrixProc() const;
143#else
144 MatrixProc getMatrixProc() const { return fMatrixProc; }
145#endif
146 SampleProc32 getSampleProc32() const { return fSampleProc32; }
147 SampleProc16 getSampleProc16() const { return fSampleProc16; }
148
reed@android.com8a1c16f2008-12-17 15:59:43 +0000149private:
reed@android.comeef375b2009-08-03 14:45:45 +0000150 friend class SkBitmapProcShader;
151
reed@google.com9fe287b2012-03-27 15:54:28 +0000152 ShaderProc32 fShaderProc32; // chooseProcs
153 ShaderProc16 fShaderProc16; // chooseProcs
154 // These are used if the shaderproc is NULL
155 MatrixProc fMatrixProc; // chooseProcs
156 SampleProc32 fSampleProc32; // chooseProcs
157 SampleProc16 fSampleProc16; // chooseProcs
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000158
reed@android.comeef375b2009-08-03 14:45:45 +0000159 SkBitmap fOrigBitmap; // CONSTRUCTOR
humper@google.com9c96d4b2013-07-14 01:44:59 +0000160 SkBitmap fScaledBitmap; // chooseProcs
reed@android.comeef375b2009-08-03 14:45:45 +0000161
reed@google.com602a1d72013-07-23 19:13:54 +0000162 SkScaledImageCache::ID* fScaledCacheID;
163
reed@android.com07d1f002009-08-13 19:35:48 +0000164 MatrixProc chooseMatrixProc(bool trivial_matrix);
reed@android.comeef375b2009-08-03 14:45:45 +0000165 bool chooseProcs(const SkMatrix& inv, const SkPaint&);
reed@google.com9a4c7462012-10-12 18:21:37 +0000166 ShaderProc32 chooseShaderProc32();
skia.committer@gmail.comfa1bd5f2013-07-13 07:00:56 +0000167
humper@google.com9c96d4b2013-07-14 01:44:59 +0000168 void possiblyScaleImage();
169
humper@google.com138ebc32013-07-19 20:20:04 +0000170 SkBitmapFilter* fBitmapFilter;
skia.committer@gmail.comb0a327e2012-11-21 02:02:25 +0000171
humper@google.com9c96d4b2013-07-14 01:44:59 +0000172 ShaderProc32 chooseBitmapFilterProc();
skia.committer@gmail.com3e2345a2013-05-24 07:01:26 +0000173
reed@google.com6bb92bc2012-11-20 19:45:16 +0000174 // Return false if we failed to setup for fast translate (e.g. overflow)
175 bool setupForTranslate();
reed@google.com9fe287b2012-03-27 15:54:28 +0000176
177#ifdef SK_DEBUG
178 static void DebugMatrixProc(const SkBitmapProcState&,
179 uint32_t[], int count, int x, int y);
180#endif
reed@android.com8a1c16f2008-12-17 15:59:43 +0000181};
182
reed@android.com07d1f002009-08-13 19:35:48 +0000183/* Macros for packing and unpacking pairs of 16bit values in a 32bit uint.
184 Used to allow access to a stream of uint16_t either one at a time, or
185 2 at a time by unpacking a uint32_t
186 */
187#ifdef SK_CPU_BENDIAN
188 #define PACK_TWO_SHORTS(pri, sec) ((pri) << 16 | (sec))
189 #define UNPACK_PRIMARY_SHORT(packed) ((uint32_t)(packed) >> 16)
190 #define UNPACK_SECONDARY_SHORT(packed) ((packed) & 0xFFFF)
191#else
192 #define PACK_TWO_SHORTS(pri, sec) ((pri) | ((sec) << 16))
193 #define UNPACK_PRIMARY_SHORT(packed) ((packed) & 0xFFFF)
194 #define UNPACK_SECONDARY_SHORT(packed) ((uint32_t)(packed) >> 16)
195#endif
196
197#ifdef SK_DEBUG
198 static inline uint32_t pack_two_shorts(U16CPU pri, U16CPU sec) {
199 SkASSERT((uint16_t)pri == pri);
200 SkASSERT((uint16_t)sec == sec);
201 return PACK_TWO_SHORTS(pri, sec);
202 }
203#else
204 #define pack_two_shorts(pri, sec) PACK_TWO_SHORTS(pri, sec)
205#endif
206
senorblanco@chromium.orgdc7de742009-11-30 20:00:29 +0000207// These functions are generated via macros, but are exposed here so that
208// platformProcs may test for them by name.
209void S32_opaque_D32_filter_DX(const SkBitmapProcState& s, const uint32_t xy[],
210 int count, SkPMColor colors[]);
senorblanco@chromium.orgf3f0bd72009-12-10 22:46:31 +0000211void S32_alpha_D32_filter_DX(const SkBitmapProcState& s, const uint32_t xy[],
212 int count, SkPMColor colors[]);
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000213void S32_opaque_D32_filter_DXDY(const SkBitmapProcState& s,
214 const uint32_t xy[], int count, SkPMColor colors[]);
215void S32_alpha_D32_filter_DXDY(const SkBitmapProcState& s,
tomhudson@google.comae29b882012-03-06 14:59:04 +0000216 const uint32_t xy[], int count, SkPMColor colors[]);
tomhudson@google.com06a73132012-02-22 18:30:43 +0000217void ClampX_ClampY_filter_scale(const SkBitmapProcState& s, uint32_t xy[],
218 int count, int x, int y);
219void ClampX_ClampY_nofilter_scale(const SkBitmapProcState& s, uint32_t xy[],
220 int count, int x, int y);
tomhudson@google.com5efaf262012-02-28 15:41:49 +0000221void ClampX_ClampY_filter_affine(const SkBitmapProcState& s,
222 uint32_t xy[], int count, int x, int y);
223void ClampX_ClampY_nofilter_affine(const SkBitmapProcState& s,
224 uint32_t xy[], int count, int x, int y);
reed@google.com78662282012-07-24 13:53:23 +0000225void S32_D16_filter_DX(const SkBitmapProcState& s,
226 const uint32_t* xy, int count, uint16_t* colors);
senorblanco@chromium.orgdc7de742009-11-30 20:00:29 +0000227
humper@google.comb0889472013-07-09 21:37:14 +0000228void highQualityFilter(const SkBitmapProcState &s, int x, int y,
229 SkPMColor *SK_RESTRICT colors, int count);
skia.committer@gmail.com9e1ec1a2013-07-10 07:00:58 +0000230
humper@google.comb0889472013-07-09 21:37:14 +0000231
reed@android.com8a1c16f2008-12-17 15:59:43 +0000232#endif