blob: 572e4cbf3b2b4272f672e8a0ebe8e5f8ba1f1e14 [file] [log] [blame]
reed@google.comac10a2d2010-12-22 21:39:39 +00001/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00002 * Copyright 2010 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.
reed@google.comac10a2d2010-12-22 21:39:39 +00006 */
7
reed@google.comac10a2d2010-12-22 21:39:39 +00008#ifndef GrDrawTarget_DEFINED
9#define GrDrawTarget_DEFINED
10
joshualitt44701df2015-02-23 14:44:57 -080011#include "GrClip.h"
joshualitt6db519c2014-10-29 08:48:18 -070012#include "GrClipMaskManager.h"
commit-bot@chromium.org2a05de02014-03-25 15:17:32 +000013#include "GrContext.h"
joshualitt8072caa2015-02-12 14:20:52 -080014#include "GrPathProcessor.h"
15#include "GrPrimitiveProcessor.h"
bsalomon@google.com934c5702012-03-20 21:17:58 +000016#include "GrIndexBuffer.h"
kkinnunenccdaa042014-08-20 01:36:23 -070017#include "GrPathRendering.h"
egdaniel8dd688b2015-01-22 10:16:09 -080018#include "GrPipelineBuilder.h"
bsalomona387a112015-08-11 14:47:42 -070019#include "GrPipeline.h"
joshualitt7eb8c7b2014-11-18 14:24:27 -080020#include "GrVertexBuffer.h"
bsalomon6a44c6a2015-05-26 09:49:05 -070021#include "GrXferProcessor.h"
reed@google.comac10a2d2010-12-22 21:39:39 +000022
bsalomon@google.com8d67c072012-12-13 20:38:14 +000023#include "SkClipStack.h"
commit-bot@chromium.orga4de8c22013-09-09 13:38:37 +000024#include "SkMatrix.h"
sugoi@google.com12b4e272012-12-06 20:13:11 +000025#include "SkPath.h"
commit-bot@chromium.org9b62aa12014-03-25 11:59:40 +000026#include "SkStrokeRec.h"
robertphillips@google.coma2d71482012-08-01 20:08:47 +000027#include "SkTArray.h"
commit-bot@chromium.orga4de8c22013-09-09 13:38:37 +000028#include "SkTLazy.h"
commit-bot@chromium.orga0b40282013-09-18 13:00:55 +000029#include "SkTypes.h"
bsalomon@google.com8d67c072012-12-13 20:38:14 +000030#include "SkXfermode.h"
Scroggo97c88c22011-05-11 14:05:25 +000031
bsalomon53469832015-08-18 09:20:09 -070032class GrBatch;
joshualitt44701df2015-02-23 14:44:57 -080033class GrClip;
bsalomon4b91f762015-05-19 09:29:46 -070034class GrCaps;
bsalomon@google.com64aef2b2012-06-11 15:36:13 +000035class GrPath;
cdaltonb85a0aa2014-07-21 15:32:44 -070036class GrPathRange;
bsalomonabd30f52015-08-13 13:34:48 -070037class GrDrawBatch;
sugoi@google.com12b4e272012-12-06 20:13:11 +000038
commit-bot@chromium.orga4de8c22013-09-09 13:38:37 +000039class GrDrawTarget : public SkRefCnt {
bsalomon@google.comf6601872012-08-28 21:11:35 +000040public:
mtklein2766c002015-06-26 11:45:03 -070041
bsalomon@google.comf6601872012-08-28 21:11:35 +000042
cdalton55b24af2014-11-25 11:00:56 -080043 typedef GrPathRange::PathIndexType PathIndexType;
44 typedef GrPathRendering::PathTransformType PathTransformType;
kkinnunenccdaa042014-08-20 01:36:23 -070045
reed@google.comac10a2d2010-12-22 21:39:39 +000046 ///////////////////////////////////////////////////////////////////////////
47
bsalomon@google.com6e4e6502013-02-25 20:12:45 +000048 // The context may not be fully constructed and should not be used during GrDrawTarget
49 // construction.
bsalomon4061b122015-05-29 10:26:19 -070050 GrDrawTarget(GrGpu* gpu, GrResourceProvider*);
bsalomona73239a2015-04-28 13:35:17 -070051
bsalomon4061b122015-05-29 10:26:19 -070052 virtual ~GrDrawTarget();
reed@google.comac10a2d2010-12-22 21:39:39 +000053
54 /**
bsalomona73239a2015-04-28 13:35:17 -070055 * Empties the draw buffer of any queued up draws.
56 */
robertphillipse40d3972015-05-07 09:51:43 -070057 void reset() { this->onReset(); }
bsalomona73239a2015-04-28 13:35:17 -070058
59 /**
60 * This plays any queued up draws to its GrGpu target. It also resets this object (i.e. flushing
61 * is destructive).
62 */
63 void flush();
64
65 /**
bsalomon@google.com18c9c192011-09-22 21:01:31 +000066 * Gets the capabilities of the draw target.
67 */
bsalomon4061b122015-05-29 10:26:19 -070068 const GrCaps* caps() const { return fCaps; }
bsalomon@google.com18c9c192011-09-22 21:01:31 +000069
bsalomonabd30f52015-08-13 13:34:48 -070070 void drawBatch(const GrPipelineBuilder&, GrDrawBatch*);
joshualitt4d8da812015-01-28 12:53:54 -080071
bsalomon@google.com86afc2a2011-02-16 16:12:19 +000072 /**
bsalomon@google.com64aef2b2012-06-11 15:36:13 +000073 * Draws path into the stencil buffer. The fill must be either even/odd or
74 * winding (not inverse or hairline). It will respect the HW antialias flag
egdaniel8dd688b2015-01-22 10:16:09 -080075 * on the GrPipelineBuilder (if possible in the 3D API). Note, we will never have an inverse
76 * fill with stencil path
bsalomon@google.com64aef2b2012-06-11 15:36:13 +000077 */
joshualitt1c735482015-07-13 08:08:25 -070078 void stencilPath(const GrPipelineBuilder&, const GrPathProcessor*, const GrPath*,
egdaniel8dd688b2015-01-22 10:16:09 -080079 GrPathRendering::FillType);
bsalomon@google.com64aef2b2012-06-11 15:36:13 +000080
81 /**
commit-bot@chromium.org32184d82013-10-09 15:14:18 +000082 * Draws a path. Fill must not be a hairline. It will respect the HW
egdaniel8dd688b2015-01-22 10:16:09 -080083 * antialias flag on the GrPipelineBuilder (if possible in the 3D API).
commit-bot@chromium.orgc4dc0ad2013-10-09 14:11:33 +000084 */
joshualitt1c735482015-07-13 08:08:25 -070085 void drawPath(const GrPipelineBuilder&, const GrPathProcessor*, const GrPath*,
egdaniel8dd688b2015-01-22 10:16:09 -080086 GrPathRendering::FillType);
commit-bot@chromium.orgc4dc0ad2013-10-09 14:11:33 +000087
88 /**
cdalton55b24af2014-11-25 11:00:56 -080089 * Draws the aggregate path from combining multiple. Note that this will not
90 * always be equivalent to back-to-back calls to drawPath(). It will respect
egdaniel8dd688b2015-01-22 10:16:09 -080091 * the HW antialias flag on the GrPipelineBuilder (if possible in the 3D API).
commit-bot@chromium.org9b62aa12014-03-25 11:59:40 +000092 *
cdalton55b24af2014-11-25 11:00:56 -080093 * @param pathRange Source paths to draw from
94 * @param indices Array of path indices to draw
95 * @param indexType Data type of the array elements in indexBuffer
96 * @param transformValues Array of transforms for the individual paths
97 * @param transformType Type of transforms in transformBuffer
98 * @param count Number of paths to draw
cdaltonb85a0aa2014-07-21 15:32:44 -070099 * @param fill Fill type for drawing all the paths
commit-bot@chromium.org9b62aa12014-03-25 11:59:40 +0000100 */
joshualitt1c735482015-07-13 08:08:25 -0700101 void drawPaths(const GrPipelineBuilder&,
joshualitt56995b52014-12-11 15:44:02 -0800102 const GrPathProcessor*,
joshualitt2e3b3e32014-12-09 13:31:14 -0800103 const GrPathRange* pathRange,
cdalton55b24af2014-11-25 11:00:56 -0800104 const void* indices,
105 PathIndexType indexType,
106 const float transformValues[],
107 PathTransformType transformType,
joshualitt9853cce2014-11-17 14:22:48 -0800108 int count,
joshualitt92e496f2014-10-31 13:56:50 -0700109 GrPathRendering::FillType fill);
cdaltonb85a0aa2014-07-21 15:32:44 -0700110
commit-bot@chromium.org9b62aa12014-03-25 11:59:40 +0000111 /**
bsalomon72e3ae42015-04-28 08:08:46 -0700112 * Helper function for drawing rects.
skia.committer@gmail.com044679e2013-02-15 07:16:57 +0000113 *
bsalomon@google.comc7818882013-03-20 19:19:53 +0000114 * @param rect the rect to draw
bsalomon@google.comc7818882013-03-20 19:19:53 +0000115 * @param localRect optional rect that specifies local coords to map onto
halcanary96fcdcc2015-08-27 07:41:13 -0700116 * rect. If nullptr then rect serves as the local coords.
joshualitt8fc6c2d2014-12-22 15:27:05 -0800117 * @param localMatrix Optional local matrix. The local coordinates are specified by localRect,
halcanary96fcdcc2015-08-27 07:41:13 -0700118 * or if it is nullptr by rect. This matrix applies to the coordinate implied by
joshualitt8fc6c2d2014-12-22 15:27:05 -0800119 * that rectangle before it is input to GrCoordTransforms that read local
120 * coordinates
bsalomon@google.com86afc2a2011-02-16 16:12:19 +0000121 */
joshualittd2b23e02015-08-21 10:53:34 -0700122 void drawNonAARect(const GrPipelineBuilder& pipelineBuilder,
123 GrColor color,
124 const SkMatrix& viewMatrix,
125 const SkRect& rect);
joshualittb6b513b2015-08-21 10:25:18 -0700126
joshualittd2b23e02015-08-21 10:53:34 -0700127 void drawNonAARect(const GrPipelineBuilder& pipelineBuilder,
128 GrColor color,
129 const SkMatrix& viewMatrix,
130 const SkRect& rect,
131 const SkMatrix& localMatrix);
joshualittb6b513b2015-08-21 10:25:18 -0700132
joshualittd2b23e02015-08-21 10:53:34 -0700133 void drawNonAARect(const GrPipelineBuilder& pipelineBuilder,
134 GrColor color,
135 const SkMatrix& viewMatrix,
136 const SkRect& rect,
137 const SkRect& localRect);
jvanverth@google.com39768252013-02-14 15:25:44 +0000138
joshualittd2b23e02015-08-21 10:53:34 -0700139 void drawNonAARect(const GrPipelineBuilder& ds,
140 GrColor color,
141 const SkMatrix& viewM,
142 const SkIRect& irect) {
reed@google.com44699382013-10-31 17:28:30 +0000143 SkRect rect = SkRect::Make(irect);
joshualittd2b23e02015-08-21 10:53:34 -0700144 this->drawNonAARect(ds, color, viewM, rect);
bsalomon@google.comcf939ae2012-12-13 19:59:23 +0000145 }
bsalomon@google.com86afc2a2011-02-16 16:12:19 +0000146
joshualitt1c735482015-07-13 08:08:25 -0700147 void drawAARect(const GrPipelineBuilder& pipelineBuilder,
robertphillipsea461502015-05-26 11:38:03 -0700148 GrColor color,
149 const SkMatrix& viewMatrix,
150 const SkRect& rect,
151 const SkRect& devRect);
bsalomon@google.com934c5702012-03-20 21:17:58 +0000152
153 /**
egdaniel8dd688b2015-01-22 10:16:09 -0800154 * Clear the passed in render target. Ignores the GrPipelineBuilder and clip. Clears the whole
halcanary96fcdcc2015-08-27 07:41:13 -0700155 * thing if rect is nullptr, otherwise just the rect. If canIgnoreRect is set then the entire
egdaniel8dd688b2015-01-22 10:16:09 -0800156 * render target can be optionally cleared.
bsalomon@google.com0b335c12011-04-25 19:17:44 +0000157 */
joshualitt9853cce2014-11-17 14:22:48 -0800158 void clear(const SkIRect* rect,
159 GrColor color,
160 bool canIgnoreRect,
bsalomon63b21962014-11-05 07:05:34 -0800161 GrRenderTarget* renderTarget);
skia.committer@gmail.coma9493a32013-04-04 07:01:12 +0000162
bsalomon53469832015-08-18 09:20:09 -0700163 /** Discards the contents render target. */
164 void discard(GrRenderTarget*);
commit-bot@chromium.org28361fa2014-03-28 16:08:05 +0000165
166 /**
bsalomon@google.come4617bf2013-04-03 14:56:40 +0000167 * Copies a pixel rectangle from one surface to another. This call may finalize
168 * reserved vertex/index data (as though a draw call was made). The src pixels
169 * copied are specified by srcRect. They are copied to a rect of the same
170 * size in dst with top left at dstPoint. If the src rect is clipped by the
171 * src bounds then pixel values in the dst rect corresponding to area clipped
bsalomon6df86402015-06-01 10:41:49 -0700172 * by the src rect are not overwritten. This method is not guaranteed to succeed
bsalomon@google.come4617bf2013-04-03 14:56:40 +0000173 * depending on the type of surface, configs, etc, and the backend-specific
bsalomon6df86402015-06-01 10:41:49 -0700174 * limitations.
bsalomon@google.come4617bf2013-04-03 14:56:40 +0000175 */
bsalomon6df86402015-06-01 10:41:49 -0700176 void copySurface(GrSurface* dst,
bsalomonf90a02b2014-11-26 12:28:00 -0800177 GrSurface* src,
178 const SkIRect& srcRect,
179 const SkIPoint& dstPoint);
bsalomon@google.com116ad842013-04-09 15:38:19 +0000180 /**
robertphillips@google.comff175842012-05-14 19:31:39 +0000181 * Release any resources that are cached but not currently in use. This
182 * is intended to give an application some recourse when resources are low.
183 */
184 virtual void purgeResources() {};
185
bsalomon4061b122015-05-29 10:26:19 -0700186 bool programUnitTest(GrContext* owner, int maxStages);
joshualitt2c93efe2014-11-06 12:57:13 -0800187
bsalomona387a112015-08-11 14:47:42 -0700188 struct PipelineInfo {
189 PipelineInfo(const GrPipelineBuilder* pipelineBuilder, const GrScissorState* scissor,
190 const GrPrimitiveProcessor* primProc,
191 const SkRect* devBounds, GrDrawTarget* target);
192
193 PipelineInfo(const GrPipelineBuilder* pipelineBuilder, const GrScissorState* scissor,
bsalomonabd30f52015-08-13 13:34:48 -0700194 const GrDrawBatch* batch, const SkRect* devBounds,
bsalomona387a112015-08-11 14:47:42 -0700195 GrDrawTarget* target);
196
197 bool valid() const { return SkToBool(fArgs.fPipelineBuilder); }
198
199 const GrPipeline::CreateArgs& pipelineCreateArgs() const {
200 SkASSERT(this->valid());
201 return fArgs;
202 }
203
bsalomona387a112015-08-11 14:47:42 -0700204 private:
205 GrPipeline::CreateArgs fArgs;
206 };
207
reed@google.comac10a2d2010-12-22 21:39:39 +0000208protected:
bsalomon4061b122015-05-29 10:26:19 -0700209 GrGpu* getGpu() { return fGpu; }
210 const GrGpu* getGpu() const { return fGpu; }
bsalomona73239a2015-04-28 13:35:17 -0700211
joshualitt65171342014-10-09 07:25:36 -0700212 // Makes a copy of the dst if it is necessary for the draw. Returns false if a copy is required
213 // but couldn't be made. Otherwise, returns true. This method needs to be protected because it
214 // needs to be accessed by GLPrograms to setup a correct drawstate
bsalomon50785a32015-02-06 07:02:37 -0800215 bool setupDstReadIfNecessary(const GrPipelineBuilder&,
egdaniele36914c2015-02-13 09:00:33 -0800216 const GrProcOptInfo& colorPOI,
217 const GrProcOptInfo& coveragePOI,
bsalomon6a44c6a2015-05-26 09:49:05 -0700218 GrXferProcessor::DstTexture*,
joshualitt9853cce2014-11-17 14:22:48 -0800219 const SkRect* drawBounds);
joshualitt65171342014-10-09 07:25:36 -0700220
bsalomon5ea03632015-08-18 10:33:30 -0700221 virtual void onDrawBatch(GrBatch*) = 0;
222
bsalomon@google.com02ddc8b2013-01-28 15:35:28 +0000223private:
bsalomona73239a2015-04-28 13:35:17 -0700224 virtual void onReset() = 0;
bsalomonf90a02b2014-11-26 12:28:00 -0800225
bsalomona73239a2015-04-28 13:35:17 -0700226 virtual void onFlush() = 0;
bsalomonf90a02b2014-11-26 12:28:00 -0800227
egdaniele36914c2015-02-13 09:00:33 -0800228 virtual void onDrawPaths(const GrPathProcessor*,
joshualitt9853cce2014-11-17 14:22:48 -0800229 const GrPathRange*,
cdalton55b24af2014-11-25 11:00:56 -0800230 const void* indices,
231 PathIndexType,
232 const float transformValues[],
joshualitt2c93efe2014-11-06 12:57:13 -0800233 PathTransformType,
cdalton55b24af2014-11-25 11:00:56 -0800234 int count,
joshualitt2c93efe2014-11-06 12:57:13 -0800235 const GrStencilSettings&,
egdaniele36914c2015-02-13 09:00:33 -0800236 const PipelineInfo&) = 0;
bsalomon@google.com64aef2b2012-06-11 15:36:13 +0000237
commit-bot@chromium.orga8916ff2013-08-16 15:53:46 +0000238 // Check to see if this set of draw commands has been sent out
239 virtual bool isIssued(uint32_t drawID) { return true; }
joshualitt9853cce2014-11-17 14:22:48 -0800240 void getPathStencilSettingsForFilltype(GrPathRendering::FillType,
egdaniel8dc7c3a2015-04-16 11:22:42 -0700241 const GrStencilAttachment*,
joshualitt9853cce2014-11-17 14:22:48 -0800242 GrStencilSettings*);
joshualitta7024152014-11-03 14:16:35 -0800243 virtual GrClipMaskManager* clipMaskManager() = 0;
joshualitt1c735482015-07-13 08:08:25 -0700244 virtual bool setupClip(const GrPipelineBuilder&,
joshualitt4421a4c2015-07-13 09:36:41 -0700245 GrPipelineBuilder::AutoRestoreFragmentProcessorState*,
bsalomon6be6f7c2015-02-26 13:05:21 -0800246 GrPipelineBuilder::AutoRestoreStencil*,
247 GrScissorState*,
joshualitt8059eb92014-12-29 15:10:07 -0800248 const SkRect* devBounds) = 0;
skia.committer@gmail.com74758112013-08-17 07:01:54 +0000249
bsalomon4061b122015-05-29 10:26:19 -0700250 GrGpu* fGpu;
251 const GrCaps* fCaps;
252 GrResourceProvider* fResourceProvider;
bsalomon4061b122015-05-29 10:26:19 -0700253 bool fFlushing;
reed@google.comfa35e3d2012-06-26 20:16:17 +0000254
commit-bot@chromium.orga4de8c22013-09-09 13:38:37 +0000255 typedef SkRefCnt INHERITED;
reed@google.comac10a2d2010-12-22 21:39:39 +0000256};
257
joshualitt329bf482014-10-29 12:31:28 -0700258/*
259 * This class is JUST for clip mask manager. Everyone else should just use draw target above.
260 */
joshualitt6db519c2014-10-29 08:48:18 -0700261class GrClipTarget : public GrDrawTarget {
262public:
bsalomonedd77a12015-05-29 09:45:57 -0700263 GrClipTarget(GrContext*);
joshualitt329bf482014-10-29 12:31:28 -0700264
265 /* Clip mask manager needs access to the context.
266 * TODO we only need a very small subset of context in the CMM.
267 */
bsalomon4061b122015-05-29 10:26:19 -0700268 GrContext* getContext() { return fContext; }
269 const GrContext* getContext() const { return fContext; }
joshualitt329bf482014-10-29 12:31:28 -0700270
joshualitt6db519c2014-10-29 08:48:18 -0700271 /**
272 * Clip Mask Manager(and no one else) needs to clear private stencil bits.
273 * ClipTarget subclass sets clip bit in the stencil buffer. The subclass
274 * is free to clear the remaining bits to zero if masked clears are more
275 * expensive than clearing all bits.
276 */
bsalomon5ea03632015-08-18 10:33:30 -0700277 void clearStencilClip(const SkIRect&, bool insideClip, GrRenderTarget*);
joshualitt6db519c2014-10-29 08:48:18 -0700278
joshualitt3bdd7dc2014-10-31 08:27:39 -0700279 /**
280 * Release any resources that are cached but not currently in use. This
281 * is intended to give an application some recourse when resources are low.
282 */
bsalomonedd77a12015-05-29 09:45:57 -0700283 void purgeResources() override;
joshualitt3bdd7dc2014-10-31 08:27:39 -0700284
joshualitt329bf482014-10-29 12:31:28 -0700285protected:
bsalomonedd77a12015-05-29 09:45:57 -0700286 SkAutoTDelete<GrClipMaskManager> fClipMaskManager;
bsalomon4061b122015-05-29 10:26:19 -0700287 GrContext* fContext;
joshualitt329bf482014-10-29 12:31:28 -0700288
joshualitt6db519c2014-10-29 08:48:18 -0700289private:
bsalomonedd77a12015-05-29 09:45:57 -0700290 GrClipMaskManager* clipMaskManager() override { return fClipMaskManager; }
joshualitt329bf482014-10-29 12:31:28 -0700291
joshualitt1c735482015-07-13 08:08:25 -0700292 bool setupClip(const GrPipelineBuilder&,
joshualitt4421a4c2015-07-13 09:36:41 -0700293 GrPipelineBuilder::AutoRestoreFragmentProcessorState*,
joshualitt5e6ba212015-07-13 07:35:05 -0700294 GrPipelineBuilder::AutoRestoreStencil*,
joshualitt5e6ba212015-07-13 07:35:05 -0700295 GrScissorState* scissorState,
296 const SkRect* devBounds) override;
joshualitt2c93efe2014-11-06 12:57:13 -0800297
joshualitt6db519c2014-10-29 08:48:18 -0700298 typedef GrDrawTarget INHERITED;
299};
300
reed@google.comac10a2d2010-12-22 21:39:39 +0000301#endif