epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 1 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 2 | /* |
epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 3 | * Copyright 2007 The Android Open Source Project |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 4 | * |
epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 5 | * Use of this source code is governed by a BSD-style license that can be |
| 6 | * found in the LICENSE file. |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 7 | */ |
| 8 | |
epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 9 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 10 | #ifndef SkPicture_DEFINED |
| 11 | #define SkPicture_DEFINED |
| 12 | |
scroggo@google.com | f8d7d27 | 2013-02-22 21:38:35 +0000 | [diff] [blame] | 13 | #include "SkBitmap.h" |
scroggo@google.com | f1754ec | 2013-06-28 21:32:00 +0000 | [diff] [blame] | 14 | #include "SkImageDecoder.h" |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 15 | #include "SkRefCnt.h" |
| 16 | |
commit-bot@chromium.org | eb9547c | 2014-03-19 21:24:25 +0000 | [diff] [blame] | 17 | #if SK_SUPPORT_GPU |
| 18 | class GrContext; |
| 19 | #endif |
| 20 | |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 21 | class SkBBHFactory; |
junov@chromium.org | 35ac048 | 2012-11-01 17:10:32 +0000 | [diff] [blame] | 22 | class SkBBoxHierarchy; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 23 | class SkCanvas; |
reed@google.com | 74babdf | 2013-05-20 17:02:41 +0000 | [diff] [blame] | 24 | class SkDrawPictureCallback; |
scroggo@google.com | 1b1bcc3 | 2013-05-21 20:31:23 +0000 | [diff] [blame] | 25 | class SkData; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 26 | class SkPicturePlayback; |
| 27 | class SkPictureRecord; |
| 28 | class SkStream; |
| 29 | class SkWStream; |
| 30 | |
scroggo@google.com | f1754ec | 2013-06-28 21:32:00 +0000 | [diff] [blame] | 31 | struct SkPictInfo; |
| 32 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 33 | /** \class SkPicture |
| 34 | |
| 35 | The SkPicture class records the drawing commands made to a canvas, to |
| 36 | be played back at a later time. |
| 37 | */ |
reed@google.com | 1a32d4a | 2011-04-25 20:02:38 +0000 | [diff] [blame] | 38 | class SK_API SkPicture : public SkRefCnt { |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 39 | public: |
robertphillips@google.com | 15e9d3e | 2012-06-21 20:25:03 +0000 | [diff] [blame] | 40 | SK_DECLARE_INST_COUNT(SkPicture) |
| 41 | |
commit-bot@chromium.org | 145d1c0 | 2014-03-16 19:46:36 +0000 | [diff] [blame] | 42 | // AccelData provides a base class for device-specific acceleration |
skia.committer@gmail.com | eb849e5 | 2014-03-17 03:02:17 +0000 | [diff] [blame] | 43 | // data. It is added to the picture via a call to a device's optimize |
commit-bot@chromium.org | 145d1c0 | 2014-03-16 19:46:36 +0000 | [diff] [blame] | 44 | // method. |
| 45 | class AccelData : public SkRefCnt { |
| 46 | public: |
| 47 | typedef uint8_t Domain; |
| 48 | typedef uint32_t Key; |
| 49 | |
| 50 | AccelData(Key key) : fKey(key) { } |
| 51 | |
| 52 | const Key& getKey() const { return fKey; } |
| 53 | |
| 54 | // This entry point allows user's to get a unique domain prefix |
| 55 | // for their keys |
| 56 | static Domain GenerateDomain(); |
| 57 | private: |
| 58 | Key fKey; |
| 59 | |
| 60 | typedef SkRefCnt INHERITED; |
| 61 | }; |
| 62 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 63 | SkPicture(); |
| 64 | /** Make a copy of the contents of src. If src records more drawing after |
| 65 | this call, those elements will not appear in this picture. |
| 66 | */ |
| 67 | SkPicture(const SkPicture& src); |
scroggo@google.com | f8d7d27 | 2013-02-22 21:38:35 +0000 | [diff] [blame] | 68 | |
commit-bot@chromium.org | 145d1c0 | 2014-03-16 19:46:36 +0000 | [diff] [blame] | 69 | /** PRIVATE / EXPERIMENTAL -- do not call */ |
skia.committer@gmail.com | eb849e5 | 2014-03-17 03:02:17 +0000 | [diff] [blame] | 70 | void EXPERIMENTAL_addAccelData(const AccelData* data) { |
| 71 | SkRefCnt_SafeAssign(fAccelData, data); |
commit-bot@chromium.org | 145d1c0 | 2014-03-16 19:46:36 +0000 | [diff] [blame] | 72 | } |
| 73 | /** PRIVATE / EXPERIMENTAL -- do not call */ |
skia.committer@gmail.com | eb849e5 | 2014-03-17 03:02:17 +0000 | [diff] [blame] | 74 | const AccelData* EXPERIMENTAL_getAccelData(AccelData::Key key) const { |
commit-bot@chromium.org | 145d1c0 | 2014-03-16 19:46:36 +0000 | [diff] [blame] | 75 | if (NULL != fAccelData && fAccelData->getKey() == key) { |
skia.committer@gmail.com | eb849e5 | 2014-03-17 03:02:17 +0000 | [diff] [blame] | 76 | return fAccelData; |
commit-bot@chromium.org | 145d1c0 | 2014-03-16 19:46:36 +0000 | [diff] [blame] | 77 | } |
| 78 | return NULL; |
| 79 | } |
| 80 | |
reed@google.com | 34342f6 | 2012-06-25 14:36:28 +0000 | [diff] [blame] | 81 | /** |
scroggo@google.com | f8d7d27 | 2013-02-22 21:38:35 +0000 | [diff] [blame] | 82 | * Function signature defining a function that sets up an SkBitmap from encoded data. On |
| 83 | * success, the SkBitmap should have its Config, width, height, rowBytes and pixelref set. |
| 84 | * If the installed pixelref has decoded the data into pixels, then the src buffer need not be |
| 85 | * copied. If the pixelref defers the actual decode until its lockPixels() is called, then it |
| 86 | * must make a copy of the src buffer. |
| 87 | * @param src Encoded data. |
| 88 | * @param length Size of the encoded data, in bytes. |
| 89 | * @param dst SkBitmap to install the pixel ref on. |
| 90 | * @param bool Whether or not a pixel ref was successfully installed. |
| 91 | */ |
| 92 | typedef bool (*InstallPixelRefProc)(const void* src, size_t length, SkBitmap* dst); |
| 93 | |
| 94 | /** |
| 95 | * Recreate a picture that was serialized into a stream. |
| 96 | * @param SkStream Serialized picture data. |
scroggo@google.com | f8d7d27 | 2013-02-22 21:38:35 +0000 | [diff] [blame] | 97 | * @param proc Function pointer for installing pixelrefs on SkBitmaps representing the |
| 98 | * encoded bitmap data from the stream. |
scroggo@google.com | f1754ec | 2013-06-28 21:32:00 +0000 | [diff] [blame] | 99 | * @return A new SkPicture representing the serialized data, or NULL if the stream is |
| 100 | * invalid. |
scroggo@google.com | f8d7d27 | 2013-02-22 21:38:35 +0000 | [diff] [blame] | 101 | */ |
scroggo@google.com | f1754ec | 2013-06-28 21:32:00 +0000 | [diff] [blame] | 102 | static SkPicture* CreateFromStream(SkStream*, |
| 103 | InstallPixelRefProc proc = &SkImageDecoder::DecodeMemory); |
scroggo@google.com | f8d7d27 | 2013-02-22 21:38:35 +0000 | [diff] [blame] | 104 | |
commit-bot@chromium.org | 5e0995e | 2014-02-07 12:20:04 +0000 | [diff] [blame] | 105 | /** |
| 106 | * Recreate a picture that was serialized into a buffer. If the creation requires bitmap |
| 107 | * decoding, the decoder must be set on the SkReadBuffer parameter by calling |
| 108 | * SkReadBuffer::setBitmapDecoder() before calling SkPicture::CreateFromBuffer(). |
| 109 | * @param SkReadBuffer Serialized picture data. |
| 110 | * @return A new SkPicture representing the serialized data, or NULL if the buffer is |
| 111 | * invalid. |
| 112 | */ |
| 113 | static SkPicture* CreateFromBuffer(SkReadBuffer&); |
| 114 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 115 | virtual ~SkPicture(); |
rmistry@google.com | fbfcd56 | 2012-08-23 18:09:54 +0000 | [diff] [blame] | 116 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 117 | /** |
| 118 | * Swap the contents of the two pictures. Guaranteed to succeed. |
| 119 | */ |
| 120 | void swap(SkPicture& other); |
skia.committer@gmail.com | a27096b | 2012-08-30 14:38:00 +0000 | [diff] [blame] | 121 | |
djsollen@google.com | c9ab987 | 2012-08-29 18:52:07 +0000 | [diff] [blame] | 122 | /** |
| 123 | * Creates a thread-safe clone of the picture that is ready for playback. |
| 124 | */ |
| 125 | SkPicture* clone() const; |
| 126 | |
| 127 | /** |
| 128 | * Creates multiple thread-safe clones of this picture that are ready for |
| 129 | * playback. The resulting clones are stored in the provided array of |
| 130 | * SkPictures. |
| 131 | */ |
| 132 | void clone(SkPicture* pictures, int count) const; |
rmistry@google.com | fbfcd56 | 2012-08-23 18:09:54 +0000 | [diff] [blame] | 133 | |
reed@android.com | ae814c8 | 2009-02-13 14:56:09 +0000 | [diff] [blame] | 134 | enum RecordingFlags { |
| 135 | /* This flag specifies that when clipPath() is called, the path will |
| 136 | be faithfully recorded, but the recording canvas' current clip will |
| 137 | only see the path's bounds. This speeds up the recording process |
| 138 | without compromising the fidelity of the playback. The only side- |
| 139 | effect for recording is that calling getTotalClip() or related |
| 140 | clip-query calls will reflect the path's bounds, not the actual |
| 141 | path. |
| 142 | */ |
commit-bot@chromium.org | d393b17 | 2014-04-16 16:02:10 +0000 | [diff] [blame] | 143 | kUsePathBoundsForClip_RecordingFlag = 0x01 |
| 144 | }; |
| 145 | |
| 146 | #ifndef SK_SUPPORT_DEPRECATED_RECORD_FLAGS |
| 147 | // TODO: once kOptimizeForClippedPlayback_RecordingFlag is hidden from |
| 148 | // all external consumers, SkPicture::createBBoxHierarchy can also be |
| 149 | // cleaned up. |
| 150 | private: |
| 151 | #endif |
| 152 | enum Deprecated_RecordingFlags { |
rileya@google.com | 8515e79 | 2012-09-13 21:41:51 +0000 | [diff] [blame] | 153 | /* This flag causes the picture to compute bounding boxes and build |
| 154 | up a spatial hierarchy (currently an R-Tree), plus a tree of Canvas' |
| 155 | usually stack-based clip/etc state. This requires an increase in |
| 156 | recording time (often ~2x; likely more for very complex pictures), |
| 157 | but allows us to perform much faster culling at playback time, and |
| 158 | completely avoid some unnecessary clips and other operations. This |
| 159 | is ideal for tiled rendering, or any other situation where you're |
skia.committer@gmail.com | 1d225f2 | 2012-09-14 02:01:10 +0000 | [diff] [blame] | 160 | drawing a fraction of a large scene into a smaller viewport. |
rileya@google.com | 8515e79 | 2012-09-13 21:41:51 +0000 | [diff] [blame] | 161 | |
| 162 | In most cases the record cost is offset by the playback improvement |
| 163 | after a frame or two of tiled rendering (and complex pictures that |
| 164 | induce the worst record times will generally get the largest |
| 165 | speedups at playback time). |
| 166 | |
| 167 | Note: Currently this is not serializable, the bounding data will be |
| 168 | discarded if you serialize into a stream and then deserialize. |
| 169 | */ |
robertphillips@google.com | ad7d481 | 2013-04-12 15:13:35 +0000 | [diff] [blame] | 170 | kOptimizeForClippedPlayback_RecordingFlag = 0x02, |
reed@android.com | ae814c8 | 2009-02-13 14:56:09 +0000 | [diff] [blame] | 171 | }; |
commit-bot@chromium.org | d393b17 | 2014-04-16 16:02:10 +0000 | [diff] [blame] | 172 | #ifndef SK_SUPPORT_DEPRECATED_RECORD_FLAGS |
| 173 | public: |
| 174 | #endif |
reed@android.com | ae814c8 | 2009-02-13 14:56:09 +0000 | [diff] [blame] | 175 | |
robertphillips@google.com | 84b18c7 | 2014-04-13 19:09:42 +0000 | [diff] [blame] | 176 | #ifndef SK_SUPPORT_LEGACY_PICTURE_CAN_RECORD |
| 177 | private: |
robertphillips@google.com | 84b18c7 | 2014-04-13 19:09:42 +0000 | [diff] [blame] | 178 | #endif |
| 179 | |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 180 | #ifdef SK_SUPPORT_LEGACY_DERIVED_PICTURE_CLASSES |
| 181 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 182 | /** Returns the canvas that records the drawing commands. |
reed@android.com | ae814c8 | 2009-02-13 14:56:09 +0000 | [diff] [blame] | 183 | @param width the base width for the picture, as if the recording |
| 184 | canvas' bitmap had this width. |
| 185 | @param height the base width for the picture, as if the recording |
| 186 | canvas' bitmap had this height. |
| 187 | @param recordFlags optional flags that control recording. |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 188 | @return the picture canvas. |
| 189 | */ |
reed@android.com | ae814c8 | 2009-02-13 14:56:09 +0000 | [diff] [blame] | 190 | SkCanvas* beginRecording(int width, int height, uint32_t recordFlags = 0); |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 191 | #endif |
reed@android.com | ae814c8 | 2009-02-13 14:56:09 +0000 | [diff] [blame] | 192 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 193 | /** Returns the recording canvas if one is active, or NULL if recording is |
| 194 | not active. This does not alter the refcnt on the canvas (if present). |
| 195 | */ |
| 196 | SkCanvas* getRecordingCanvas() const; |
| 197 | /** Signal that the caller is done recording. This invalidates the canvas |
| 198 | returned by beginRecording/getRecordingCanvas, and prepares the picture |
| 199 | for drawing. Note: this happens implicitly the first time the picture |
| 200 | is drawn. |
| 201 | */ |
| 202 | void endRecording(); |
junov@chromium.org | 4866cc0 | 2012-06-01 21:23:07 +0000 | [diff] [blame] | 203 | |
robertphillips@google.com | 84b18c7 | 2014-04-13 19:09:42 +0000 | [diff] [blame] | 204 | #ifndef SK_SUPPORT_LEGACY_PICTURE_CAN_RECORD |
| 205 | public: |
| 206 | #endif |
| 207 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 208 | /** Replays the drawing commands on the specified canvas. This internally |
| 209 | calls endRecording() if that has not already been called. |
reed@google.com | 74babdf | 2013-05-20 17:02:41 +0000 | [diff] [blame] | 210 | @param canvas the canvas receiving the drawing commands. |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 211 | */ |
reed@google.com | 74babdf | 2013-05-20 17:02:41 +0000 | [diff] [blame] | 212 | void draw(SkCanvas* canvas, SkDrawPictureCallback* = NULL); |
rmistry@google.com | fbfcd56 | 2012-08-23 18:09:54 +0000 | [diff] [blame] | 213 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 214 | /** Return the width of the picture's recording canvas. This |
| 215 | value reflects what was passed to setSize(), and does not necessarily |
| 216 | reflect the bounds of what has been recorded into the picture. |
| 217 | @return the width of the picture's recording canvas |
| 218 | */ |
| 219 | int width() const { return fWidth; } |
| 220 | |
| 221 | /** Return the height of the picture's recording canvas. This |
| 222 | value reflects what was passed to setSize(), and does not necessarily |
| 223 | reflect the bounds of what has been recorded into the picture. |
| 224 | @return the height of the picture's recording canvas |
| 225 | */ |
| 226 | int height() const { return fHeight; } |
| 227 | |
skia.committer@gmail.com | a915772 | 2014-04-03 03:04:26 +0000 | [diff] [blame] | 228 | /** Return a non-zero, unique value representing the picture. This call is |
| 229 | only valid when not recording. Between a beginRecording/endRecording |
commit-bot@chromium.org | 2b4e370 | 2014-04-07 18:26:22 +0000 | [diff] [blame] | 230 | pair it will just return 0 (the invalid ID). Each beginRecording/ |
robertphillips@google.com | d550088 | 2014-04-02 23:51:13 +0000 | [diff] [blame] | 231 | endRecording pair will cause a different generation ID to be returned. |
| 232 | */ |
commit-bot@chromium.org | 2b4e370 | 2014-04-07 18:26:22 +0000 | [diff] [blame] | 233 | uint32_t uniqueID() const; |
robertphillips@google.com | d550088 | 2014-04-02 23:51:13 +0000 | [diff] [blame] | 234 | |
scroggo@google.com | 5a7c6be | 2012-10-04 21:46:08 +0000 | [diff] [blame] | 235 | /** |
scroggo@google.com | 1b1bcc3 | 2013-05-21 20:31:23 +0000 | [diff] [blame] | 236 | * Function to encode an SkBitmap to an SkData. A function with this |
commit-bot@chromium.org | 8b0e8ac | 2014-01-30 18:58:24 +0000 | [diff] [blame] | 237 | * signature can be passed to serialize() and SkWriteBuffer. |
| 238 | * Returning NULL will tell the SkWriteBuffer to use |
scroggo@google.com | 1b1bcc3 | 2013-05-21 20:31:23 +0000 | [diff] [blame] | 239 | * SkBitmap::flatten() to store the bitmap. |
reed@google.com | 672588b | 2014-01-08 15:42:01 +0000 | [diff] [blame] | 240 | * |
| 241 | * @param pixelRefOffset DEPRECATED -- caller assumes it will return 0. |
scroggo@google.com | 1b1bcc3 | 2013-05-21 20:31:23 +0000 | [diff] [blame] | 242 | * @return SkData If non-NULL, holds encoded data representing the passed |
| 243 | * in bitmap. The caller is responsible for calling unref(). |
scroggo@google.com | 32ef131 | 2013-02-22 22:04:19 +0000 | [diff] [blame] | 244 | */ |
scroggo@google.com | 1b1bcc3 | 2013-05-21 20:31:23 +0000 | [diff] [blame] | 245 | typedef SkData* (*EncodeBitmap)(size_t* pixelRefOffset, const SkBitmap& bm); |
scroggo@google.com | 32ef131 | 2013-02-22 22:04:19 +0000 | [diff] [blame] | 246 | |
| 247 | /** |
scroggo@google.com | 5a7c6be | 2012-10-04 21:46:08 +0000 | [diff] [blame] | 248 | * Serialize to a stream. If non NULL, encoder will be used to encode |
| 249 | * any bitmaps in the picture. |
scroggo@google.com | 1b1bcc3 | 2013-05-21 20:31:23 +0000 | [diff] [blame] | 250 | * encoder will never be called with a NULL pixelRefOffset. |
scroggo@google.com | 5a7c6be | 2012-10-04 21:46:08 +0000 | [diff] [blame] | 251 | */ |
scroggo@google.com | 32ef131 | 2013-02-22 22:04:19 +0000 | [diff] [blame] | 252 | void serialize(SkWStream*, EncodeBitmap encoder = NULL) const; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 253 | |
tomhudson@google.com | 381010e | 2013-10-24 11:12:47 +0000 | [diff] [blame] | 254 | /** |
commit-bot@chromium.org | 5e0995e | 2014-02-07 12:20:04 +0000 | [diff] [blame] | 255 | * Serialize to a buffer. |
| 256 | */ |
| 257 | void flatten(SkWriteBuffer&) const; |
| 258 | |
| 259 | /** |
tomhudson@google.com | 381010e | 2013-10-24 11:12:47 +0000 | [diff] [blame] | 260 | * Returns true if any bitmaps may be produced when this SkPicture |
| 261 | * is replayed. |
| 262 | * Returns false if called while still recording. |
| 263 | */ |
| 264 | bool willPlayBackBitmaps() const; |
| 265 | |
djsollen@google.com | d9b0f48 | 2013-02-01 16:18:09 +0000 | [diff] [blame] | 266 | #ifdef SK_BUILD_FOR_ANDROID |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 267 | /** Signals that the caller is prematurely done replaying the drawing |
| 268 | commands. This can be called from a canvas virtual while the picture |
rmistry@google.com | fbfcd56 | 2012-08-23 18:09:54 +0000 | [diff] [blame] | 269 | is drawing. Has no effect if the picture is not drawing. |
djsollen@google.com | d9b0f48 | 2013-02-01 16:18:09 +0000 | [diff] [blame] | 270 | @deprecated preserving for legacy purposes |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 271 | */ |
| 272 | void abortPlayback(); |
djsollen@google.com | d9b0f48 | 2013-02-01 16:18:09 +0000 | [diff] [blame] | 273 | #endif |
rmistry@google.com | fbfcd56 | 2012-08-23 18:09:54 +0000 | [diff] [blame] | 274 | |
commit-bot@chromium.org | 6f4fb0f | 2014-03-03 19:18:39 +0000 | [diff] [blame] | 275 | /** Return true if the SkStream/Buffer represents a serialized picture, and |
| 276 | fills out SkPictInfo. After this function returns, the data source is not |
skia.committer@gmail.com | ade9a34 | 2014-03-04 03:02:32 +0000 | [diff] [blame] | 277 | rewound so it will have to be manually reset before passing to |
commit-bot@chromium.org | 6f4fb0f | 2014-03-03 19:18:39 +0000 | [diff] [blame] | 278 | CreateFromStream or CreateFromBuffer. Note, CreateFromStream and |
| 279 | CreateFromBuffer perform this check internally so these entry points are |
| 280 | intended for stand alone tools. |
| 281 | If false is returned, SkPictInfo is unmodified. |
| 282 | */ |
| 283 | static bool InternalOnly_StreamIsSKP(SkStream*, SkPictInfo*); |
| 284 | static bool InternalOnly_BufferIsSKP(SkReadBuffer&, SkPictInfo*); |
| 285 | |
commit-bot@chromium.org | e494dbd | 2014-03-04 19:08:57 +0000 | [diff] [blame] | 286 | /** Enable/disable all the picture recording optimizations (i.e., |
| 287 | those in SkPictureRecord). It is mainly intended for testing the |
| 288 | existing optimizations (i.e., to actually have the pattern |
| 289 | appear in an .skp we have to disable the optimization). Call right |
| 290 | after 'beginRecording'. |
| 291 | */ |
| 292 | void internalOnly_EnableOpts(bool enableOpts); |
| 293 | |
commit-bot@chromium.org | eb9547c | 2014-03-19 21:24:25 +0000 | [diff] [blame] | 294 | /** Return true if the picture is suitable for rendering on the GPU. |
| 295 | */ |
| 296 | |
| 297 | #if SK_SUPPORT_GPU |
| 298 | bool suitableForGpuRasterization(GrContext*) const; |
| 299 | #endif |
| 300 | |
scroggo@google.com | 2983ddd | 2013-05-07 14:45:40 +0000 | [diff] [blame] | 301 | protected: |
robertphillips@google.com | 9a5b570 | 2012-11-13 20:41:18 +0000 | [diff] [blame] | 302 | // V2 : adds SkPixelRef's generation ID. |
| 303 | // V3 : PictInfo tag at beginning, and EOF tag at the end |
| 304 | // V4 : move SkPictInfo to be the header |
| 305 | // V5 : don't read/write FunctionPtr on cross-process (we can detect that) |
| 306 | // V6 : added serialization of SkPath's bounds (and packed its flags tighter) |
| 307 | // V7 : changed drawBitmapRect(IRect) to drawBitmapRectToRect(Rect) |
| 308 | // V8 : Add an option for encoding bitmaps |
| 309 | // V9 : Allow the reader and writer of an SKP disagree on whether to support |
| 310 | // SK_SUPPORT_HINTING_SCALE_FACTOR |
reed@google.com | 4ed0fb7 | 2012-12-12 20:48:18 +0000 | [diff] [blame] | 311 | // V10: add drawRRect, drawOval, clipRRect |
scroggo@google.com | 74b7ffd | 2013-04-30 02:32:41 +0000 | [diff] [blame] | 312 | // V11: modify how readBitmap and writeBitmap store their info. |
reed@google.com | 277c3f8 | 2013-05-31 15:17:50 +0000 | [diff] [blame] | 313 | // V12: add conics to SkPath, use new SkPathRef flattening |
commit-bot@chromium.org | eed779d | 2013-08-16 10:24:37 +0000 | [diff] [blame] | 314 | // V13: add flag to drawBitmapRectToRect |
robertphillips@google.com | 7ce661d | 2013-08-27 16:14:03 +0000 | [diff] [blame] | 315 | // parameterize blurs by sigma rather than radius |
robertphillips@google.com | ca0c838 | 2013-09-26 12:18:23 +0000 | [diff] [blame] | 316 | // V14: Add flags word to PathRef serialization |
robertphillips@google.com | d550088 | 2014-04-02 23:51:13 +0000 | [diff] [blame] | 317 | // V15: Remove A1 bitmap config (and renumber remaining configs) |
robertphillips@google.com | 466310d | 2013-12-03 16:43:54 +0000 | [diff] [blame] | 318 | // V16: Move SkPath's isOval flag to SkPathRef |
reed@google.com | e132f50 | 2013-12-13 19:58:46 +0000 | [diff] [blame] | 319 | // V17: SkPixelRef now writes SkImageInfo |
reed@google.com | 672588b | 2014-01-08 15:42:01 +0000 | [diff] [blame] | 320 | // V18: SkBitmap now records x,y for its pixelref origin, instead of offset. |
commit-bot@chromium.org | fed2ab6 | 2014-01-23 15:16:05 +0000 | [diff] [blame] | 321 | // V19: encode matrices and regions into the ops stream |
commit-bot@chromium.org | 5e0995e | 2014-02-07 12:20:04 +0000 | [diff] [blame] | 322 | // V20: added bool to SkPictureImageFilter's serialization (to allow SkPicture serialization) |
commit-bot@chromium.org | 210ae2a | 2014-02-27 17:40:13 +0000 | [diff] [blame] | 323 | // V21: add pushCull, popCull |
commit-bot@chromium.org | dcb8e54 | 2014-03-05 18:25:20 +0000 | [diff] [blame] | 324 | // V22: SK_PICT_FACTORY_TAG's size is now the chunk size in bytes |
commit-bot@chromium.org | 85faf50 | 2014-04-16 12:58:02 +0000 | [diff] [blame] | 325 | // V23: SkPaint::FilterLevel became a real enum |
commit-bot@chromium.org | 44d83c1 | 2014-04-21 13:10:25 +0000 | [diff] [blame^] | 326 | // V24: SkTwoPointConicalGradient now has fFlipped flag for gradient flipping |
commit-bot@chromium.org | d281c92 | 2014-02-18 22:08:16 +0000 | [diff] [blame] | 327 | |
| 328 | // Note: If the picture version needs to be increased then please follow the |
| 329 | // steps to generate new SKPs in (only accessible to Googlers): http://goo.gl/qATVcw |
commit-bot@chromium.org | e8d9614 | 2014-02-25 02:16:10 +0000 | [diff] [blame] | 330 | |
| 331 | // Only SKPs within the min/current picture version range (inclusive) can be read. |
| 332 | static const uint32_t MIN_PICTURE_VERSION = 19; |
commit-bot@chromium.org | 44d83c1 | 2014-04-21 13:10:25 +0000 | [diff] [blame^] | 333 | static const uint32_t CURRENT_PICTURE_VERSION = 24; |
robertphillips@google.com | 9a5b570 | 2012-11-13 20:41:18 +0000 | [diff] [blame] | 334 | |
commit-bot@chromium.org | 2b4e370 | 2014-04-07 18:26:22 +0000 | [diff] [blame] | 335 | mutable uint32_t fUniqueID; |
robertphillips@google.com | d550088 | 2014-04-02 23:51:13 +0000 | [diff] [blame] | 336 | |
robertphillips@google.com | 9a5b570 | 2012-11-13 20:41:18 +0000 | [diff] [blame] | 337 | // fPlayback, fRecord, fWidth & fHeight are protected to allow derived classes to |
skia.committer@gmail.com | fbb0ed9 | 2012-11-13 21:46:06 +0000 | [diff] [blame] | 338 | // install their own SkPicturePlayback-derived players,SkPictureRecord-derived |
robertphillips@google.com | 9a5b570 | 2012-11-13 20:41:18 +0000 | [diff] [blame] | 339 | // recorders and set the picture size |
commit-bot@chromium.org | 145d1c0 | 2014-03-16 19:46:36 +0000 | [diff] [blame] | 340 | SkPicturePlayback* fPlayback; |
| 341 | SkPictureRecord* fRecord; |
| 342 | int fWidth, fHeight; |
| 343 | const AccelData* fAccelData; |
robertphillips@google.com | 63f1127 | 2012-10-24 19:30:41 +0000 | [diff] [blame] | 344 | |
commit-bot@chromium.org | 2b4e370 | 2014-04-07 18:26:22 +0000 | [diff] [blame] | 345 | void needsNewGenID() { fUniqueID = SK_InvalidGenID; } |
robertphillips@google.com | d550088 | 2014-04-02 23:51:13 +0000 | [diff] [blame] | 346 | |
scroggo@google.com | f1754ec | 2013-06-28 21:32:00 +0000 | [diff] [blame] | 347 | // Create a new SkPicture from an existing SkPicturePlayback. Ref count of |
| 348 | // playback is unchanged. |
| 349 | SkPicture(SkPicturePlayback*, int width, int height); |
| 350 | |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 351 | #ifdef SK_SUPPORT_LEGACY_DERIVED_PICTURE_CLASSES |
junov@chromium.org | 35ac048 | 2012-11-01 17:10:32 +0000 | [diff] [blame] | 352 | // For testing. Derived classes may instantiate an alternate |
| 353 | // SkBBoxHierarchy implementation |
| 354 | virtual SkBBoxHierarchy* createBBoxHierarchy() const; |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 355 | #endif |
| 356 | |
| 357 | SkCanvas* beginRecording(int width, int height, SkBBHFactory* factory, uint32_t recordFlags); |
commit-bot@chromium.org | d393b17 | 2014-04-16 16:02:10 +0000 | [diff] [blame] | 358 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 359 | private: |
commit-bot@chromium.org | 70512af | 2014-03-18 17:45:32 +0000 | [diff] [blame] | 360 | // An OperationList encapsulates a set of operation offsets into the picture byte |
| 361 | // stream along with the CTMs needed for those operation. |
commit-bot@chromium.org | e3beb6b | 2014-04-07 19:34:38 +0000 | [diff] [blame] | 362 | class OperationList : ::SkNoncopyable { |
commit-bot@chromium.org | 70512af | 2014-03-18 17:45:32 +0000 | [diff] [blame] | 363 | public: |
| 364 | virtual ~OperationList() {} |
| 365 | |
| 366 | // If valid returns false then there is no optimization data |
| 367 | // present. All the draw operations need to be issued. |
| 368 | virtual bool valid() const { return false; } |
| 369 | |
| 370 | // The following three entry points should only be accessed if |
| 371 | // 'valid' returns true. |
| 372 | virtual int numOps() const { SkASSERT(false); return 0; }; |
| 373 | // The offset in the picture of the operation to execute. |
| 374 | virtual uint32_t offset(int index) const { SkASSERT(false); return 0; }; |
| 375 | // The CTM that must be installed for the operation to behave correctly |
| 376 | virtual const SkMatrix& matrix(int index) const { SkASSERT(false); return SkMatrix::I(); } |
| 377 | |
| 378 | static const OperationList& InvalidList(); |
commit-bot@chromium.org | 70512af | 2014-03-18 17:45:32 +0000 | [diff] [blame] | 379 | }; |
| 380 | |
| 381 | /** PRIVATE / EXPERIMENTAL -- do not call |
| 382 | Return the operations required to render the content inside 'queryRect'. |
| 383 | */ |
| 384 | const OperationList& EXPERIMENTAL_getActiveOps(const SkIRect& queryRect); |
| 385 | |
commit-bot@chromium.org | 75cf29b | 2014-03-24 19:40:49 +0000 | [diff] [blame] | 386 | /** PRIVATE / EXPERIMENTAL -- do not call |
| 387 | Return the ID of the operation currently being executed when playing |
| 388 | back. 0 indicates no call is active. |
| 389 | */ |
| 390 | size_t EXPERIMENTAL_curOpID() const; |
| 391 | |
commit-bot@chromium.org | 9e5f85e | 2014-03-12 14:46:41 +0000 | [diff] [blame] | 392 | void createHeader(SkPictInfo* info) const; |
| 393 | static bool IsValidPictInfo(const SkPictInfo& info); |
commit-bot@chromium.org | 5e0995e | 2014-02-07 12:20:04 +0000 | [diff] [blame] | 394 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 395 | friend class SkFlatPicture; |
| 396 | friend class SkPicturePlayback; |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 397 | friend class SkPictureRecorder; |
commit-bot@chromium.org | 70512af | 2014-03-18 17:45:32 +0000 | [diff] [blame] | 398 | friend class SkGpuDevice; |
commit-bot@chromium.org | 75cf29b | 2014-03-24 19:40:49 +0000 | [diff] [blame] | 399 | friend class GrGatherDevice; |
| 400 | friend class SkDebugCanvas; |
robertphillips@google.com | 15e9d3e | 2012-06-21 20:25:03 +0000 | [diff] [blame] | 401 | |
| 402 | typedef SkRefCnt INHERITED; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 403 | }; |
| 404 | |
reed@google.com | 74babdf | 2013-05-20 17:02:41 +0000 | [diff] [blame] | 405 | /** |
| 406 | * Subclasses of this can be passed to canvas.drawPicture. During the drawing |
| 407 | * of the picture, this callback will periodically be invoked. If its |
| 408 | * abortDrawing() returns true, then picture playback will be interrupted. |
| 409 | * |
| 410 | * The resulting drawing is undefined, as there is no guarantee how often the |
| 411 | * callback will be invoked. If the abort happens inside some level of nested |
| 412 | * calls to save(), restore will automatically be called to return the state |
| 413 | * to the same level it was before the drawPicture call was made. |
| 414 | */ |
commit-bot@chromium.org | be879bc | 2013-05-22 21:11:42 +0000 | [diff] [blame] | 415 | class SK_API SkDrawPictureCallback { |
reed@google.com | 74babdf | 2013-05-20 17:02:41 +0000 | [diff] [blame] | 416 | public: |
| 417 | SkDrawPictureCallback() {} |
| 418 | virtual ~SkDrawPictureCallback() {} |
skia.committer@gmail.com | 3e50e99 | 2013-05-21 07:01:40 +0000 | [diff] [blame] | 419 | |
reed@google.com | 74babdf | 2013-05-20 17:02:41 +0000 | [diff] [blame] | 420 | virtual bool abortDrawing() = 0; |
| 421 | }; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 422 | |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 423 | #ifdef SK_SUPPORT_LEGACY_DERIVED_PICTURE_CLASSES |
| 424 | |
robertphillips@google.com | 84b18c7 | 2014-04-13 19:09:42 +0000 | [diff] [blame] | 425 | class SkPictureFactory : public SkRefCnt { |
| 426 | public: |
| 427 | /** |
| 428 | * Allocate a new SkPicture. Return NULL on failure. |
| 429 | */ |
| 430 | virtual SkPicture* create(int width, int height) = 0; |
commit-bot@chromium.org | d393b17 | 2014-04-16 16:02:10 +0000 | [diff] [blame] | 431 | |
| 432 | private: |
| 433 | typedef SkRefCnt INHERITED; |
robertphillips@google.com | 84b18c7 | 2014-04-13 19:09:42 +0000 | [diff] [blame] | 434 | }; |
| 435 | |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 436 | #endif |
| 437 | |
robertphillips@google.com | 770963f | 2014-04-18 18:04:41 +0000 | [diff] [blame] | 438 | #ifdef SK_SUPPORT_LEGACY_PICTURE_HEADERS |
| 439 | #include "SkPictureRecorder.h" |
commit-bot@chromium.org | 5fb2ce3 | 2014-04-17 23:35:06 +0000 | [diff] [blame] | 440 | #endif |
| 441 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 442 | #endif |