| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #ifndef SkCanvasDrawable_DEFINED | 8 #ifndef SkDrawable_DEFINED |
| 9 #define SkCanvasDrawable_DEFINED | 9 #define SkDrawable_DEFINED |
| 10 | 10 |
| 11 #include "SkRefCnt.h" | 11 #include "SkRefCnt.h" |
| 12 | 12 |
| 13 class SkCanvas; | 13 class SkCanvas; |
| 14 class SkPicture; | 14 class SkPicture; |
| 15 struct SkRect; | 15 struct SkRect; |
| 16 | 16 |
| 17 /** | 17 /** |
| 18 * Base-class for objects that draw into SkCanvas. | 18 * Base-class for objects that draw into SkCanvas. |
| 19 * | 19 * |
| 20 * The object has a generation ID, which is guaranteed to be unique across all
drawables. To | 20 * The object has a generation ID, which is guaranteed to be unique across all
drawables. To |
| 21 * allow for clients of the drawable that may want to cache the results, the dr
awable must | 21 * allow for clients of the drawable that may want to cache the results, the dr
awable must |
| 22 * change its generation ID whenever its internal state changes such that it wi
ll draw differently. | 22 * change its generation ID whenever its internal state changes such that it wi
ll draw differently. |
| 23 */ | 23 */ |
| 24 class SkCanvasDrawable : public SkRefCnt { | 24 class SkDrawable : public SkRefCnt { |
| 25 public: | 25 public: |
| 26 SkCanvasDrawable(); | 26 SkDrawable(); |
| 27 | 27 |
| 28 /** | 28 /** |
| 29 * Draws into the specified content. The drawing sequence will be balanced
upon return | 29 * Draws into the specified content. The drawing sequence will be balanced
upon return |
| 30 * (i.e. the saveLevel() on the canvas will match what it was when draw() w
as called, | 30 * (i.e. the saveLevel() on the canvas will match what it was when draw() w
as called, |
| 31 * and the current matrix and clip settings will not be changed. | 31 * and the current matrix and clip settings will not be changed. |
| 32 */ | 32 */ |
| 33 void draw(SkCanvas*); | 33 void draw(SkCanvas*); |
| 34 | 34 |
| 35 SkPicture* newPictureSnapshot(); | 35 SkPicture* newPictureSnapshot(); |
| 36 | 36 |
| (...skipping 16 matching lines...) Expand all Loading... |
| 53 /** | 53 /** |
| 54 * Calling this invalidates the previous generation ID, and causes a new on
e to be computed | 54 * Calling this invalidates the previous generation ID, and causes a new on
e to be computed |
| 55 * the next time getGenerationID() is called. Typically this is called by t
he object itself, | 55 * the next time getGenerationID() is called. Typically this is called by t
he object itself, |
| 56 * in response to its internal state changing. | 56 * in response to its internal state changing. |
| 57 */ | 57 */ |
| 58 void notifyDrawingChanged(); | 58 void notifyDrawingChanged(); |
| 59 | 59 |
| 60 protected: | 60 protected: |
| 61 virtual SkRect onGetBounds() = 0; | 61 virtual SkRect onGetBounds() = 0; |
| 62 virtual void onDraw(SkCanvas*) = 0; | 62 virtual void onDraw(SkCanvas*) = 0; |
| 63 |
| 64 /** |
| 65 * Default implementation calls onDraw() with a canvas that records into a
picture. Subclasses |
| 66 * may override if they have a more efficient way to return a picture for t
he current state |
| 67 * of their drawable. Note: this picture must draw the same as what would b
e drawn from |
| 68 * onDraw(). |
| 69 */ |
| 63 virtual SkPicture* onNewPictureSnapshot(); | 70 virtual SkPicture* onNewPictureSnapshot(); |
| 64 | 71 |
| 65 private: | 72 private: |
| 66 int32_t fGenerationID; | 73 int32_t fGenerationID; |
| 67 }; | 74 }; |
| 68 | 75 |
| 69 #endif | 76 #endif |
| OLD | NEW |