Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 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 GrSWMaskHelper_DEFINED | 8 #ifndef GrSWMaskHelper_DEFINED |
| 9 #define GrSWMaskHelper_DEFINED | 9 #define GrSWMaskHelper_DEFINED |
| 10 | 10 |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 35 * draw one or more paths/rects specifying the required boolean ops | 35 * draw one or more paths/rects specifying the required boolean ops |
| 36 * | 36 * |
| 37 * toTexture(); // to get it from the internal bitmap to the GPU | 37 * toTexture(); // to get it from the internal bitmap to the GPU |
| 38 * | 38 * |
| 39 * The result of this process will be the final mask (on the GPU) in the | 39 * The result of this process will be the final mask (on the GPU) in the |
| 40 * upper left hand corner of the texture. | 40 * upper left hand corner of the texture. |
| 41 */ | 41 */ |
| 42 class GrSWMaskHelper : SkNoncopyable { | 42 class GrSWMaskHelper : SkNoncopyable { |
| 43 public: | 43 public: |
| 44 GrSWMaskHelper(GrContext* context) | 44 GrSWMaskHelper(GrContext* context) |
| 45 : fContext(context), fCompressMask(false) { | 45 : fContext(context) |
| 46 , fCompressionMode(kNone_CompressionMode) | |
| 47 , fCompressedBuffer(NULL) { | |
| 46 } | 48 } |
| 47 | 49 |
| 50 ~GrSWMaskHelper() { | |
| 51 sk_free(fCompressedBuffer); | |
| 52 } | |
| 53 | |
| 54 | |
| 48 // set up the internal state in preparation for draws. Since many masks | 55 // set up the internal state in preparation for draws. Since many masks |
| 49 // may be accumulated in the helper during creation, "resultBounds" | 56 // may be accumulated in the helper during creation, "resultBounds" |
| 50 // allows the caller to specify the region of interest - to limit the | 57 // allows the caller to specify the region of interest - to limit the |
| 51 // amount of work. | 58 // amount of work. |
| 52 bool init(const SkIRect& resultBounds, const SkMatrix* matrix); | 59 bool init(const SkIRect& resultBounds, const SkMatrix* matrix); |
| 53 | 60 |
| 54 // Draw a single rect into the accumulation bitmap using the specified op | 61 // Draw a single rect into the accumulation bitmap using the specified op |
| 55 void draw(const SkRect& rect, SkRegion::Op op, | 62 void draw(const SkRect& rect, SkRegion::Op op, |
| 56 bool antiAlias, uint8_t alpha); | 63 bool antiAlias, uint8_t alpha); |
| 57 | 64 |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 87 // geometry and the current drawState. The current drawState is altered to | 94 // geometry and the current drawState. The current drawState is altered to |
| 88 // accommodate the mask. | 95 // accommodate the mask. |
| 89 // Note that this method assumes that the GrPaint::kTotalStages slot in | 96 // Note that this method assumes that the GrPaint::kTotalStages slot in |
| 90 // the draw state can be used to hold the mask texture stage. | 97 // the draw state can be used to hold the mask texture stage. |
| 91 // This method is really only intended to be used with the | 98 // This method is really only intended to be used with the |
| 92 // output of DrawPathMaskToTexture. | 99 // output of DrawPathMaskToTexture. |
| 93 static void DrawToTargetWithPathMask(GrTexture* texture, | 100 static void DrawToTargetWithPathMask(GrTexture* texture, |
| 94 GrDrawTarget* target, | 101 GrDrawTarget* target, |
| 95 const SkIRect& rect); | 102 const SkIRect& rect); |
| 96 | 103 |
| 97 protected: | |
| 98 private: | 104 private: |
| 99 GrContext* fContext; | 105 GrContext* fContext; |
| 100 SkMatrix fMatrix; | 106 SkMatrix fMatrix; |
| 101 SkBitmap fBM; | 107 SkBitmap fBM; |
| 102 SkDraw fDraw; | 108 SkDraw fDraw; |
| 103 SkRasterClip fRasterClip; | 109 SkRasterClip fRasterClip; |
| 104 | 110 |
| 105 // This flag says whether or not we should compress the mask. If | 111 // This enum says whether or not we should compress the mask: |
| 106 // it is true, then fCompressedFormat is always valid. | 112 // kNone_CompressionMode: compression is not supported on this device. |
| 107 bool fCompressMask; | 113 // kCompress_CompressionMode: compress the bitmap before it gets sent to the gpu |
| 114 // kBlitter_CompressionMode: write to the bitmap using a special compressed blitter. | |
| 115 enum CompressionMode { | |
| 116 kNone_CompressionMode, | |
| 117 kCompress_CompressionMode, | |
| 118 kBlitter_CompressionMode, | |
| 119 } fCompressionMode; | |
| 120 | |
| 121 // This is the buffer into which we store our compressed data. This buffer i s | |
| 122 // only allocated (non-null) if fCompressionMode is kBlitter_CompressionMode | |
|
robertphillips
2014/08/07 13:55:06
Can we use an SkAutoMalloc for this?
krajcevski
2014/08/07 14:48:12
Done.
| |
| 123 void* fCompressedBuffer; | |
| 108 | 124 |
| 109 // This is the desired format within which to compress the | 125 // This is the desired format within which to compress the |
| 110 // texture. This value is only valid if fCompressMask is true. | 126 // texture. This value is only valid if fCompressionMode is not kNone_Compre ssionMode. |
| 111 SkTextureCompressor::Format fCompressedFormat; | 127 SkTextureCompressor::Format fCompressedFormat; |
| 112 | 128 |
| 113 // Actually sends the texture data to the GPU. This is called from | 129 // Actually sends the texture data to the GPU. This is called from |
| 114 // toTexture with the data filled in depending on the texture config. | 130 // toTexture with the data filled in depending on the texture config. |
| 115 void sendTextureData(GrTexture *texture, const GrTextureDesc& desc, | 131 void sendTextureData(GrTexture *texture, const GrTextureDesc& desc, |
| 116 const void *data, int rowbytes); | 132 const void *data, int rowbytes); |
| 117 | 133 |
| 118 // Compresses the bitmap stored in fBM and sends the compressed data | 134 // Compresses the bitmap stored in fBM and sends the compressed data |
| 119 // to the GPU to be stored in 'texture' using sendTextureData. | 135 // to the GPU to be stored in 'texture' using sendTextureData. |
| 120 void compressTextureData(GrTexture *texture, const GrTextureDesc& desc); | 136 void compressTextureData(GrTexture *texture, const GrTextureDesc& desc); |
| 121 | 137 |
| 122 typedef SkNoncopyable INHERITED; | 138 typedef SkNoncopyable INHERITED; |
| 123 }; | 139 }; |
| 124 | 140 |
| 125 #endif // GrSWMaskHelper_DEFINED | 141 #endif // GrSWMaskHelper_DEFINED |
| OLD | NEW |