diff options
Diffstat (limited to 'gfx/skia/skia/src/core/SkSpecialSurface.h')
-rw-r--r-- | gfx/skia/skia/src/core/SkSpecialSurface.h | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/gfx/skia/skia/src/core/SkSpecialSurface.h b/gfx/skia/skia/src/core/SkSpecialSurface.h new file mode 100644 index 0000000000..4c33008940 --- /dev/null +++ b/gfx/skia/skia/src/core/SkSpecialSurface.h @@ -0,0 +1,101 @@ +/* + * Copyright 2016 Google Inc. + * + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file + */ + +#ifndef SkSpecialSurface_DEFINED +#define SkSpecialSurface_DEFINED + +#include "include/core/SkCanvas.h" +#include "include/core/SkImageInfo.h" +#include "include/core/SkRefCnt.h" +#include "include/core/SkSurfaceProps.h" + +#if defined(SK_GANESH) +#include "include/private/gpu/ganesh/GrTypesPriv.h" +#endif + +#if defined(SK_GRAPHITE) +namespace skgpu::graphite { + class Recorder; +} +#endif + +class GrBackendFormat; +class GrRecordingContext; +class SkBaseDevice; +class SkBitmap; +class SkCanvas; +class SkSpecialImage; + +/** + * SkSpecialSurface is a restricted form of SkSurface solely for internal use. It differs + * from SkSurface in that: + * - it can be backed by GrTextures larger than [ fWidth, fHeight ] + * - it can't be used for tiling + * - it becomes inactive once a snapshot of it is taken (i.e., no copy-on-write) + * - it has no generation ID + */ +class SkSpecialSurface : public SkRefCnt { +public: + SkSpecialSurface(sk_sp<SkBaseDevice>, const SkIRect& subset); + +#ifdef SK_DEBUG + SkSurfaceProps props() const { return fCanvas->getBaseProps(); } +#endif + + const SkIRect& subset() const { return fSubset; } + int width() const { return fSubset.width(); } + int height() const { return fSubset.height(); } + + /** + * Return a canvas that will draw into this special surface. This will always + * return the same canvas for a given special surface, and is managed/owned by the + * special surface. + * + * The canvas will be invalid after 'makeImageSnapshot' is called. + */ + SkCanvas* getCanvas() { return fCanvas.get(); } + + /** + * Returns an image of the current state of the surface pixels up to this + * point. The canvas returned by 'getCanvas' becomes invalidated by this + * call and no more drawing to this surface is allowed. + */ + sk_sp<SkSpecialImage> makeImageSnapshot(); + +#if defined(SK_GANESH) + /** + * Allocate a new GPU-backed SkSpecialSurface. If the requested surface cannot + * be created, nullptr will be returned. + */ + static sk_sp<SkSpecialSurface> MakeRenderTarget(GrRecordingContext*, + const SkImageInfo&, + const SkSurfaceProps&, + GrSurfaceOrigin); +#endif + +#if defined(SK_GRAPHITE) + static sk_sp<SkSpecialSurface> MakeGraphite(skgpu::graphite::Recorder*, + const SkImageInfo&, + const SkSurfaceProps&); +#endif + + /** + * Return a new CPU-backed surface, with the memory for the pixels automatically + * allocated. + * + * If the requested surface cannot be created, or the request is not a + * supported configuration, nullptr will be returned. + */ + static sk_sp<SkSpecialSurface> MakeRaster(const SkImageInfo&, + const SkSurfaceProps&); + +private: + std::unique_ptr<SkCanvas> fCanvas; + const SkIRect fSubset; +}; + +#endif |