Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6)

Side by Side Diff: src/gpu/GrClipMaskManager.h

Issue 1230023003: Modify GrClipMaskManager to reflect logical constness (Closed) Base URL: https://skia.googlesource.com/skia.git@proctomemorypool
Patch Set: deal with warnings Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « include/gpu/GrProcessorDataManager.h ('k') | src/gpu/GrClipMaskManager.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #ifndef GrClipMaskManager_DEFINED 7 #ifndef GrClipMaskManager_DEFINED
8 #define GrClipMaskManager_DEFINED 8 #define GrClipMaskManager_DEFINED
9 9
10 #include "GrClipMaskCache.h" 10 #include "GrClipMaskCache.h"
(...skipping 25 matching lines...) Expand all
36 public: 36 public:
37 GrClipMaskManager(GrClipTarget* owner); 37 GrClipMaskManager(GrClipTarget* owner);
38 38
39 /** 39 /**
40 * Creates a clip mask if necessary as a stencil buffer or alpha texture 40 * Creates a clip mask if necessary as a stencil buffer or alpha texture
41 * and sets the GrGpu's scissor and stencil state. If the return is false 41 * and sets the GrGpu's scissor and stencil state. If the return is false
42 * then the draw can be skipped. The AutoRestoreEffects is initialized by 42 * then the draw can be skipped. The AutoRestoreEffects is initialized by
43 * the manager when it must install additional effects to implement the 43 * the manager when it must install additional effects to implement the
44 * clip. devBounds is optional but can help optimize clipping. 44 * clip. devBounds is optional but can help optimize clipping.
45 */ 45 */
46 bool setupClipping(GrPipelineBuilder*, 46 bool setupClipping(const GrPipelineBuilder&,
47 GrPipelineBuilder::AutoRestoreFragmentProcessors*, 47 GrPipelineBuilder::AutoRestoreFragmentProcessors*,
48 GrPipelineBuilder::AutoRestoreStencil*, 48 GrPipelineBuilder::AutoRestoreStencil*,
49 GrPipelineBuilder::AutoRestoreProcessorDataManager*,
49 GrScissorState*, 50 GrScissorState*,
50 const SkRect* devBounds); 51 const SkRect* devBounds);
51 52
52 /** 53 /**
53 * Purge resources to free up memory. TODO: This class shouldn't hold any lo ng lived refs 54 * Purge resources to free up memory. TODO: This class shouldn't hold any lo ng lived refs
54 * which will allow Resourcecache to automatically purge anything this class has created. 55 * which will allow Resourcecache to automatically purge anything this class has created.
55 */ 56 */
56 void purgeResources(); 57 void purgeResources();
57 58
58 bool isClipInStencil() const { 59 bool isClipInStencil() const {
(...skipping 20 matching lines...) Expand all
79 kModifyClip_StencilClipMode, 80 kModifyClip_StencilClipMode,
80 // Clip against the existing representation of the clip in the high bit 81 // Clip against the existing representation of the clip in the high bit
81 // of the stencil buffer. 82 // of the stencil buffer.
82 kRespectClip_StencilClipMode, 83 kRespectClip_StencilClipMode,
83 // Neither writing to nor clipping against the clip bit. 84 // Neither writing to nor clipping against the clip bit.
84 kIgnoreClip_StencilClipMode, 85 kIgnoreClip_StencilClipMode,
85 }; 86 };
86 87
87 // Attempts to install a series of coverage effects to implement the clip. R eturn indicates 88 // Attempts to install a series of coverage effects to implement the clip. R eturn indicates
88 // whether the element list was successfully converted to effects. 89 // whether the element list was successfully converted to effects.
89 bool installClipEffects(GrPipelineBuilder*, 90 bool installClipEffects(const GrPipelineBuilder&,
90 GrPipelineBuilder::AutoRestoreFragmentProcessors*, 91 GrPipelineBuilder::AutoRestoreFragmentProcessors*,
91 const GrReducedClip::ElementList&, 92 const GrReducedClip::ElementList&,
92 const SkVector& clipOffset, 93 const SkVector& clipOffset,
93 const SkRect* devBounds); 94 const SkRect* devBounds);
94 95
95 // Draws the clip into the stencil buffer 96 // Draws the clip into the stencil buffer
96 bool createStencilClipMask(GrRenderTarget*, 97 bool createStencilClipMask(GrRenderTarget*,
97 int32_t elementsGenID, 98 int32_t elementsGenID,
98 GrReducedClip::InitialState initialState, 99 GrReducedClip::InitialState initialState,
99 const GrReducedClip::ElementList& elements, 100 const GrReducedClip::ElementList& elements,
(...skipping 18 matching lines...) Expand all
118 // Returns the cached mask texture if it matches the elementsGenID and the c lipSpaceIBounds. 119 // Returns the cached mask texture if it matches the elementsGenID and the c lipSpaceIBounds.
119 // Returns NULL if not found. 120 // Returns NULL if not found.
120 GrTexture* getCachedMaskTexture(int32_t elementsGenID, const SkIRect& clipSp aceIBounds); 121 GrTexture* getCachedMaskTexture(int32_t elementsGenID, const SkIRect& clipSp aceIBounds);
121 122
122 // Handles allocation (if needed) of a clip alpha-mask texture for both the sw-upload 123 // Handles allocation (if needed) of a clip alpha-mask texture for both the sw-upload
123 // or gpu-rendered cases. 124 // or gpu-rendered cases.
124 GrTexture* allocMaskTexture(int32_t elementsGenID, 125 GrTexture* allocMaskTexture(int32_t elementsGenID,
125 const SkIRect& clipSpaceIBounds, 126 const SkIRect& clipSpaceIBounds,
126 bool willUpload); 127 bool willUpload);
127 128
128 bool useSWOnlyPath(const GrPipelineBuilder*, 129 bool useSWOnlyPath(const GrPipelineBuilder&,
129 const SkVector& clipToMaskOffset, 130 const SkVector& clipToMaskOffset,
130 const GrReducedClip::ElementList& elements); 131 const GrReducedClip::ElementList& elements);
131 132
132 // Draws a clip element into the target alpha mask. The caller should have a lready setup the 133 // Draws a clip element into the target alpha mask. The caller should have a lready setup the
133 // desired blend operation. Optionally if the caller already selected a path renderer it can 134 // desired blend operation. Optionally if the caller already selected a path renderer it can
134 // be passed. Otherwise the function will select one if the element is a pat h. 135 // be passed. Otherwise the function will select one if the element is a pat h.
135 bool drawElement(GrPipelineBuilder*, 136 bool drawElement(GrPipelineBuilder*,
136 const SkMatrix& viewMatrix, 137 const SkMatrix& viewMatrix,
137 GrTexture* target, 138 GrTexture* target,
138 const SkClipStack::Element*, 139 const SkClipStack::Element*,
(...skipping 15 matching lines...) Expand all
154 const SkIRect& srcBound); 155 const SkIRect& srcBound);
155 156
156 GrTexture* createTempMask(int width, int height); 157 GrTexture* createTempMask(int width, int height);
157 158
158 void setupCache(const SkClipStack& clip, 159 void setupCache(const SkClipStack& clip,
159 const SkIRect& bounds); 160 const SkIRect& bounds);
160 /** 161 /**
161 * Called prior to return control back the GrGpu in setupClipping. It update s the 162 * Called prior to return control back the GrGpu in setupClipping. It update s the
162 * GrPipelineBuilder with stencil settings that account for stencil-based cl ipping. 163 * GrPipelineBuilder with stencil settings that account for stencil-based cl ipping.
163 */ 164 */
164 void setPipelineBuilderStencil(GrPipelineBuilder*, GrPipelineBuilder::AutoRe storeStencil*); 165 void setPipelineBuilderStencil(const GrPipelineBuilder&,
166 GrPipelineBuilder::AutoRestoreStencil*);
165 167
166 /** 168 /**
167 * Adjusts the stencil settings to account for interaction with stencil 169 * Adjusts the stencil settings to account for interaction with stencil
168 * clipping. 170 * clipping.
169 */ 171 */
170 void adjustStencilParams(GrStencilSettings* settings, 172 void adjustStencilParams(GrStencilSettings* settings,
171 StencilClipMode mode, 173 StencilClipMode mode,
172 int stencilBitCnt); 174 int stencilBitCnt);
173 175
174 /** 176 /**
175 * We may represent the clip as a mask in the stencil buffer or as an alpha 177 * We may represent the clip as a mask in the stencil buffer or as an alpha
176 * texture. It may be neither because the scissor rect suffices or we 178 * texture. It may be neither because the scissor rect suffices or we
177 * haven't yet examined the clip. 179 * haven't yet examined the clip.
178 */ 180 */
179 enum ClipMaskType { 181 enum ClipMaskType {
180 kNone_ClipMaskType, 182 kNone_ClipMaskType,
181 kStencil_ClipMaskType, 183 kStencil_ClipMaskType,
182 kAlpha_ClipMaskType, 184 kAlpha_ClipMaskType,
183 } fCurrClipMaskType; 185 } fCurrClipMaskType;
184 186
185 GrClipMaskCache fAACache; // cache for the AA path 187 GrClipMaskCache fAACache; // cache for the AA path
186 GrClipTarget* fClipTarget; // This is our owning clip target. 188 GrClipTarget* fClipTarget; // This is our owning clip target.
187 StencilClipMode fClipMode; 189 StencilClipMode fClipMode;
188 190
189 typedef SkNoncopyable INHERITED; 191 typedef SkNoncopyable INHERITED;
190 }; 192 };
191 #endif // GrClipMaskManager_DEFINED 193 #endif // GrClipMaskManager_DEFINED
OLDNEW
« no previous file with comments | « include/gpu/GrProcessorDataManager.h ('k') | src/gpu/GrClipMaskManager.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698