ea26d6b816
This reverts commitb4e965c103
. Reason for revert: Thin stroke problems, chrome pixel test, g3 clang-tidy Original change's description: > Revert "Revert "Use GrOvalOpFactory ops to draw non-AA rrects, ovals, and arcs."" > > This reverts commitbefff6580e
. > > Bug: skia: > Change-Id: Ia108408cd986c03783af5058845790f6b17201f4 > Reviewed-on: https://skia-review.googlesource.com/98703 > Reviewed-by: Brian Salomon <bsalomon@google.com> > Commit-Queue: Brian Salomon <bsalomon@google.com> TBR=bsalomon@google.com Change-Id: I785af7efdfc39680052f5721a55ecffbeaf1f0ad No-Presubmit: true No-Tree-Checks: true No-Try: true Bug: skia: Reviewed-on: https://skia-review.googlesource.com/98785 Reviewed-by: Brian Salomon <bsalomon@google.com> Commit-Queue: Brian Salomon <bsalomon@google.com>
467 lines
19 KiB
C++
467 lines
19 KiB
C++
/*
|
|
* Copyright 2015 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#ifndef GrRenderTargetContext_DEFINED
|
|
#define GrRenderTargetContext_DEFINED
|
|
|
|
#include "../private/GrRenderTargetProxy.h"
|
|
#include "GrColor.h"
|
|
#include "GrContext.h"
|
|
#include "GrContextPriv.h"
|
|
#include "GrPaint.h"
|
|
#include "GrSurfaceContext.h"
|
|
#include "GrTypesPriv.h"
|
|
#include "GrXferProcessor.h"
|
|
#include "SkRefCnt.h"
|
|
#include "SkSurfaceProps.h"
|
|
#include "text/GrTextUtils.h"
|
|
|
|
class GrBackendSemaphore;
|
|
class GrCCPRAtlas;
|
|
class GrClip;
|
|
class GrColorSpaceXform;
|
|
class GrCoverageCountingPathRenderer;
|
|
class GrDrawingManager;
|
|
class GrDrawOp;
|
|
class GrFixedClip;
|
|
class GrRenderTarget;
|
|
class GrRenderTargetContextPriv;
|
|
class GrRenderTargetOpList;
|
|
class GrShape;
|
|
class GrStyle;
|
|
class GrTextureProxy;
|
|
struct GrUserStencilSettings;
|
|
class SkDrawFilter;
|
|
struct SkDrawShadowRec;
|
|
struct SkIPoint;
|
|
struct SkIRect;
|
|
class SkLatticeIter;
|
|
class SkMatrix;
|
|
class SkPaint;
|
|
class SkPath;
|
|
struct SkPoint;
|
|
struct SkRect;
|
|
class SkRegion;
|
|
class SkRRect;
|
|
struct SkRSXform;
|
|
class SkTextBlob;
|
|
class SkVertices;
|
|
|
|
/**
|
|
* A helper object to orchestrate commands (draws, etc...) for GrSurfaces that are GrRenderTargets.
|
|
*/
|
|
class SK_API GrRenderTargetContext : public GrSurfaceContext {
|
|
public:
|
|
~GrRenderTargetContext() override;
|
|
|
|
// We use SkPaint rather than GrPaint here for two reasons:
|
|
// * The SkPaint carries extra text settings. If these were extracted to a lighter object
|
|
// we could use GrPaint except that
|
|
// * SkPaint->GrPaint conversion depends upon whether the glyphs are color or grayscale and
|
|
// this can vary within a text run.
|
|
virtual void drawText(const GrClip&, const SkPaint&, const SkMatrix& viewMatrix,
|
|
const char text[], size_t byteLength, SkScalar x, SkScalar y,
|
|
const SkIRect& clipBounds);
|
|
virtual void drawPosText(const GrClip&, const SkPaint&, const SkMatrix& viewMatrix,
|
|
const char text[], size_t byteLength, const SkScalar pos[],
|
|
int scalarsPerPosition, const SkPoint& offset,
|
|
const SkIRect& clipBounds);
|
|
virtual void drawTextBlob(const GrClip&, const SkPaint&,
|
|
const SkMatrix& viewMatrix, const SkTextBlob*,
|
|
SkScalar x, SkScalar y,
|
|
SkDrawFilter*, const SkIRect& clipBounds);
|
|
|
|
/**
|
|
* Provides a perfomance hint that the render target's contents are allowed
|
|
* to become undefined.
|
|
*/
|
|
void discard();
|
|
|
|
enum class CanClearFullscreen : bool {
|
|
kNo = false,
|
|
kYes = true
|
|
};
|
|
|
|
/**
|
|
* Clear the entire or rect of the render target, ignoring any clips.
|
|
* @param rect the rect to clear or the whole thing if rect is NULL.
|
|
* @param color the color to clear to.
|
|
* @param CanClearFullscreen allows partial clears to be converted to fullscreen clears on
|
|
* tiling platforms where that is an optimization.
|
|
*/
|
|
void clear(const SkIRect* rect, GrColor color, CanClearFullscreen);
|
|
|
|
/**
|
|
* Draw everywhere (respecting the clip) with the paint.
|
|
*/
|
|
void drawPaint(const GrClip&, GrPaint&&, const SkMatrix& viewMatrix);
|
|
|
|
/**
|
|
* Draw the rect using a paint.
|
|
* @param paint describes how to color pixels.
|
|
* @param GrAA Controls whether rect is antialiased
|
|
* @param viewMatrix transformation matrix
|
|
* @param style The style to apply. Null means fill. Currently path effects are not
|
|
* allowed.
|
|
* The rects coords are used to access the paint (through texture matrix)
|
|
*/
|
|
void drawRect(const GrClip&,
|
|
GrPaint&& paint,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRect&,
|
|
const GrStyle* style = nullptr);
|
|
|
|
/**
|
|
* Maps a rectangle of shader coordinates to a rectangle and fills that rectangle.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param GrAA Controls whether rect is antialiased
|
|
* @param viewMatrix transformation matrix which applies to rectToDraw
|
|
* @param rectToDraw the rectangle to draw
|
|
* @param localRect the rectangle of shader coordinates applied to rectToDraw
|
|
*/
|
|
void fillRectToRect(const GrClip&,
|
|
GrPaint&& paint,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRect& rectToDraw,
|
|
const SkRect& localRect);
|
|
|
|
/**
|
|
* Fills a rect with a paint and a localMatrix.
|
|
*/
|
|
void fillRectWithLocalMatrix(const GrClip& clip,
|
|
GrPaint&& paint,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRect& rect,
|
|
const SkMatrix& localMatrix);
|
|
|
|
/**
|
|
* Creates an op that draws a subrectangle of a texture. The passed color is modulated by the
|
|
* texture's color. 'srcRect' specifies the rectangle of the texture to draw. 'dstRect'
|
|
* specifies the rectangle to draw in local coords which will be transformed by 'viewMatrix' to
|
|
* device space. This asserts that the view matrix does not have perspective.
|
|
*/
|
|
void drawTextureAffine(const GrClip& clip, sk_sp<GrTextureProxy>, GrSamplerState::Filter,
|
|
GrColor, const SkRect& srcRect, const SkRect& dstRect, GrAA aa,
|
|
const SkMatrix& viewMatrix, sk_sp<GrColorSpaceXform>);
|
|
|
|
/**
|
|
* Draw a roundrect using a paint.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param GrAA Controls whether rrect is antialiased.
|
|
* @param viewMatrix transformation matrix
|
|
* @param rrect the roundrect to draw
|
|
* @param style style to apply to the rrect. Currently path effects are not allowed.
|
|
*/
|
|
void drawRRect(const GrClip&,
|
|
GrPaint&&,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRRect& rrect,
|
|
const GrStyle& style);
|
|
|
|
/**
|
|
* Use a fast method to render the ambient and spot shadows for a path.
|
|
* Will return false if not possible for the given path.
|
|
*
|
|
* @param viewMatrix transformation matrix
|
|
* @param path the path to shadow
|
|
* @param rec parameters for shadow rendering
|
|
*/
|
|
bool drawFastShadow(const GrClip&,
|
|
const SkMatrix& viewMatrix,
|
|
const SkPath& path,
|
|
const SkDrawShadowRec& rec);
|
|
|
|
/**
|
|
* Shortcut for filling a SkPath consisting of nested rrects using a paint. The result is
|
|
* undefined if outer does not contain inner.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param GrAA Controls whether rrects edges are antialiased
|
|
* @param viewMatrix transformation matrix
|
|
* @param outer the outer roundrect
|
|
* @param inner the inner roundrect
|
|
*/
|
|
void drawDRRect(const GrClip&,
|
|
GrPaint&&,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRRect& outer,
|
|
const SkRRect& inner);
|
|
|
|
/**
|
|
* Draws a path.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param GrAA Controls whether the path is antialiased.
|
|
* @param viewMatrix transformation matrix
|
|
* @param path the path to draw
|
|
* @param style style to apply to the path.
|
|
*/
|
|
void drawPath(const GrClip&,
|
|
GrPaint&&,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkPath&,
|
|
const GrStyle& style);
|
|
|
|
/**
|
|
* Draws vertices with a paint.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param viewMatrix transformation matrix
|
|
* @param vertices specifies the mesh to draw.
|
|
* @param overridePrimType primitive type to draw. If NULL, derive prim type from vertices.
|
|
*/
|
|
void drawVertices(const GrClip&,
|
|
GrPaint&& paint,
|
|
const SkMatrix& viewMatrix,
|
|
sk_sp<SkVertices> vertices,
|
|
GrPrimitiveType* overridePrimType = nullptr);
|
|
|
|
/**
|
|
* Draws textured sprites from an atlas with a paint. This currently does not support AA for the
|
|
* sprite rectangle edges.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param viewMatrix transformation matrix
|
|
* @param spriteCount number of sprites.
|
|
* @param xform array of compressed transformation data, required.
|
|
* @param texRect array of texture rectangles used to access the paint.
|
|
* @param colors optional array of per-sprite colors, supercedes
|
|
* the paint's color field.
|
|
*/
|
|
void drawAtlas(const GrClip&,
|
|
GrPaint&& paint,
|
|
const SkMatrix& viewMatrix,
|
|
int spriteCount,
|
|
const SkRSXform xform[],
|
|
const SkRect texRect[],
|
|
const SkColor colors[]);
|
|
|
|
/**
|
|
* Draws a region.
|
|
*
|
|
* @param paint describes how to color pixels
|
|
* @param viewMatrix transformation matrix
|
|
* @param aa should the rects of the region be antialiased.
|
|
* @param region the region to be drawn
|
|
* @param style style to apply to the region
|
|
*/
|
|
void drawRegion(const GrClip&,
|
|
GrPaint&& paint,
|
|
GrAA aa,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRegion& region,
|
|
const GrStyle& style,
|
|
const GrUserStencilSettings* ss = nullptr);
|
|
|
|
/**
|
|
* Draws an oval.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param GrAA Controls whether the oval is antialiased.
|
|
* @param viewMatrix transformation matrix
|
|
* @param oval the bounding rect of the oval.
|
|
* @param style style to apply to the oval. Currently path effects are not allowed.
|
|
*/
|
|
void drawOval(const GrClip&,
|
|
GrPaint&& paint,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRect& oval,
|
|
const GrStyle& style);
|
|
/**
|
|
* Draws a partial arc of an oval.
|
|
*
|
|
* @param paint describes how to color pixels.
|
|
* @param GrGrAA Controls whether the arc is antialiased.
|
|
* @param viewMatrix transformation matrix.
|
|
* @param oval the bounding rect of the oval.
|
|
* @param startAngle starting angle in degrees.
|
|
* @param sweepAngle angle to sweep in degrees. Must be in (-360, 360)
|
|
* @param useCenter true means that the implied path begins at the oval center, connects as
|
|
* a line to the point indicated by the start contains the arc indicated by
|
|
* the sweep angle. If false the line beginning at the center point is
|
|
* omitted.
|
|
* @param style style to apply to the oval.
|
|
*/
|
|
void drawArc(const GrClip&,
|
|
GrPaint&& paint,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRect& oval,
|
|
SkScalar startAngle,
|
|
SkScalar sweepAngle,
|
|
bool useCenter,
|
|
const GrStyle& style);
|
|
|
|
/**
|
|
* Draw the image as a set of rects, specified by |iter|.
|
|
*/
|
|
void drawImageLattice(const GrClip&,
|
|
GrPaint&& paint,
|
|
const SkMatrix& viewMatrix,
|
|
int imageWidth,
|
|
int imageHeight,
|
|
std::unique_ptr<SkLatticeIter> iter,
|
|
const SkRect& dst);
|
|
|
|
/**
|
|
* After this returns any pending surface IO will be issued to the backend 3D API and
|
|
* if the surface has MSAA it will be resolved.
|
|
*/
|
|
GrSemaphoresSubmitted prepareForExternalIO(int numSemaphores,
|
|
GrBackendSemaphore backendSemaphores[]);
|
|
|
|
/**
|
|
* The next time this GrRenderTargetContext is flushed, the gpu will wait on the passed in
|
|
* semaphores before executing any commands.
|
|
*/
|
|
bool waitOnSemaphores(int numSemaphores, const GrBackendSemaphore* waitSemaphores);
|
|
|
|
void insertEventMarker(const SkString&);
|
|
|
|
GrFSAAType fsaaType() const { return fRenderTargetProxy->fsaaType(); }
|
|
const GrCaps* caps() const { return fContext->caps(); }
|
|
int width() const { return fRenderTargetProxy->width(); }
|
|
int height() const { return fRenderTargetProxy->height(); }
|
|
int numColorSamples() const { return fRenderTargetProxy->numColorSamples(); }
|
|
int numStencilSamples() const { return fRenderTargetProxy->numStencilSamples(); }
|
|
const SkSurfaceProps& surfaceProps() const { return fSurfaceProps; }
|
|
GrSurfaceOrigin origin() const { return fRenderTargetProxy->origin(); }
|
|
GrMipMapped mipMapped() const;
|
|
|
|
bool wasAbandoned() const;
|
|
|
|
void setNeedsStencil() { fRenderTargetProxy->setNeedsStencil(); }
|
|
|
|
GrRenderTarget* accessRenderTarget() {
|
|
// TODO: usage of this entry point needs to be reduced and potentially eliminated
|
|
// since it ends the deferral of the GrRenderTarget's allocation
|
|
if (!fRenderTargetProxy->instantiate(fContext->contextPriv().resourceProvider())) {
|
|
return nullptr;
|
|
}
|
|
return fRenderTargetProxy->priv().peekRenderTarget();
|
|
}
|
|
|
|
GrSurfaceProxy* asSurfaceProxy() override { return fRenderTargetProxy.get(); }
|
|
const GrSurfaceProxy* asSurfaceProxy() const override { return fRenderTargetProxy.get(); }
|
|
sk_sp<GrSurfaceProxy> asSurfaceProxyRef() override { return fRenderTargetProxy; }
|
|
|
|
GrTextureProxy* asTextureProxy() override;
|
|
const GrTextureProxy* asTextureProxy() const override;
|
|
sk_sp<GrTextureProxy> asTextureProxyRef() override;
|
|
|
|
GrRenderTargetProxy* asRenderTargetProxy() override { return fRenderTargetProxy.get(); }
|
|
sk_sp<GrRenderTargetProxy> asRenderTargetProxyRef() override { return fRenderTargetProxy; }
|
|
|
|
GrRenderTargetContext* asRenderTargetContext() override { return this; }
|
|
|
|
// Provides access to functions that aren't part of the public API.
|
|
GrRenderTargetContextPriv priv();
|
|
const GrRenderTargetContextPriv priv() const;
|
|
|
|
GrTextUtils::Target* textTarget() { return fTextTarget.get(); }
|
|
|
|
bool isWrapped_ForTesting() const;
|
|
|
|
protected:
|
|
GrRenderTargetContext(GrContext*, GrDrawingManager*, sk_sp<GrRenderTargetProxy>,
|
|
sk_sp<SkColorSpace>, const SkSurfaceProps*, GrAuditTrail*,
|
|
GrSingleOwner*, bool managedOpList = true);
|
|
|
|
SkDEBUGCODE(void validate() const override;)
|
|
|
|
private:
|
|
class TextTarget;
|
|
|
|
inline GrAAType chooseAAType(GrAA aa, GrAllowMixedSamples allowMixedSamples) {
|
|
return GrChooseAAType(aa, this->fsaaType(), allowMixedSamples, *this->caps());
|
|
}
|
|
|
|
friend class GrAtlasTextBlob; // for access to add[Mesh]DrawOp
|
|
friend class GrStencilAndCoverTextContext; // for access to add[Mesh]DrawOp
|
|
friend class GrClipStackClip; // for access to getOpList
|
|
|
|
friend class GrDrawingManager; // for ctor
|
|
friend class GrRenderTargetContextPriv;
|
|
|
|
// All the path renderers currently make their own ops
|
|
friend class GrSoftwarePathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrAAConvexPathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrDashLinePathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrAAHairLinePathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrAALinearizingConvexPathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrSmallPathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrDefaultPathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrMSAAPathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrStencilAndCoverPathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrTessellatingPathRenderer; // for access to add[Mesh]DrawOp
|
|
friend class GrCCAtlas; // for access to addDrawOp
|
|
friend class GrCoverageCountingPathRenderer; // for access to addDrawOp
|
|
// for a unit test
|
|
friend void test_draw_op(GrRenderTargetContext*, std::unique_ptr<GrFragmentProcessor>,
|
|
sk_sp<GrTextureProxy>);
|
|
|
|
void internalClear(const GrFixedClip&, const GrColor, CanClearFullscreen);
|
|
|
|
// Only consumes the GrPaint if successful.
|
|
bool drawFilledDRRect(const GrClip& clip,
|
|
GrPaint&& paint,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRRect& origOuter,
|
|
const SkRRect& origInner);
|
|
|
|
// Only consumes the GrPaint if successful.
|
|
bool drawFilledRect(const GrClip& clip,
|
|
GrPaint&& paint,
|
|
GrAA,
|
|
const SkMatrix& viewMatrix,
|
|
const SkRect& rect,
|
|
const GrUserStencilSettings* ss);
|
|
|
|
void drawShapeUsingPathRenderer(const GrClip&, GrPaint&&, GrAA, const SkMatrix&,
|
|
const GrShape&);
|
|
|
|
// These perform processing specific to Gr[Mesh]DrawOp-derived ops before recording them into
|
|
// the op list. They return the id of the opList to which the op was added, or 0, if it was
|
|
// dropped (e.g., due to clipping).
|
|
uint32_t addDrawOp(const GrClip&, std::unique_ptr<GrDrawOp>);
|
|
|
|
// Makes a copy of the proxy if it is necessary for the draw and places the texture that should
|
|
// be used by GrXferProcessor to access the destination color in 'result'. If the return
|
|
// value is false then a texture copy could not be made.
|
|
bool SK_WARN_UNUSED_RESULT setupDstProxy(GrRenderTargetProxy*,
|
|
const GrClip&,
|
|
const SkRect& opBounds,
|
|
GrXferProcessor::DstProxy* result);
|
|
|
|
GrRenderTargetOpList* getRTOpList();
|
|
GrOpList* getOpList() override;
|
|
|
|
std::unique_ptr<GrTextUtils::Target> fTextTarget;
|
|
sk_sp<GrRenderTargetProxy> fRenderTargetProxy;
|
|
|
|
// In MDB-mode the GrOpList can be closed by some other renderTargetContext that has picked
|
|
// it up. For this reason, the GrOpList should only ever be accessed via 'getOpList'.
|
|
sk_sp<GrRenderTargetOpList> fOpList;
|
|
|
|
SkSurfaceProps fSurfaceProps;
|
|
bool fManagedOpList;
|
|
|
|
typedef GrSurfaceContext INHERITED;
|
|
};
|
|
|
|
#endif
|