GrDrawTarget.h revision 99c7c07e0f1f7b78980eb21d84bebda8b45a7178
1ec3ed6a5ebf6f2c406d7bcf94b6bc34fcaeb976eepoger@google.com/*
2ec3ed6a5ebf6f2c406d7bcf94b6bc34fcaeb976eepoger@google.com * Copyright 2010 Google Inc.
3ec3ed6a5ebf6f2c406d7bcf94b6bc34fcaeb976eepoger@google.com *
4ec3ed6a5ebf6f2c406d7bcf94b6bc34fcaeb976eepoger@google.com * Use of this source code is governed by a BSD-style license that can be
5ec3ed6a5ebf6f2c406d7bcf94b6bc34fcaeb976eepoger@google.com * found in the LICENSE file.
6ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com */
7ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com
8ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com#ifndef GrDrawTarget_DEFINED
9ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com#define GrDrawTarget_DEFINED
10ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com
1144701df5ce572ac3cccec785cf52103d3d5d14a5joshualitt#include "GrClip.h"
126db519c42471aaaa8a8e1a3ece314014481ab832joshualitt#include "GrClipMaskManager.h"
132a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org#include "GrContext.h"
148072caa80384292858d31ae34b7e19768875866bjoshualitt#include "GrPathProcessor.h"
158072caa80384292858d31ae34b7e19768875866bjoshualitt#include "GrPrimitiveProcessor.h"
16934c570297c1b1f99cb4ca8d012d468a7eddf73fbsalomon@google.com#include "GrIndexBuffer.h"
17ccdaa0422501e5cbcba53d6bd19f2736f1beaef3kkinnunen#include "GrPathRendering.h"
188dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel#include "GrPipelineBuilder.h"
192a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org#include "GrTraceMarker.h"
207eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt#include "GrVertexBuffer.h"
21ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com
228d67c0711b52226db59158a0cfce09f35badd96absalomon@google.com#include "SkClipStack.h"
23a4de8c257ea0be8ff7081f645249b6afe5c48e7ecommit-bot@chromium.org#include "SkMatrix.h"
2412b4e27ae1a29460e91a59f38122483e1faec697sugoi@google.com#include "SkPath.h"
259b62aa156bcf1db6f11af9302bf8bb8ef2567142commit-bot@chromium.org#include "SkStrokeRec.h"
26a2d71482db8b6d752a51c96da74768d7dfc27932robertphillips@google.com#include "SkTArray.h"
27a4de8c257ea0be8ff7081f645249b6afe5c48e7ecommit-bot@chromium.org#include "SkTLazy.h"
28a0b40280a49a8a43af7929ead3b3489951c58501commit-bot@chromium.org#include "SkTypes.h"
298d67c0711b52226db59158a0cfce09f35badd96absalomon@google.com#include "SkXfermode.h"
3097c88c255cff3dbb8343c5d090526fdbedad6dd6Scroggo
314d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualittclass GrBatch;
3244701df5ce572ac3cccec785cf52103d3d5d14a5joshualittclass GrClip;
33c26d94fd7dc0b00cd6d0e42d28285f4a38aff021bsalomon@google.comclass GrDrawTargetCaps;
34a73239a0096370221d3dfababf339dd6d3fed84fbsalomonclass GrIndexBufferAllocPool;
3564aef2bacd1f5c25ffd9347aabd6265c9b60c0f4bsalomon@google.comclass GrPath;
36b85a0aab6905af8b329539b7573a7555b727d5e5cdaltonclass GrPathRange;
37e36914cb205699526988127a827d1a76c9a98d39egdanielclass GrPipeline;
38a73239a0096370221d3dfababf339dd6d3fed84fbsalomonclass GrVertexBufferAllocPool;
3912b4e27ae1a29460e91a59f38122483e1faec697sugoi@google.com
40a4de8c257ea0be8ff7081f645249b6afe5c48e7ecommit-bot@chromium.orgclass GrDrawTarget : public SkRefCnt {
41bcce8926524827775539874346dd424a9510dbc9bsalomon@google.compublic:
42bcce8926524827775539874346dd424a9510dbc9bsalomon@google.com    SK_DECLARE_INST_COUNT(GrDrawTarget)
43bcce8926524827775539874346dd424a9510dbc9bsalomon@google.com
4455b24afc178e641e17a5664beba7ab2b4982c91acdalton    typedef GrPathRange::PathIndexType PathIndexType;
4555b24afc178e641e17a5664beba7ab2b4982c91acdalton    typedef GrPathRendering::PathTransformType PathTransformType;
46ccdaa0422501e5cbcba53d6bd19f2736f1beaef3kkinnunen
47ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com    ///////////////////////////////////////////////////////////////////////////
48ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com
496e4e65066a7c0dbc9bfbfe4b8f5d49c3d8a79b59bsalomon@google.com    // The context may not be fully constructed and should not be used during GrDrawTarget
506e4e65066a7c0dbc9bfbfe4b8f5d49c3d8a79b59bsalomon@google.com    // construction.
51a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    GrDrawTarget(GrContext* context, GrVertexBufferAllocPool*, GrIndexBufferAllocPool*);
52a73239a0096370221d3dfababf339dd6d3fed84fbsalomon
5372e3ae486c66871c2043eac4f08d85d419fbca2absalomon    virtual ~GrDrawTarget() {}
54ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com
55ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com    /**
56a73239a0096370221d3dfababf339dd6d3fed84fbsalomon     * Empties the draw buffer of any queued up draws.
57a73239a0096370221d3dfababf339dd6d3fed84fbsalomon     */
58a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    void reset();
59a73239a0096370221d3dfababf339dd6d3fed84fbsalomon
60a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    /**
61a73239a0096370221d3dfababf339dd6d3fed84fbsalomon     * This plays any queued up draws to its GrGpu target. It also resets this object (i.e. flushing
62a73239a0096370221d3dfababf339dd6d3fed84fbsalomon     * is destructive).
63a73239a0096370221d3dfababf339dd6d3fed84fbsalomon     */
64a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    void flush();
65a73239a0096370221d3dfababf339dd6d3fed84fbsalomon
66a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    /**
6718c9c198f571997463d9a7134dbd88298e592ec2bsalomon@google.com     * Gets the capabilities of the draw target.
6818c9c198f571997463d9a7134dbd88298e592ec2bsalomon@google.com     */
69c26d94fd7dc0b00cd6d0e42d28285f4a38aff021bsalomon@google.com    const GrDrawTargetCaps* caps() const { return fCaps.get(); }
7018c9c198f571997463d9a7134dbd88298e592ec2bsalomon@google.com
7199c7c07e0f1f7b78980eb21d84bebda8b45a7178joshualitt    void drawBatch(GrPipelineBuilder*, GrBatch*);
724d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt
7386afc2ae27fec84c01eb0e81a32766bdaf67dca8bsalomon@google.com    /**
7464aef2bacd1f5c25ffd9347aabd6265c9b60c0f4bsalomon@google.com     * Draws path into the stencil buffer. The fill must be either even/odd or
7564aef2bacd1f5c25ffd9347aabd6265c9b60c0f4bsalomon@google.com     * winding (not inverse or hairline). It will respect the HW antialias flag
768dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel     * on the GrPipelineBuilder (if possible in the 3D API).  Note, we will never have an inverse
778dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel     * fill with stencil path
7864aef2bacd1f5c25ffd9347aabd6265c9b60c0f4bsalomon@google.com     */
798dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    void stencilPath(GrPipelineBuilder*, const GrPathProcessor*, const GrPath*,
808dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel                     GrPathRendering::FillType);
8164aef2bacd1f5c25ffd9347aabd6265c9b60c0f4bsalomon@google.com
8264aef2bacd1f5c25ffd9347aabd6265c9b60c0f4bsalomon@google.com    /**
8332184d81629e39809bb9e915286d8fe971a8ed68commit-bot@chromium.org     * Draws a path. Fill must not be a hairline. It will respect the HW
848dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel     * antialias flag on the GrPipelineBuilder (if possible in the 3D API).
85c4dc0ad8e252a7e30d19b47d3d0d9f2c69faf854commit-bot@chromium.org     */
868dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    void drawPath(GrPipelineBuilder*, const GrPathProcessor*, const GrPath*,
878dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel                  GrPathRendering::FillType);
88c4dc0ad8e252a7e30d19b47d3d0d9f2c69faf854commit-bot@chromium.org
89c4dc0ad8e252a7e30d19b47d3d0d9f2c69faf854commit-bot@chromium.org    /**
9055b24afc178e641e17a5664beba7ab2b4982c91acdalton     * Draws the aggregate path from combining multiple. Note that this will not
9155b24afc178e641e17a5664beba7ab2b4982c91acdalton     * always be equivalent to back-to-back calls to drawPath(). It will respect
928dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel     * the HW antialias flag on the GrPipelineBuilder (if possible in the 3D API).
939b62aa156bcf1db6f11af9302bf8bb8ef2567142commit-bot@chromium.org     *
9455b24afc178e641e17a5664beba7ab2b4982c91acdalton     * @param pathRange       Source paths to draw from
9555b24afc178e641e17a5664beba7ab2b4982c91acdalton     * @param indices         Array of path indices to draw
9655b24afc178e641e17a5664beba7ab2b4982c91acdalton     * @param indexType       Data type of the array elements in indexBuffer
9755b24afc178e641e17a5664beba7ab2b4982c91acdalton     * @param transformValues Array of transforms for the individual paths
9855b24afc178e641e17a5664beba7ab2b4982c91acdalton     * @param transformType   Type of transforms in transformBuffer
9955b24afc178e641e17a5664beba7ab2b4982c91acdalton     * @param count           Number of paths to draw
100b85a0aab6905af8b329539b7573a7555b727d5e5cdalton     * @param fill            Fill type for drawing all the paths
101b85a0aab6905af8b329539b7573a7555b727d5e5cdalton     */
1028dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    void drawPaths(GrPipelineBuilder*,
10356995b5cc00c9c83bd5fcf86bca9a67e939a96cbjoshualitt                   const GrPathProcessor*,
1042e3b3e369d79e78f7635d4c20e83a47ab571bdf2joshualitt                   const GrPathRange* pathRange,
10555b24afc178e641e17a5664beba7ab2b4982c91acdalton                   const void* indices,
10655b24afc178e641e17a5664beba7ab2b4982c91acdalton                   PathIndexType indexType,
10755b24afc178e641e17a5664beba7ab2b4982c91acdalton                   const float transformValues[],
10855b24afc178e641e17a5664beba7ab2b4982c91acdalton                   PathTransformType transformType,
1099853ccef19c200be93a6211f32589fa82a53067cjoshualitt                   int count,
11092e496f96abbd664888f0c8a7d546ab02e703bf7joshualitt                   GrPathRendering::FillType fill);
111b85a0aab6905af8b329539b7573a7555b727d5e5cdalton
1129b62aa156bcf1db6f11af9302bf8bb8ef2567142commit-bot@chromium.org    /**
11372e3ae486c66871c2043eac4f08d85d419fbca2absalomon     * Helper function for drawing rects.
114044679ef8c08e1f01afadf5bc08251fe8597df81skia.committer@gmail.com     *
115c78188896e28a4ae49e406a7422b345ae177dafebsalomon@google.com     * @param rect        the rect to draw
116c78188896e28a4ae49e406a7422b345ae177dafebsalomon@google.com     * @param localRect   optional rect that specifies local coords to map onto
117c78188896e28a4ae49e406a7422b345ae177dafebsalomon@google.com     *                    rect. If NULL then rect serves as the local coords.
1188fc6c2d82c1f30ff82274334c01f0799def6a609joshualitt     * @param localMatrix Optional local matrix. The local coordinates are specified by localRect,
1198fc6c2d82c1f30ff82274334c01f0799def6a609joshualitt     *                    or if it is NULL by rect. This matrix applies to the coordinate implied by
1208fc6c2d82c1f30ff82274334c01f0799def6a609joshualitt     *                    that rectangle before it is input to GrCoordTransforms that read local
1218fc6c2d82c1f30ff82274334c01f0799def6a609joshualitt     *                    coordinates
12286afc2ae27fec84c01eb0e81a32766bdaf67dca8bsalomon@google.com     */
1234d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt    void drawRect(GrPipelineBuilder* pipelineBuilder,
1242e3b3e369d79e78f7635d4c20e83a47ab571bdf2joshualitt                  GrColor color,
1258059eb9f6e24ed609393fbda4ad71edea03ac258joshualitt                  const SkMatrix& viewMatrix,
1269853ccef19c200be93a6211f32589fa82a53067cjoshualitt                  const SkRect& rect,
127fd03d4a829efe2d77a712fd991927c55f59a2ffecommit-bot@chromium.org                  const SkRect* localRect,
1280406b9e1faee06c6ecb2732a1bcf3b0e53104e07bsalomon@google.com                  const SkMatrix* localMatrix) {
1294d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        this->onDrawRect(pipelineBuilder, color, viewMatrix, rect, localRect, localMatrix);
1300406b9e1faee06c6ecb2732a1bcf3b0e53104e07bsalomon@google.com    }
1313976825a21532e254311b90b4a9046e25717e335jvanverth@google.com
132cf939ae54842fc7408ee68a41427086962b4c3dcbsalomon@google.com    /**
133c78188896e28a4ae49e406a7422b345ae177dafebsalomon@google.com     * Helper for drawRect when the caller doesn't need separate local rects or matrices.
134cf939ae54842fc7408ee68a41427086962b4c3dcbsalomon@google.com     */
1358dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    void drawSimpleRect(GrPipelineBuilder* ds, GrColor color, const SkMatrix& viewM,
1368dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel                        const SkRect& rect) {
1378059eb9f6e24ed609393fbda4ad71edea03ac258joshualitt        this->drawRect(ds, color, viewM, rect, NULL, NULL);
138cf939ae54842fc7408ee68a41427086962b4c3dcbsalomon@google.com    }
1398dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    void drawSimpleRect(GrPipelineBuilder* ds, GrColor color, const SkMatrix& viewM,
1408059eb9f6e24ed609393fbda4ad71edea03ac258joshualitt                        const SkIRect& irect) {
1414469938e92d779dff05e745559e67907bbf21e78reed@google.com        SkRect rect = SkRect::Make(irect);
1428059eb9f6e24ed609393fbda4ad71edea03ac258joshualitt        this->drawRect(ds, color, viewM, rect, NULL, NULL);
143cf939ae54842fc7408ee68a41427086962b4c3dcbsalomon@google.com    }
14486afc2ae27fec84c01eb0e81a32766bdaf67dca8bsalomon@google.com
145934c570297c1b1f99cb4ca8d012d468a7eddf73fbsalomon@google.com
146934c570297c1b1f99cb4ca8d012d468a7eddf73fbsalomon@google.com    /**
1478dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel     * Clear the passed in render target. Ignores the GrPipelineBuilder and clip. Clears the whole
1488dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel     * thing if rect is NULL, otherwise just the rect. If canIgnoreRect is set then the entire
1498dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel     * render target can be optionally cleared.
1500b335c1ac100aeacf79a4c98a052286fd46661e7bsalomon@google.com     */
1519853ccef19c200be93a6211f32589fa82a53067cjoshualitt    void clear(const SkIRect* rect,
1529853ccef19c200be93a6211f32589fa82a53067cjoshualitt               GrColor color,
1539853ccef19c200be93a6211f32589fa82a53067cjoshualitt               bool canIgnoreRect,
15463b21962867af0f98e12a3ccbe5eef76b7ecc3aabsalomon               GrRenderTarget* renderTarget);
155a9493a3c78f6eb82635ece960b4f16918b885428skia.committer@gmail.com
156e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com    /**
15789c62980c1eb50b2090f33312086c7e8c66739b4bsalomon     * Discards the contents render target.
15828361fad1054d59ed4e6a320c7a8b8782a1487c7commit-bot@chromium.org     **/
15989c62980c1eb50b2090f33312086c7e8c66739b4bsalomon    virtual void discard(GrRenderTarget*) = 0;
16028361fad1054d59ed4e6a320c7a8b8782a1487c7commit-bot@chromium.org
16128361fad1054d59ed4e6a320c7a8b8782a1487c7commit-bot@chromium.org    /**
1622a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org     * Called at start and end of gpu trace marking
1632a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org     * GR_CREATE_GPU_TRACE_MARKER(marker_str, target) will automatically call these at the start
1642a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org     * and end of a code block respectively
165a3baf3be0e2a3128fb73bd41d40d130f75a4dc86commit-bot@chromium.org     */
1663eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel    void addGpuTraceMarker(const GrGpuTraceMarker* marker);
1673eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel    void removeGpuTraceMarker(const GrGpuTraceMarker* marker);
1683eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel
1693eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel    /**
1703eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel     * Takes the current active set of markers and stores them for later use. Any current marker
1713eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel     * in the active set is removed from the active set and the targets remove function is called.
1723eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel     * These functions do not work as a stack so you cannot call save a second time before calling
1733eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel     * restore. Also, it is assumed that when restore is called the current active set of markers
1743eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel     * is empty. When the stored markers are added back into the active set, the targets add marker
1753eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel     * is called.
1763eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel     */
1773eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel    void saveActiveTraceMarkers();
1783eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel    void restoreActiveTraceMarkers();
179a3baf3be0e2a3128fb73bd41d40d130f75a4dc86commit-bot@chromium.org
180a3baf3be0e2a3128fb73bd41d40d130f75a4dc86commit-bot@chromium.org    /**
181e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * Copies a pixel rectangle from one surface to another. This call may finalize
182e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * reserved vertex/index data (as though a draw call was made). The src pixels
183e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * copied are specified by srcRect. They are copied to a rect of the same
184e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * size in dst with top left at dstPoint. If the src rect is clipped by the
185e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * src bounds then  pixel values in the dst rect corresponding to area clipped
186e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * by the src rect are not overwritten. This method can fail and return false
187e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * depending on the type of surface, configs, etc, and the backend-specific
188e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * limitations. If rect is clipped out entirely by the src or dst bounds then
189e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     * true is returned since there is no actual copy necessary to succeed.
190e4617bf6d45cdde07f89e341ebf5c485916bf0b2bsalomon@google.com     */
191f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon    bool copySurface(GrSurface* dst,
192f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                     GrSurface* src,
193f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                     const SkIRect& srcRect,
194f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                     const SkIPoint& dstPoint);
195116ad84d3126b0db22b2312ca59ed70e5c56f6fcbsalomon@google.com    /**
196f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon     * Function that determines whether a copySurface call would succeed without actually
197116ad84d3126b0db22b2312ca59ed70e5c56f6fcbsalomon@google.com     * performing the copy.
198116ad84d3126b0db22b2312ca59ed70e5c56f6fcbsalomon@google.com     */
199f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon    bool canCopySurface(const GrSurface* dst,
200f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                        const GrSurface* src,
201f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                        const SkIRect& srcRect,
202f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                        const SkIPoint& dstPoint);
203eb85117c05471e1a55ce387cbc38279f857a4584bsalomon@google.com
204eb85117c05471e1a55ce387cbc38279f857a4584bsalomon@google.com    /**
205ff17584e1c15f68ccc296be517e8a6776a9ddabdrobertphillips@google.com     * Release any resources that are cached but not currently in use. This
206ff17584e1c15f68ccc296be517e8a6776a9ddabdrobertphillips@google.com     * is intended to give an application some recourse when resources are low.
207ff17584e1c15f68ccc296be517e8a6776a9ddabdrobertphillips@google.com     */
208ff17584e1c15f68ccc296be517e8a6776a9ddabdrobertphillips@google.com    virtual void purgeResources() {};
209ff17584e1c15f68ccc296be517e8a6776a9ddabdrobertphillips@google.com
210a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    ///////////////////////////////////////////////////////////////////////////
211a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    // Draw execution tracking (for font atlases and other resources)
212a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    class DrawToken {
213a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    public:
214a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org        DrawToken(GrDrawTarget* drawTarget, uint32_t drawID) :
215a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org                  fDrawTarget(drawTarget), fDrawID(drawID) {}
2167475811143e190e172bf83d13c4bdba85704b604skia.committer@gmail.com
21749f085dddff10473b6ebf832a974288300224e60bsalomon        bool isIssued() { return fDrawTarget && fDrawTarget->isIssued(fDrawID); }
2187475811143e190e172bf83d13c4bdba85704b604skia.committer@gmail.com
219a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    private:
220a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org        GrDrawTarget*  fDrawTarget;
221a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org        uint32_t       fDrawID;   // this may wrap, but we're doing direct comparison
222a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org                                  // so that should be okay
223a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    };
2247475811143e190e172bf83d13c4bdba85704b604skia.committer@gmail.com
225a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    virtual DrawToken getCurrentDrawToken() { return DrawToken(this, 0); }
2267475811143e190e172bf83d13c4bdba85704b604skia.committer@gmail.com
2273322fa432a96fdc94d54f2475faf918dfa05b919joshualitt    /**
2283322fa432a96fdc94d54f2475faf918dfa05b919joshualitt     * Used to communicate draws to GPUs / subclasses
2293322fa432a96fdc94d54f2475faf918dfa05b919joshualitt     */
2303322fa432a96fdc94d54f2475faf918dfa05b919joshualitt    class DrawInfo {
2313322fa432a96fdc94d54f2475faf918dfa05b919joshualitt    public:
2324d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        DrawInfo() { fDevBounds = NULL; }
2333322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        DrawInfo(const DrawInfo& di) { (*this) = di; }
2343322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        DrawInfo& operator =(const DrawInfo& di);
2353322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
2363322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        GrPrimitiveType primitiveType() const { return fPrimitiveType; }
2373322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int startVertex() const { return fStartVertex; }
2383322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int startIndex() const { return fStartIndex; }
2393322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int vertexCount() const { return fVertexCount; }
2403322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int indexCount() const { return fIndexCount; }
2413322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int verticesPerInstance() const { return fVerticesPerInstance; }
2423322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int indicesPerInstance() const { return fIndicesPerInstance; }
2433322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int instanceCount() const { return fInstanceCount; }
2443322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
2454d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setPrimitiveType(GrPrimitiveType type) { fPrimitiveType = type; }
2464d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setStartVertex(int startVertex) { fStartVertex = startVertex; }
2474d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setStartIndex(int startIndex) { fStartIndex = startIndex; }
2484d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setVertexCount(int vertexCount) { fVertexCount = vertexCount; }
2494d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setIndexCount(int indexCount) { fIndexCount = indexCount; }
2504d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setVerticesPerInstance(int verticesPerI) { fVerticesPerInstance = verticesPerI; }
2514d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setIndicesPerInstance(int indicesPerI) { fIndicesPerInstance = indicesPerI; }
2524d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt        void setInstanceCount(int instanceCount) { fInstanceCount = instanceCount; }
2534d8da81562852e0ff7e18b66ee1cebd50ad81ee8joshualitt
2543322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        bool isIndexed() const { return fIndexCount > 0; }
2553322fa432a96fdc94d54f2475faf918dfa05b919joshualitt#ifdef SK_DEBUG
2563322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        bool isInstanced() const; // this version is longer because of asserts
2573322fa432a96fdc94d54f2475faf918dfa05b919joshualitt#else
2583322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        bool isInstanced() const { return fInstanceCount > 0; }
2593322fa432a96fdc94d54f2475faf918dfa05b919joshualitt#endif
2603322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
2613322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        // adds or remove instances
2623322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        void adjustInstanceCount(int instanceOffset);
2633322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        // shifts the start vertex
26472e3ae486c66871c2043eac4f08d85d419fbca2absalomon        void adjustStartVertex(int vertexOffset) {
26572e3ae486c66871c2043eac4f08d85d419fbca2absalomon            fStartVertex += vertexOffset;
26672e3ae486c66871c2043eac4f08d85d419fbca2absalomon            SkASSERT(fStartVertex >= 0);
26772e3ae486c66871c2043eac4f08d85d419fbca2absalomon        }
2683322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        // shifts the start index
26972e3ae486c66871c2043eac4f08d85d419fbca2absalomon        void adjustStartIndex(int indexOffset) {
27072e3ae486c66871c2043eac4f08d85d419fbca2absalomon            SkASSERT(this->isIndexed());
27172e3ae486c66871c2043eac4f08d85d419fbca2absalomon            fStartIndex += indexOffset;
27272e3ae486c66871c2043eac4f08d85d419fbca2absalomon            SkASSERT(fStartIndex >= 0);
27372e3ae486c66871c2043eac4f08d85d419fbca2absalomon        }
2743322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        void setDevBounds(const SkRect& bounds) {
2753322fa432a96fdc94d54f2475faf918dfa05b919joshualitt            fDevBoundsStorage = bounds;
2763322fa432a96fdc94d54f2475faf918dfa05b919joshualitt            fDevBounds = &fDevBoundsStorage;
2773322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        }
2787eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        const GrVertexBuffer* vertexBuffer() const { return fVertexBuffer.get(); }
2797eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        const GrIndexBuffer* indexBuffer() const { return fIndexBuffer.get(); }
2807eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        void setVertexBuffer(const GrVertexBuffer* vb) {
2817eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt            fVertexBuffer.reset(vb);
2827eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        }
2837eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        void setIndexBuffer(const GrIndexBuffer* ib) {
2847eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt            fIndexBuffer.reset(ib);
2857eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        }
2863322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        const SkRect* getDevBounds() const { return fDevBounds; }
2873322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
2883322fa432a96fdc94d54f2475faf918dfa05b919joshualitt    private:
2893322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        friend class GrDrawTarget;
2903322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
2913322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        GrPrimitiveType         fPrimitiveType;
2923322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
2933322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int                     fStartVertex;
2943322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int                     fStartIndex;
2953322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int                     fVertexCount;
2963322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int                     fIndexCount;
2973322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
2983322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int                     fInstanceCount;
2993322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int                     fVerticesPerInstance;
3003322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        int                     fIndicesPerInstance;
3013322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
3023322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        SkRect                  fDevBoundsStorage;
3033322fa432a96fdc94d54f2475faf918dfa05b919joshualitt        SkRect*                 fDevBounds;
3043322fa432a96fdc94d54f2475faf918dfa05b919joshualitt
3057eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        GrPendingIOResource<const GrVertexBuffer, kRead_GrIOType> fVertexBuffer;
3067eb8c7b00a5d776bebaf33a8687357df95c1aa43joshualitt        GrPendingIOResource<const GrIndexBuffer, kRead_GrIOType>  fIndexBuffer;
3073322fa432a96fdc94d54f2475faf918dfa05b919joshualitt    };
3082c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt
3092c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt    bool programUnitTest(int maxStages);
3102c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt
311ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.comprotected:
312dad7794dcbf205a6d0f3c5c44e251897f5256f09robertphillips    friend class GrTargetCommands; // for PipelineInfo
313dad7794dcbf205a6d0f3c5c44e251897f5256f09robertphillips
3146e4e65066a7c0dbc9bfbfe4b8f5d49c3d8a79b59bsalomon@google.com    GrContext* getContext() { return fContext; }
3156e4e65066a7c0dbc9bfbfe4b8f5d49c3d8a79b59bsalomon@google.com    const GrContext* getContext() const { return fContext; }
3166e4e65066a7c0dbc9bfbfe4b8f5d49c3d8a79b59bsalomon@google.com
317a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    GrGpu* getGpu() {
318a73239a0096370221d3dfababf339dd6d3fed84fbsalomon        SkASSERT(fContext && fContext->getGpu());
319a73239a0096370221d3dfababf339dd6d3fed84fbsalomon        return fContext->getGpu();
320a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    }
321a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    const GrGpu* getGpu() const {
322a73239a0096370221d3dfababf339dd6d3fed84fbsalomon        SkASSERT(fContext && fContext->getGpu());
323a73239a0096370221d3dfababf339dd6d3fed84fbsalomon        return fContext->getGpu();
324a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    }
325a73239a0096370221d3dfababf339dd6d3fed84fbsalomon
326a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    GrVertexBufferAllocPool* getVertexAllocPool() { return fVertexPool; }
327a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    GrIndexBufferAllocPool* getIndexAllocPool() { return fIndexPool; }
32802ddc8b85ace91b15feb329a6a1d5d62b2b846c6bsalomon@google.com
3292a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org    const GrTraceMarkerSet& getActiveTraceMarkers() { return fActiveTraceMarkers; }
3302a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org
331651713408c5a5d9565665967ad09981250c7a8c9joshualitt    // Makes a copy of the dst if it is necessary for the draw. Returns false if a copy is required
332651713408c5a5d9565665967ad09981250c7a8c9joshualitt    // but couldn't be made. Otherwise, returns true.  This method needs to be protected because it
333651713408c5a5d9565665967ad09981250c7a8c9joshualitt    // needs to be accessed by GLPrograms to setup a correct drawstate
33450785a3d10b53bea5beb6e18431a2449860be237bsalomon    bool setupDstReadIfNecessary(const GrPipelineBuilder&,
335e36914cb205699526988127a827d1a76c9a98d39egdaniel                                 const GrProcOptInfo& colorPOI,
336e36914cb205699526988127a827d1a76c9a98d39egdaniel                                 const GrProcOptInfo& coveragePOI,
3379853ccef19c200be93a6211f32589fa82a53067cjoshualitt                                 GrDeviceCoordTexture* dstCopy,
3389853ccef19c200be93a6211f32589fa82a53067cjoshualitt                                 const SkRect* drawBounds);
339651713408c5a5d9565665967ad09981250c7a8c9joshualitt
340e36914cb205699526988127a827d1a76c9a98d39egdaniel    struct PipelineInfo {
341e36914cb205699526988127a827d1a76c9a98d39egdaniel        PipelineInfo(GrPipelineBuilder* pipelineBuilder, GrScissorState* scissor,
34244701df5ce572ac3cccec785cf52103d3d5d14a5joshualitt                     const GrPrimitiveProcessor* primProc,
34344701df5ce572ac3cccec785cf52103d3d5d14a5joshualitt                     const SkRect* devBounds, GrDrawTarget* target);
344e36914cb205699526988127a827d1a76c9a98d39egdaniel
345e36914cb205699526988127a827d1a76c9a98d39egdaniel        PipelineInfo(GrPipelineBuilder* pipelineBuilder, GrScissorState* scissor,
34644701df5ce572ac3cccec785cf52103d3d5d14a5joshualitt                     const GrBatch* batch, const SkRect* devBounds,
34744701df5ce572ac3cccec785cf52103d3d5d14a5joshualitt                     GrDrawTarget* target);
348e36914cb205699526988127a827d1a76c9a98d39egdaniel
349e36914cb205699526988127a827d1a76c9a98d39egdaniel        bool willBlendWithDst(const GrPrimitiveProcessor* primProc) const {
350e36914cb205699526988127a827d1a76c9a98d39egdaniel            return fPipelineBuilder->willBlendWithDst(primProc);
351e36914cb205699526988127a827d1a76c9a98d39egdaniel        }
352e36914cb205699526988127a827d1a76c9a98d39egdaniel    private:
353e36914cb205699526988127a827d1a76c9a98d39egdaniel        friend class GrDrawTarget;
354e36914cb205699526988127a827d1a76c9a98d39egdaniel
355e36914cb205699526988127a827d1a76c9a98d39egdaniel        bool mustSkipDraw() const { return (NULL == fPipelineBuilder); }
356e36914cb205699526988127a827d1a76c9a98d39egdaniel
357e36914cb205699526988127a827d1a76c9a98d39egdaniel        GrPipelineBuilder*      fPipelineBuilder;
358e36914cb205699526988127a827d1a76c9a98d39egdaniel        GrScissorState*         fScissor;
359e36914cb205699526988127a827d1a76c9a98d39egdaniel        GrProcOptInfo           fColorPOI;
360e36914cb205699526988127a827d1a76c9a98d39egdaniel        GrProcOptInfo           fCoveragePOI;
361e36914cb205699526988127a827d1a76c9a98d39egdaniel        GrDeviceCoordTexture    fDstCopy;
362e36914cb205699526988127a827d1a76c9a98d39egdaniel    };
363e36914cb205699526988127a827d1a76c9a98d39egdaniel
364e36914cb205699526988127a827d1a76c9a98d39egdaniel    void setupPipeline(const PipelineInfo& pipelineInfo, GrPipeline* pipeline);
365e36914cb205699526988127a827d1a76c9a98d39egdaniel
36602ddc8b85ace91b15feb329a6a1d5d62b2b846c6bsalomon@google.comprivate:
367a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    virtual void onReset() = 0;
368f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon
369a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    virtual void onFlush() = 0;
370f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon
371e36914cb205699526988127a827d1a76c9a98d39egdaniel    virtual void onDrawBatch(GrBatch*, const PipelineInfo&) = 0;
3725478d427c6e67c986a3390162c8fec77c466058ajoshualitt    // TODO copy in order drawbuffer onDrawRect to here
3738dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    virtual void onDrawRect(GrPipelineBuilder*,
3742e3b3e369d79e78f7635d4c20e83a47ab571bdf2joshualitt                            GrColor color,
3758059eb9f6e24ed609393fbda4ad71edea03ac258joshualitt                            const SkMatrix& viewMatrix,
3769853ccef19c200be93a6211f32589fa82a53067cjoshualitt                            const SkRect& rect,
377fd03d4a829efe2d77a712fd991927c55f59a2ffecommit-bot@chromium.org                            const SkRect* localRect,
3785478d427c6e67c986a3390162c8fec77c466058ajoshualitt                            const SkMatrix* localMatrix) = 0;
37932184d81629e39809bb9e915286d8fe971a8ed68commit-bot@chromium.org
3808dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    virtual void onStencilPath(const GrPipelineBuilder&,
38156995b5cc00c9c83bd5fcf86bca9a67e939a96cbjoshualitt                               const GrPathProcessor*,
3829853ccef19c200be93a6211f32589fa82a53067cjoshualitt                               const GrPath*,
3833e79124a69d4806f0a1a776090bff718e1b90970bsalomon                               const GrScissorState&,
3842c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt                               const GrStencilSettings&) = 0;
385e36914cb205699526988127a827d1a76c9a98d39egdaniel    virtual void onDrawPath(const GrPathProcessor*,
3869853ccef19c200be93a6211f32589fa82a53067cjoshualitt                            const GrPath*,
3872c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt                            const GrStencilSettings&,
388e36914cb205699526988127a827d1a76c9a98d39egdaniel                            const PipelineInfo&) = 0;
389e36914cb205699526988127a827d1a76c9a98d39egdaniel    virtual void onDrawPaths(const GrPathProcessor*,
3909853ccef19c200be93a6211f32589fa82a53067cjoshualitt                             const GrPathRange*,
39155b24afc178e641e17a5664beba7ab2b4982c91acdalton                             const void* indices,
39255b24afc178e641e17a5664beba7ab2b4982c91acdalton                             PathIndexType,
39355b24afc178e641e17a5664beba7ab2b4982c91acdalton                             const float transformValues[],
3942c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt                             PathTransformType,
39555b24afc178e641e17a5664beba7ab2b4982c91acdalton                             int count,
3962c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt                             const GrStencilSettings&,
397e36914cb205699526988127a827d1a76c9a98d39egdaniel                             const PipelineInfo&) = 0;
39864aef2bacd1f5c25ffd9347aabd6265c9b60c0f4bsalomon@google.com
39963b21962867af0f98e12a3ccbe5eef76b7ecc3aabsalomon    virtual void onClear(const SkIRect* rect, GrColor color, bool canIgnoreRect,
40063b21962867af0f98e12a3ccbe5eef76b7ecc3aabsalomon                         GrRenderTarget* renderTarget) = 0;
40163b21962867af0f98e12a3ccbe5eef76b7ecc3aabsalomon
402a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    /** The subclass's copy surface implementation. It should assume that any clipping has already
403a73239a0096370221d3dfababf339dd6d3fed84fbsalomon        been performed on the rect and point and that the GrGpu supports the copy. */
404a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    virtual void onCopySurface(GrSurface* dst,
405f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                               GrSurface* src,
406f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                               const SkIRect& srcRect,
407f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon                               const SkIPoint& dstPoint) = 0;
408f90a02b42ac7a1ed59460760c6ce03f6f975f22bbsalomon
409a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    // Check to see if this set of draw commands has been sent out
410a8916ffd90c04dc6cc1fb9ba94af2ff950284fadcommit-bot@chromium.org    virtual bool       isIssued(uint32_t drawID) { return true; }
4119853ccef19c200be93a6211f32589fa82a53067cjoshualitt    void getPathStencilSettingsForFilltype(GrPathRendering::FillType,
4128dc7c3a839b38b73af34cc2674a06f49eb1ce527egdaniel                                           const GrStencilAttachment*,
4139853ccef19c200be93a6211f32589fa82a53067cjoshualitt                                           GrStencilSettings*);
414a702415d9e80f5631181143c293498de924e8ae4joshualitt    virtual GrClipMaskManager* clipMaskManager() = 0;
4158dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    virtual bool setupClip(GrPipelineBuilder*,
4166be6f7cb66b277e7b1ce13d09b635fb8e09a2f68bsalomon                           GrPipelineBuilder::AutoRestoreFragmentProcessors*,
4176be6f7cb66b277e7b1ce13d09b635fb8e09a2f68bsalomon                           GrPipelineBuilder::AutoRestoreStencil*,
4186be6f7cb66b277e7b1ce13d09b635fb8e09a2f68bsalomon                           GrScissorState*,
4198059eb9f6e24ed609393fbda4ad71edea03ac258joshualitt                           const SkRect* devBounds) = 0;
4207475811143e190e172bf83d13c4bdba85704b604skia.committer@gmail.com
4216e4e65066a7c0dbc9bfbfe4b8f5d49c3d8a79b59bsalomon@google.com    // The context owns us, not vice-versa, so this ptr is not ref'ed by DrawTarget.
4226e4e65066a7c0dbc9bfbfe4b8f5d49c3d8a79b59bsalomon@google.com    GrContext*                                                      fContext;
423a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    SkAutoTUnref<const GrDrawTargetCaps>                            fCaps;
4242a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org    // To keep track that we always have at least as many debug marker adds as removes
4252a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org    int                                                             fGpuTraceMarkerCount;
4262a05de0c049a8648942a55016126a1f92e1c14d6commit-bot@chromium.org    GrTraceMarkerSet                                                fActiveTraceMarkers;
4273eee3834fba1d2e29dfb61adcb97e4624b6a3ac8egdaniel    GrTraceMarkerSet                                                fStoredTraceMarkers;
428a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    GrVertexBufferAllocPool*                                        fVertexPool;
429a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    GrIndexBufferAllocPool*                                         fIndexPool;
430a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    bool                                                            fFlushing;
431fa35e3ddcc9d130ce87c927218bdf27879c38711reed@google.com
432a4de8c257ea0be8ff7081f645249b6afe5c48e7ecommit-bot@chromium.org    typedef SkRefCnt INHERITED;
433ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com};
434ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com
435329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt/*
436329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt * This class is JUST for clip mask manager.  Everyone else should just use draw target above.
437329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt */
4386db519c42471aaaa8a8e1a3ece314014481ab832joshualittclass GrClipTarget : public GrDrawTarget {
4396db519c42471aaaa8a8e1a3ece314014481ab832joshualittpublic:
440a73239a0096370221d3dfababf339dd6d3fed84fbsalomon    GrClipTarget(GrContext* context,
441a73239a0096370221d3dfababf339dd6d3fed84fbsalomon                 GrVertexBufferAllocPool* vpool,
442a73239a0096370221d3dfababf339dd6d3fed84fbsalomon                 GrIndexBufferAllocPool* ipool)
443a73239a0096370221d3dfababf339dd6d3fed84fbsalomon        : INHERITED(context, vpool, ipool) {
444329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt        fClipMaskManager.setClipTarget(this);
445329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt    }
446329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt
447329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt    /* Clip mask manager needs access to the context.
448329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt     * TODO we only need a very small subset of context in the CMM.
449329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt     */
450329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt    GrContext* getContext() { return INHERITED::getContext(); }
451329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt    const GrContext* getContext() const { return INHERITED::getContext(); }
452329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt
4536db519c42471aaaa8a8e1a3ece314014481ab832joshualitt    /**
4546db519c42471aaaa8a8e1a3ece314014481ab832joshualitt     * Clip Mask Manager(and no one else) needs to clear private stencil bits.
4556db519c42471aaaa8a8e1a3ece314014481ab832joshualitt     * ClipTarget subclass sets clip bit in the stencil buffer. The subclass
4566db519c42471aaaa8a8e1a3ece314014481ab832joshualitt     * is free to clear the remaining bits to zero if masked clears are more
4576db519c42471aaaa8a8e1a3ece314014481ab832joshualitt     * expensive than clearing all bits.
4586db519c42471aaaa8a8e1a3ece314014481ab832joshualitt     */
4596db519c42471aaaa8a8e1a3ece314014481ab832joshualitt    virtual void clearStencilClip(const SkIRect& rect, bool insideClip, GrRenderTarget* = NULL) = 0;
4606db519c42471aaaa8a8e1a3ece314014481ab832joshualitt
4613bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt    /**
4623bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt     * Release any resources that are cached but not currently in use. This
4633bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt     * is intended to give an application some recourse when resources are low.
4643bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt     */
46536352bf5e38f45a70ee4f4fc132a38048d38206dmtklein    void purgeResources() override {
4663bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt        // The clip mask manager can rebuild all its clip masks so just
4673bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt        // get rid of them all.
4683bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt        fClipMaskManager.purgeResources();
4693bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt    };
4703bdd7dce5e8393aeed0a64b583e1077f5159d516joshualitt
471329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualittprotected:
472329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt    GrClipMaskManager           fClipMaskManager;
473329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt
4746db519c42471aaaa8a8e1a3ece314014481ab832joshualittprivate:
47536352bf5e38f45a70ee4f4fc132a38048d38206dmtklein    GrClipMaskManager* clipMaskManager() override { return &fClipMaskManager; }
476329bf4862e9d5e05363c2b071d8ca475a0ef1952joshualitt
4778dd688b7569df569a672a8a67b2db86a9d376cfcegdaniel    virtual bool setupClip(GrPipelineBuilder*,
4786be6f7cb66b277e7b1ce13d09b635fb8e09a2f68bsalomon                           GrPipelineBuilder::AutoRestoreFragmentProcessors*,
4796be6f7cb66b277e7b1ce13d09b635fb8e09a2f68bsalomon                           GrPipelineBuilder::AutoRestoreStencil*,
4808059eb9f6e24ed609393fbda4ad71edea03ac258joshualitt                           GrScissorState* scissorState,
48136352bf5e38f45a70ee4f4fc132a38048d38206dmtklein                           const SkRect* devBounds) override;
4822c93efeb6f2dd652eb2575c04124d82952f020c7joshualitt
4836db519c42471aaaa8a8e1a3ece314014481ab832joshualitt    typedef GrDrawTarget INHERITED;
4846db519c42471aaaa8a8e1a3ece314014481ab832joshualitt};
4856db519c42471aaaa8a8e1a3ece314014481ab832joshualitt
486ac10a2d039c5d52eed66e27cbbc503ab523c1cd5reed@google.com#endif
487