1 /* 2 * Copyright 2014 Google Inc. 3 * 4 * Use of this source code is governed by a BSD-style license that can be 5 * found in the LICENSE file. 6 */ 7 8 #ifndef SkMultiPictureDraw_DEFINED 9 #define SkMultiPictureDraw_DEFINED 10 11 #include "SkMatrix.h" 12 #include "SkTDArray.h" 13 14 class SkCanvas; 15 class SkPaint; 16 class SkPicture; 17 18 /** \class SkMultiPictureDraw 19 20 The MultiPictureDraw object accepts several picture/canvas pairs and 21 then attempts to optimally draw the pictures into the canvases, sharing 22 as many resources as possible. 23 */ 24 class SK_API SkMultiPictureDraw { 25 public: 26 /** 27 * Create an object to optimize the drawing of multiple pictures. 28 * @param reserve Hint for the number of add calls expected to be issued 29 */ 30 SkMultiPictureDraw(int reserve = 0); ~SkMultiPictureDraw()31 ~SkMultiPictureDraw() { this->reset(); } 32 33 /** 34 * Add a canvas/picture pair for later rendering. 35 * @param canvas the canvas in which to draw picture 36 * @param picture the picture to draw into canvas 37 * @param matrix if non-NULL, applied to the CTM when drawing 38 * @param paint if non-NULL, draw picture to a temporary buffer 39 * and then apply the paint when the result is drawn 40 */ 41 void add(SkCanvas* canvas, 42 const SkPicture* picture, 43 const SkMatrix* matrix = NULL, 44 const SkPaint* paint = NULL); 45 46 /** 47 * Perform all the previously added draws. This will reset the state 48 * of this object. If flush is true, all canvases are flushed after 49 * draw. 50 */ 51 void draw(bool flush = false); 52 53 /** 54 * Abandon all buffered draws and reset to the initial state. 55 */ 56 void reset(); 57 58 private: 59 struct DrawData { 60 SkCanvas* fCanvas; // reffed 61 const SkPicture* fPicture; // reffed 62 SkMatrix fMatrix; 63 SkPaint* fPaint; // owned 64 65 void init(SkCanvas*, const SkPicture*, const SkMatrix*, const SkPaint*); 66 void draw(); 67 68 static void Reset(SkTDArray<DrawData>&); 69 DrawDrawData70 static void Draw(DrawData* d) { d->draw(); } 71 }; 72 73 SkTDArray<DrawData> fThreadSafeDrawData; 74 SkTDArray<DrawData> fGPUDrawData; 75 }; 76 77 #endif 78