Revert "Revert "Revert "Remove GrBackendRenderTargetDesc in favor of GrBackendRenderTarget."""
This reverts commit71554bc256
. Reason for revert: Google3 Original change's description: > Revert "Revert "Remove GrBackendRenderTargetDesc in favor of GrBackendRenderTarget."" > > This reverts commit807371c15b
. > > Docs-Preview: https://skia.org/?cl=40260 > Change-Id: I28e0434c455155ff39a5aaa4141abdf442474e87 > Reviewed-on: https://skia-review.googlesource.com/40260 > Reviewed-by: Greg Daniel <egdaniel@google.com> > Commit-Queue: Brian Salomon <bsalomon@google.com> TBR=egdaniel@google.com,bsalomon@google.com Change-Id: Ifdfa896a70db69935473276d12dce54de5c6b6f7 No-Presubmit: true No-Tree-Checks: true No-Try: true Reviewed-on: https://skia-review.googlesource.com/41500 Reviewed-by: Brian Salomon <bsalomon@google.com> Commit-Queue: Brian Salomon <bsalomon@google.com>
This commit is contained in:
parent
2dafbd796d
commit
6df4d6be0d
@ -55,10 +55,11 @@ void SkGLWidget::createRenderTarget() {
|
|||||||
glClearStencil(0);
|
glClearStencil(0);
|
||||||
glClear(GL_STENCIL_BUFFER_BIT);
|
glClear(GL_STENCIL_BUFFER_BIT);
|
||||||
fCurContext->resetContext();
|
fCurContext->resetContext();
|
||||||
GrBackendRenderTarget backendRenderTarget = this->getBackendRenderTarget();
|
|
||||||
fGpuSurface = SkSurface::MakeFromBackendRenderTarget(fCurContext.get(), backendRenderTarget,
|
GrBackendRenderTargetDesc desc = this->getDesc(this->width(), this->height());
|
||||||
kBottomLeft_GrSurfaceOrigin,
|
desc.fOrigin = kBottomLeft_GrSurfaceOrigin;
|
||||||
nullptr, nullptr);
|
|
||||||
|
fGpuSurface = SkSurface::MakeFromBackendRenderTarget(fCurContext.get(), desc, nullptr);
|
||||||
fCanvas = fGpuSurface->getCanvas();
|
fCanvas = fGpuSurface->getCanvas();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -77,19 +78,18 @@ void SkGLWidget::paintGL() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GrBackendRenderTarget SkGLWidget::getBackendRenderTarget() {
|
GrBackendRenderTargetDesc SkGLWidget::getDesc(int w, int h) {
|
||||||
GrGLFramebufferInfo info;
|
GrBackendRenderTargetDesc desc;
|
||||||
int stencilBits;
|
desc.fWidth = SkScalarRoundToInt(this->width());
|
||||||
int sampleCnt;
|
desc.fHeight = SkScalarRoundToInt(this->height());
|
||||||
GR_GL_GetIntegerv(fCurIntf.get(), GR_GL_FRAMEBUFFER_BINDING, &info.fFBOID);
|
desc.fConfig = kSkia8888_GrPixelConfig;
|
||||||
GR_GL_GetIntegerv(fCurIntf.get(), GR_GL_SAMPLES, &sampleCnt);
|
GR_GL_GetIntegerv(fCurIntf.get(), GR_GL_SAMPLES, &desc.fSampleCnt);
|
||||||
GR_GL_GetIntegerv(fCurIntf.get(), GR_GL_STENCIL_BITS, &stencilBits);
|
GR_GL_GetIntegerv(fCurIntf.get(), GR_GL_STENCIL_BITS, &desc.fStencilBits);
|
||||||
return GrBackendRenderTarget(SkScalarRoundToInt(this->width()),
|
GrGLint buffer;
|
||||||
SkScalarRoundToInt(this->height()),
|
GR_GL_GetIntegerv(fCurIntf.get(), GR_GL_FRAMEBUFFER_BINDING, &buffer);
|
||||||
sampleCnt,
|
desc.fRenderTargetHandle = buffer;
|
||||||
stencilBits,
|
|
||||||
kSkia8888_GrPixelConfig,
|
return desc;
|
||||||
info);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
#include "SkDebugCanvas.h"
|
#include "SkDebugCanvas.h"
|
||||||
#include "SkDebugger.h"
|
#include "SkDebugger.h"
|
||||||
#include "SkGpuDevice.h"
|
#include "SkGpuDevice.h"
|
||||||
#include "GrBackendSurface.h"
|
|
||||||
#include "GrContext.h"
|
#include "GrContext.h"
|
||||||
#include "gl/GrGLInterface.h"
|
#include "gl/GrGLInterface.h"
|
||||||
#include "gl/GrGLUtil.h"
|
#include "gl/GrGLUtil.h"
|
||||||
@ -52,7 +51,7 @@ private:
|
|||||||
SkCanvas* fCanvas;
|
SkCanvas* fCanvas;
|
||||||
|
|
||||||
SkDebugger* fDebugger;
|
SkDebugger* fDebugger;
|
||||||
GrBackendRenderTarget getBackendRenderTarget();
|
GrBackendRenderTargetDesc getDesc(int w, int h);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* SK_SUPPORT_GPU */
|
#endif /* SK_SUPPORT_GPU */
|
||||||
|
@ -5,11 +5,12 @@
|
|||||||
* found in the LICENSE file.
|
* found in the LICENSE file.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "GLFW/glfw3.h"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "GLFW/glfw3.h"
|
|
||||||
#include "GrBackendSurface.h"
|
|
||||||
#include "GrContext.h"
|
#include "GrContext.h"
|
||||||
|
|
||||||
#include "SkCanvas.h"
|
#include "SkCanvas.h"
|
||||||
#include "SkImage.h"
|
#include "SkImage.h"
|
||||||
#include "SkRSXform.h"
|
#include "SkRSXform.h"
|
||||||
@ -32,17 +33,16 @@ static void key_callback(GLFWwindow* window, int key, int scancode, int action,
|
|||||||
static void init_skia(int w, int h) {
|
static void init_skia(int w, int h) {
|
||||||
sContext = GrContext::MakeGL(nullptr).release();
|
sContext = GrContext::MakeGL(nullptr).release();
|
||||||
|
|
||||||
GrGLFramebufferInfo framebufferInfo;
|
GrBackendRenderTargetDesc desc;
|
||||||
framebufferInfo.fFBOID = 0; // assume default framebuffer
|
desc.fWidth = w;
|
||||||
GrBackendRenderTarget backendRenderTarget(w, h,
|
desc.fHeight = h;
|
||||||
0, // sample count
|
desc.fConfig = kSkia8888_GrPixelConfig;
|
||||||
0, // stencil bits
|
desc.fOrigin = kBottomLeft_GrSurfaceOrigin;
|
||||||
kSkia8888_GrPixelConfig,
|
desc.fSampleCnt = 1;
|
||||||
framebufferInfo);
|
desc.fStencilBits = 0;
|
||||||
|
desc.fRenderTargetHandle = 0; // assume default framebuffer
|
||||||
|
|
||||||
sSurface = SkSurface::MakeFromBackendRenderTarget(sContext, backendRenderTarget,
|
sSurface = SkSurface::MakeFromBackendRenderTarget(sContext, desc, nullptr, nullptr).release();
|
||||||
kBottomLeft_GrSurfaceOrigin,
|
|
||||||
nullptr, nullptr).release();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cleanup_skia() {
|
static void cleanup_skia() {
|
||||||
|
@ -8,12 +8,13 @@
|
|||||||
*/
|
*/
|
||||||
#include <v8.h>
|
#include <v8.h>
|
||||||
#include <include/libplatform/libplatform.h>
|
#include <include/libplatform/libplatform.h>
|
||||||
|
|
||||||
#include "SkV8Example.h"
|
#include "SkV8Example.h"
|
||||||
#include "Global.h"
|
#include "Global.h"
|
||||||
#include "JsContext.h"
|
#include "JsContext.h"
|
||||||
#include "Path2D.h"
|
#include "Path2D.h"
|
||||||
#include "Path2DBuilder.h"
|
#include "Path2DBuilder.h"
|
||||||
#include "GrBackendSurface.h"
|
|
||||||
#include "gl/GrGLUtil.h"
|
#include "gl/GrGLUtil.h"
|
||||||
#include "gl/GrGLDefines.h"
|
#include "gl/GrGLDefines.h"
|
||||||
#include "gl/GrGLInterface.h"
|
#include "gl/GrGLInterface.h"
|
||||||
@ -83,17 +84,19 @@ void SkV8ExampleWindow::windowSizeChanged() {
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
GrGLFramebufferInfo framebufferInfo;
|
GrBackendRenderTargetDesc desc;
|
||||||
GR_GL_GetIntegerv(fCurIntf, GR_GL_FRAMEBUFFER_BINDING, &framebufferInfo.fFBOID);
|
desc.fWidth = SkScalarRoundToInt(this->width());
|
||||||
GrBackendRenderTarget backendRenderTarget(SkScalarRoundToInt(this->width()),
|
desc.fHeight = SkScalarRoundToInt(this->height());
|
||||||
SkScalarRoundToInt(this->height()),
|
desc.fConfig = kSkia8888_GrPixelConfig;
|
||||||
attachmentInfo.fSampleCount,
|
desc.fOrigin = kBottomLeft_GrSurfaceOrigin;
|
||||||
attachmentInfo.fStencilBits,
|
desc.fSampleCnt = attachmentInfo.fSampleCount;
|
||||||
kSkia8888_GrPixelConfig,
|
desc.fStencilBits = attachmentInfo.fStencilBits;
|
||||||
framebufferInfo);
|
GrGLint buffer;
|
||||||
|
GR_GL_GetIntegerv(fCurIntf, GR_GL_FRAMEBUFFER_BINDING, &buffer);
|
||||||
|
desc.fRenderTargetHandle = buffer;
|
||||||
|
|
||||||
SkSafeUnref(fCurSurface);
|
SkSafeUnref(fCurSurface);
|
||||||
fCurSurface = SkSurface::MakeFromBackendRenderTarget(fCurContext, backendRenderTarget,
|
fCurSurface = SkSurface::MakeFromBackendRenderTarget(fCurContext, desc,
|
||||||
kBottomLeft_GrSurfaceOrigin,
|
|
||||||
nullptr, nullptr).release();
|
nullptr, nullptr).release();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -94,6 +94,16 @@ public:
|
|||||||
GrSurfaceOrigin origin, int sampleCnt,
|
GrSurfaceOrigin origin, int sampleCnt,
|
||||||
sk_sp<SkColorSpace>, const SkSurfaceProps*);
|
sk_sp<SkColorSpace>, const SkSurfaceProps*);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used to wrap a pre-existing 3D API rendering target as a SkSurface. Skia will not assume
|
||||||
|
* ownership of the render target and the client must ensure the render target is valid for the
|
||||||
|
* lifetime of the SkSurface.
|
||||||
|
*/
|
||||||
|
static sk_sp<SkSurface> MakeFromBackendRenderTarget(GrContext*,
|
||||||
|
const GrBackendRenderTargetDesc&,
|
||||||
|
sk_sp<SkColorSpace>,
|
||||||
|
const SkSurfaceProps*);
|
||||||
|
|
||||||
static sk_sp<SkSurface> MakeFromBackendRenderTarget(GrContext*,
|
static sk_sp<SkSurface> MakeFromBackendRenderTarget(GrContext*,
|
||||||
const GrBackendRenderTarget&,
|
const GrBackendRenderTarget&,
|
||||||
GrSurfaceOrigin origin,
|
GrSurfaceOrigin origin,
|
||||||
@ -103,9 +113,10 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Used to wrap a pre-existing 3D API texture as a SkSurface. Skia will treat the texture as
|
* Used to wrap a pre-existing 3D API texture as a SkSurface. Skia will treat the texture as
|
||||||
* a rendering target only, but unlike NewFromBackendRenderTarget, Skia will manage and own
|
* a rendering target only, but unlike NewFromBackendRenderTarget, Skia will manage and own
|
||||||
* the associated render target objects (but not the provided texture). Skia will not assume
|
* the associated render target objects (but not the provided texture). The kRenderTarget flag
|
||||||
* ownership of the texture and the client must ensure the texture is valid for the lifetime
|
* must be set on GrBackendTextureDesc for this to succeed. Skia will not assume ownership
|
||||||
* of the SkSurface.
|
* of the texture and the client must ensure the texture is valid for the lifetime of the
|
||||||
|
* SkSurface.
|
||||||
*/
|
*/
|
||||||
static sk_sp<SkSurface> MakeFromBackendTextureAsRenderTarget(GrContext*,
|
static sk_sp<SkSurface> MakeFromBackendTextureAsRenderTarget(GrContext*,
|
||||||
const GrBackendTexture&,
|
const GrBackendTexture&,
|
||||||
@ -114,6 +125,17 @@ public:
|
|||||||
sk_sp<SkColorSpace>,
|
sk_sp<SkColorSpace>,
|
||||||
const SkSurfaceProps*);
|
const SkSurfaceProps*);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Legacy version of the above factory, without color space support. This creates a "legacy"
|
||||||
|
* surface that operate without gamma correction or color management.
|
||||||
|
*/
|
||||||
|
static sk_sp<SkSurface> MakeFromBackendRenderTarget(GrContext* ctx,
|
||||||
|
const GrBackendRenderTargetDesc& desc,
|
||||||
|
const SkSurfaceProps* props) {
|
||||||
|
return MakeFromBackendRenderTarget(ctx, desc, nullptr, props);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return a new surface whose contents will be drawn to an offscreen
|
* Return a new surface whose contents will be drawn to an offscreen
|
||||||
* render target, allocated by the surface.
|
* render target, allocated by the surface.
|
||||||
|
@ -108,6 +108,12 @@ public:
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
// Temporary constructor which can be used to convert from a GrBackendRenderTargetDesc.
|
||||||
|
GrBackendRenderTarget(const GrBackendRenderTargetDesc& desc, GrBackend backend);
|
||||||
|
|
||||||
|
// Friending for access to above constructor taking a GrBackendRenderTargetDesc
|
||||||
|
friend class SkSurface;
|
||||||
|
|
||||||
int fWidth; //<! width in pixels
|
int fWidth; //<! width in pixels
|
||||||
int fHeight; //<! height in pixels
|
int fHeight; //<! height in pixels
|
||||||
|
|
||||||
|
@ -641,6 +641,39 @@ enum GrWrapOwnership {
|
|||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gr can wrap an existing render target created by the client in the 3D API
|
||||||
|
* with a GrRenderTarget object. The client is responsible for ensuring that the
|
||||||
|
* underlying 3D API object lives at least as long as the GrRenderTarget object
|
||||||
|
* wrapping it. We require the client to explicitly provide information about
|
||||||
|
* the target, such as width, height, and pixel config rather than querying the
|
||||||
|
* 3D API for these values. We expect these properties to be immutable even if
|
||||||
|
* the 3D API doesn't require this (OpenGL).
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct GrBackendRenderTargetDesc {
|
||||||
|
GrBackendRenderTargetDesc() { memset(this, 0, sizeof(*this)); }
|
||||||
|
int fWidth; //<! width in pixels
|
||||||
|
int fHeight; //<! height in pixels
|
||||||
|
GrPixelConfig fConfig; //<! color format
|
||||||
|
GrSurfaceOrigin fOrigin; //<! pixel origin
|
||||||
|
/**
|
||||||
|
* The number of samples per pixel. Gr uses this to influence decisions
|
||||||
|
* about applying other forms of anti-aliasing.
|
||||||
|
*/
|
||||||
|
int fSampleCnt;
|
||||||
|
/**
|
||||||
|
* Number of bits of stencil per-pixel.
|
||||||
|
*/
|
||||||
|
int fStencilBits;
|
||||||
|
/**
|
||||||
|
* Handle to the 3D API object.
|
||||||
|
* OpenGL: FBO ID
|
||||||
|
* Vulkan: GrVkImageInfo*
|
||||||
|
*/
|
||||||
|
GrBackendObject fRenderTargetHandle;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The GrContext's cache of backend context state can be partially invalidated.
|
* The GrContext's cache of backend context state can be partially invalidated.
|
||||||
* These enums are specific to the GL backend and we'd add a new set for an alternative backend.
|
* These enums are specific to the GL backend and we'd add a new set for an alternative backend.
|
||||||
|
@ -116,9 +116,11 @@ can be in any gamut, but must have a linear transfer function.
|
|||||||
sk_sp<SkImage> MakeFromEncoded(sk_sp<SkData> encoded);
|
sk_sp<SkImage> MakeFromEncoded(sk_sp<SkData> encoded);
|
||||||
|
|
||||||
// Create an image from a texture in a particular color space
|
// Create an image from a texture in a particular color space
|
||||||
sk_sp<SkImage> MakeFromTexture(GrContext*, const GrBackendTexture&,
|
// Caution: There are versions of this constructor that do not take an
|
||||||
GrSurfaceOrigin, SkAlphaType, sk_sp<SkColorSpace>,
|
// SkColorSpace. But without an SkColorSpace, Skia does not have
|
||||||
...);
|
// enough information to draw correctly.
|
||||||
|
sk_sp<SkImage> MakeFromTexture(GrContext*, const GrBackendTextureDesc&,
|
||||||
|
SkAlphaType, sk_sp<SkColorSpace>, ...);
|
||||||
|
|
||||||
**SkBitmap** is another (not preferred) representation for image sources. Be careful to not forget
|
**SkBitmap** is another (not preferred) representation for image sources. Be careful to not forget
|
||||||
the color space.
|
the color space.
|
||||||
@ -189,4 +191,3 @@ It is possible to create **an object that is both a source and destination**, if
|
|||||||
draw into it and then draw it somewhere else. The same rules from above still apply, but it is
|
draw into it and then draw it somewhere else. The same rules from above still apply, but it is
|
||||||
subtle that the color space tag could have an effect (or no effect) depending on how the object is
|
subtle that the color space tag could have an effect (or no effect) depending on how the object is
|
||||||
used.
|
used.
|
||||||
|
|
||||||
|
@ -33,16 +33,14 @@ To create a GrContext that is backed by Vulkan the client creates a Vulkan devic
|
|||||||
|
|
||||||
sk_sp<GrContext> context = GrContext::MakeVulkan(vkBackendContext);
|
sk_sp<GrContext> context = GrContext::MakeVulkan(vkBackendContext);
|
||||||
|
|
||||||
When using the Vulkan backend, GrVkImageInfo is used to construct GrBackendTexture
|
When using the Vulkan backend the GrBackendObject field in
|
||||||
and GrBackendRenderTarget objects that in turn are used to create SkSurface and SkImage
|
GrBackendRenderTargetDesc and GrBackendTextureDesc is interpeted as a pointer
|
||||||
objects that refer to VkImages created by the Skia client.
|
to a GrVkImageInfo object. GrVkImageInfo specifies a VkImage and associated
|
||||||
|
state (tiling, layout, format, etc). This allows the client to import
|
||||||
|
externally created Vulkan images as destinations for Skia rendering via
|
||||||
|
SkSurface factory functions or for to composite Skia rendered content using
|
||||||
|
SkImage::getTextureHandle().
|
||||||
|
|
||||||
The GrBackendObject returned by SkImage::getTextureHandle(),
|
|
||||||
SkSurface::getTextureHandle(), and SkSurface::getRenderTargetHandle() should be
|
|
||||||
interpreted as a GrVkImageInfo*. This allows a client to get the backing VkImage
|
|
||||||
of a SkImage or SkSurface.
|
|
||||||
|
|
||||||
GrVkImageInfo specifies a VkImage and associated state (tiling, layout, format, etc).
|
|
||||||
After getting a GrVkImageInfo* via getTextureHandle() or
|
After getting a GrVkImageInfo* via getTextureHandle() or
|
||||||
getRenderTargetHandle(), the client should check the fImageLayout field to know
|
getRenderTargetHandle(), the client should check the fImageLayout field to know
|
||||||
what layout Skia left the VkImage in before using the VkImage. If the client
|
what layout Skia left the VkImage in before using the VkImage. If the client
|
||||||
|
@ -97,6 +97,29 @@ GrBackendRenderTarget::GrBackendRenderTarget(int width,
|
|||||||
, fBackend(kOpenGL_GrBackend)
|
, fBackend(kOpenGL_GrBackend)
|
||||||
, fGLInfo(glInfo) {}
|
, fGLInfo(glInfo) {}
|
||||||
|
|
||||||
|
GrBackendRenderTarget::GrBackendRenderTarget(const GrBackendRenderTargetDesc& desc,
|
||||||
|
GrBackend backend)
|
||||||
|
: fWidth(desc.fWidth)
|
||||||
|
, fHeight(desc.fHeight)
|
||||||
|
, fSampleCnt(desc.fSampleCnt)
|
||||||
|
, fStencilBits(desc.fStencilBits)
|
||||||
|
, fConfig(desc.fConfig)
|
||||||
|
, fBackend(backend) {
|
||||||
|
if (kOpenGL_GrBackend == backend) {
|
||||||
|
fGLInfo.fFBOID = static_cast<GrGLuint>(desc.fRenderTargetHandle);
|
||||||
|
} else {
|
||||||
|
SkASSERT(kVulkan_GrBackend == backend);
|
||||||
|
#ifdef SK_VULKAN
|
||||||
|
const GrVkImageInfo* vkInfo =
|
||||||
|
reinterpret_cast<const GrVkImageInfo*>(desc.fRenderTargetHandle);
|
||||||
|
fConfig = GrVkFormatToPixelConfig(vkInfo->fFormat);
|
||||||
|
fVkInfo = *vkInfo;
|
||||||
|
#else
|
||||||
|
fConfig = kUnknown_GrPixelConfig;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef SK_VULKAN
|
#ifdef SK_VULKAN
|
||||||
const GrVkImageInfo* GrBackendRenderTarget::getVkImageInfo() const {
|
const GrVkImageInfo* GrBackendRenderTarget::getVkImageInfo() const {
|
||||||
if (kVulkan_GrBackend == fBackend) {
|
if (kVulkan_GrBackend == fBackend) {
|
||||||
|
@ -258,6 +258,13 @@ sk_sp<SkSurface> SkSurface::MakeFromBackendTexture(GrContext*, const GrBackendTe
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sk_sp<SkSurface> SkSurface::MakeFromBackendRenderTarget(GrContext*,
|
||||||
|
const GrBackendRenderTargetDesc&,
|
||||||
|
sk_sp<SkColorSpace>,
|
||||||
|
const SkSurfaceProps*) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
sk_sp<SkSurface> SkSurface::MakeFromBackendRenderTarget(GrContext*,
|
sk_sp<SkSurface> SkSurface::MakeFromBackendRenderTarget(GrContext*,
|
||||||
const GrBackendRenderTarget&,
|
const GrBackendRenderTarget&,
|
||||||
GrSurfaceOrigin origin,
|
GrSurfaceOrigin origin,
|
||||||
|
@ -265,6 +265,20 @@ sk_sp<SkSurface> SkSurface::MakeFromBackendTexture(GrContext* context, const GrB
|
|||||||
return sk_make_sp<SkSurface_Gpu>(std::move(device));
|
return sk_make_sp<SkSurface_Gpu>(std::move(device));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sk_sp<SkSurface> SkSurface::MakeFromBackendRenderTarget(GrContext* context,
|
||||||
|
const GrBackendRenderTargetDesc& desc,
|
||||||
|
sk_sp<SkColorSpace> colorSpace,
|
||||||
|
const SkSurfaceProps* props) {
|
||||||
|
if (!context) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
GrBackendRenderTarget backendRT(desc, context->contextPriv().getBackend());
|
||||||
|
return MakeFromBackendRenderTarget(context, backendRT, desc.fOrigin,
|
||||||
|
std::move(colorSpace), props);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
sk_sp<SkSurface> SkSurface::MakeFromBackendRenderTarget(GrContext* context,
|
sk_sp<SkSurface> SkSurface::MakeFromBackendRenderTarget(GrContext* context,
|
||||||
const GrBackendRenderTarget& backendRT,
|
const GrBackendRenderTarget& backendRT,
|
||||||
GrSurfaceOrigin origin,
|
GrSurfaceOrigin origin,
|
||||||
|
Loading…
Reference in New Issue
Block a user