/* * 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 GrRenderTargetPriv_DEFINED #define GrRenderTargetPriv_DEFINED #include "GrRenderTarget.h" #include "GrGpu.h" class GrStencilSettings; /** Class that adds methods to GrRenderTarget that are only intended for use internal to Skia. This class is purely a privileged window into GrRenderTarget. It should never have additional data members or virtual methods. */ class GrRenderTargetPriv { public: /** * GrStencilAttachment is not part of the public API. */ GrStencilAttachment* getStencilAttachment() const { return fRenderTarget->fStencilAttachment.get(); } /** * Attaches the GrStencilAttachment onto the render target. If stencil is a nullptr then the * currently attached GrStencilAttachment will be removed if one was previously attached. This * function returns false if there were any failure in attaching the GrStencilAttachment. */ void attachStencilAttachment(sk_sp<GrStencilAttachment> stencil); int numStencilBits() const; /** * Returns a unique key that identifies this render target's sample pattern. (Must be * multisampled.) * * NOTE: The pipeline argument is only required in case we need to flush draw state and actually * query multisample info. The pipeline itself is not expected to affect sample locations. */ int getSamplePatternKey(const GrPipeline&) const; /** * Retrieves the per-pixel HW sample locations for this render target, and, as a by-product, the actual * number of samples in use. (This may differ from fSampleCnt.) Sample locations are returned as * 0..1 offsets relative to the top-left corner of the pixel. */ const SkTArray<SkPoint>& getSampleLocations(const GrPipeline& pipeline) const { int samplePatternKey = this->getSamplePatternKey(pipeline); return fRenderTarget->getGpu()->retrieveSampleLocations(samplePatternKey); } private: explicit GrRenderTargetPriv(GrRenderTarget* renderTarget) : fRenderTarget(renderTarget) {} GrRenderTargetPriv(const GrRenderTargetPriv&) {} // unimpl GrRenderTargetPriv& operator=(const GrRenderTargetPriv&); // unimpl // No taking addresses of this type. const GrRenderTargetPriv* operator&() const; GrRenderTargetPriv* operator&(); GrRenderTarget* fRenderTarget; friend class GrRenderTarget; // to construct/copy this type. }; inline GrRenderTargetPriv GrRenderTarget::renderTargetPriv() { return GrRenderTargetPriv(this); } inline const GrRenderTargetPriv GrRenderTarget::renderTargetPriv () const { return GrRenderTargetPriv(const_cast<GrRenderTarget*>(this)); } #endif