Add a new entry point for making promise images
This paves the way for promise image sharing among direct & recording contexts, and untethers promise images from DDL recorder. Followup CLs will migrate us to actually use this entry point, and then migrate Chrome to do same. Bug: skia:10286 Change-Id: I0ad46e8e4b91d8bc03cb039b304d2ea6d8a65c35 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/373716 Commit-Queue: Brian Salomon <bsalomon@google.com> Reviewed-by: Brian Salomon <bsalomon@google.com> Reviewed-by: Robert Phillips <robertphillips@google.com>
This commit is contained in:
parent
cc35b06f6d
commit
c44e21f37e
@ -58,6 +58,10 @@ Milestone 90
|
|||||||
improves rendering when diffuse and specular constants are greater than 1.
|
improves rendering when diffuse and specular constants are greater than 1.
|
||||||
https://review.skia.org/355496
|
https://review.skia.org/355496
|
||||||
|
|
||||||
|
* SkDeferredDisplayListRecorder::makePromiseTexture has moved to SkImage::MakePromiseTexture.
|
||||||
|
New code should use the new entry point – migration CLs will be coming soon.
|
||||||
|
https://review.skia.org/373716
|
||||||
|
|
||||||
Milestone 89
|
Milestone 89
|
||||||
------------
|
------------
|
||||||
* Removed SkYUVAIndex and SkYUVASizeInfo. These were no longer used in any
|
* Removed SkYUVAIndex and SkYUVASizeInfo. These were no longer used in any
|
||||||
|
@ -26,7 +26,7 @@ class SkSurface;
|
|||||||
/*
|
/*
|
||||||
* This class is intended to be used as:
|
* This class is intended to be used as:
|
||||||
* Get an SkSurfaceCharacterization representing the intended gpu-backed destination SkSurface
|
* Get an SkSurfaceCharacterization representing the intended gpu-backed destination SkSurface
|
||||||
* Create one of these (an SkDDLMaker) on the stack
|
* Create one of these (an SkDeferredDisplayListRecorder) on the stack
|
||||||
* Get the canvas and render into it
|
* Get the canvas and render into it
|
||||||
* Snap off and hold on to an SkDeferredDisplayList
|
* Snap off and hold on to an SkDeferredDisplayList
|
||||||
* Once your app actually needs the pixels, call SkSurface::draw(SkDeferredDisplayList*)
|
* Once your app actually needs the pixels, call SkSurface::draw(SkDeferredDisplayList*)
|
||||||
@ -51,43 +51,12 @@ public:
|
|||||||
|
|
||||||
sk_sp<SkDeferredDisplayList> detach();
|
sk_sp<SkDeferredDisplayList> detach();
|
||||||
|
|
||||||
using PromiseImageTextureContext = void*;
|
using PromiseImageTextureContext = SkImage::PromiseImageTextureContext;
|
||||||
using PromiseImageTextureFulfillProc =
|
using PromiseImageTextureFulfillProc = SkImage::PromiseImageTextureFulfillProc;
|
||||||
sk_sp<SkPromiseImageTexture> (*)(PromiseImageTextureContext);
|
using PromiseImageTextureReleaseProc = SkImage::PromiseImageTextureReleaseProc;
|
||||||
using PromiseImageTextureReleaseProc = void (*)(PromiseImageTextureContext);
|
|
||||||
|
|
||||||
/**
|
#ifndef SK_MAKE_PROMISE_TEXTURE_DISABLE_LEGACY_API
|
||||||
Create a new SkImage that is very similar to an SkImage created by MakeFromTexture. The
|
/** Deprecated: Use SkImage::MakePromiseTexture instead. */
|
||||||
difference is that the caller need not have created the texture nor populated it with the
|
|
||||||
image pixel data. Moreover, the SkImage may be created on a thread as the creation of the
|
|
||||||
image does not require access to the backend API or GrContext. Instead of passing a
|
|
||||||
GrBackendTexture the client supplies a description of the texture consisting of
|
|
||||||
GrBackendFormat, width, height, and GrMipmapped state. The resulting SkImage can be drawn
|
|
||||||
to a SkDeferredDisplayListRecorder or directly to a GPU-backed SkSurface.
|
|
||||||
|
|
||||||
When the actual texture is required to perform a backend API draw, textureFulfillProc will
|
|
||||||
be called to receive a GrBackendTexture. The properties of the GrBackendTexture must match
|
|
||||||
those set during the SkImage creation, and it must refer to a valid existing texture in the
|
|
||||||
backend API context/device, and be populated with the image pixel data. The texture cannot
|
|
||||||
be deleted until textureReleaseProc is called.
|
|
||||||
|
|
||||||
There is at most one call to each of textureFulfillProc and textureReleaseProc.
|
|
||||||
textureReleaseProc is always called even if image creation fails or if the
|
|
||||||
image is never fulfilled (e.g. it is never drawn or all draws are clipped out)
|
|
||||||
|
|
||||||
This call is only valid if the SkDeferredDisplayListRecorder is backed by a GPU context.
|
|
||||||
|
|
||||||
@param backendFormat format of promised gpu texture
|
|
||||||
@param width width of promised gpu texture
|
|
||||||
@param height height of promised gpu texture
|
|
||||||
@param mipMapped mip mapped state of promised gpu texture
|
|
||||||
@param colorSpace range of colors; may be nullptr
|
|
||||||
@param textureFulfillProc function called to get actual gpu texture
|
|
||||||
@param textureReleaseProc function called when texture can be deleted
|
|
||||||
@param textureContext state passed to textureFulfillProc and textureReleaseProc
|
|
||||||
@param version controls when textureReleaseProc is called
|
|
||||||
@return created SkImage, or nullptr
|
|
||||||
*/
|
|
||||||
sk_sp<SkImage> makePromiseTexture(const GrBackendFormat& backendFormat,
|
sk_sp<SkImage> makePromiseTexture(const GrBackendFormat& backendFormat,
|
||||||
int width,
|
int width,
|
||||||
int height,
|
int height,
|
||||||
@ -100,26 +69,13 @@ public:
|
|||||||
PromiseImageTextureReleaseProc textureReleaseProc,
|
PromiseImageTextureReleaseProc textureReleaseProc,
|
||||||
PromiseImageTextureContext textureContext);
|
PromiseImageTextureContext textureContext);
|
||||||
|
|
||||||
/**
|
/** Deprecated: Use SkImage::MakePromiseYUVATexture instead. */
|
||||||
This entry point operates like 'makePromiseTexture' but it is used to construct a SkImage
|
|
||||||
from YUV[A] data. The source data may be planar (i.e. spread across multiple textures). In
|
|
||||||
the extreme Y, U, V, and A are all in different planes and thus the image is specified by
|
|
||||||
four textures. 'yuvaBackendTextureInfo' describes the planar arrangement, texture formats,
|
|
||||||
conversion to RGB, and origin of the textures. Separate 'textureFulfillProc' and
|
|
||||||
'textureReleaseProc' calls are made for each texture. Each texture has its own
|
|
||||||
PromiseImageTextureContext. If 'yuvaBackendTextureinfo' is not valid then no release proc
|
|
||||||
calls are made. Otherwise, the calls will be made even on failure. 'textureContexts' has one
|
|
||||||
entry for each of the up to four textures, as indicated by 'yuvaBackendTextureinfo'.
|
|
||||||
|
|
||||||
Currently the mip mapped property of 'yuvaBackendTextureInfo' is ignored. However, in the
|
|
||||||
near future it will be required that if it is kYes then textureFulfillProc must return
|
|
||||||
a mip mapped texture for each plane in order to successfully draw the image.
|
|
||||||
*/
|
|
||||||
sk_sp<SkImage> makeYUVAPromiseTexture(const GrYUVABackendTextureInfo& yuvaBackendTextureInfo,
|
sk_sp<SkImage> makeYUVAPromiseTexture(const GrYUVABackendTextureInfo& yuvaBackendTextureInfo,
|
||||||
sk_sp<SkColorSpace> imageColorSpace,
|
sk_sp<SkColorSpace> imageColorSpace,
|
||||||
PromiseImageTextureFulfillProc textureFulfillProc,
|
PromiseImageTextureFulfillProc textureFulfillProc,
|
||||||
PromiseImageTextureReleaseProc textureReleaseProc,
|
PromiseImageTextureReleaseProc textureReleaseProc,
|
||||||
PromiseImageTextureContext textureContexts[]);
|
PromiseImageTextureContext textureContexts[]);
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SkDeferredDisplayListRecorder(const SkDeferredDisplayListRecorder&) = delete;
|
SkDeferredDisplayListRecorder(const SkDeferredDisplayListRecorder&) = delete;
|
||||||
|
@ -31,12 +31,15 @@ class SkImageGenerator;
|
|||||||
class SkMipmap;
|
class SkMipmap;
|
||||||
class SkPaint;
|
class SkPaint;
|
||||||
class SkPicture;
|
class SkPicture;
|
||||||
|
class SkPromiseImageTexture;
|
||||||
class SkSurface;
|
class SkSurface;
|
||||||
class SkYUVAPixmaps;
|
class SkYUVAPixmaps;
|
||||||
|
class GrBackendFormat;
|
||||||
class GrBackendTexture;
|
class GrBackendTexture;
|
||||||
class GrDirectContext;
|
class GrDirectContext;
|
||||||
class GrRecordingContext;
|
class GrRecordingContext;
|
||||||
class GrContextThreadSafeProxy;
|
class GrContextThreadSafeProxy;
|
||||||
|
class GrYUVABackendTextureInfo;
|
||||||
class GrYUVABackendTextures;
|
class GrYUVABackendTextures;
|
||||||
|
|
||||||
/** \class SkImage
|
/** \class SkImage
|
||||||
@ -474,6 +477,83 @@ public:
|
|||||||
GrSurfaceOrigin surfaceOrigin = kTopLeft_GrSurfaceOrigin);
|
GrSurfaceOrigin surfaceOrigin = kTopLeft_GrSurfaceOrigin);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
using PromiseImageTextureContext = void*;
|
||||||
|
using PromiseImageTextureFulfillProc =
|
||||||
|
sk_sp<SkPromiseImageTexture> (*)(PromiseImageTextureContext);
|
||||||
|
using PromiseImageTextureReleaseProc = void (*)(PromiseImageTextureContext);
|
||||||
|
|
||||||
|
/** Create a new SkImage that is very similar to an SkImage created by MakeFromTexture. The
|
||||||
|
difference is that the caller need not have created the texture nor populated it with the
|
||||||
|
image pixel data. Moreover, the SkImage may be created on a thread as the creation of the
|
||||||
|
image does not require access to the backend API or GrDirectContext. Instead of passing a
|
||||||
|
GrBackendTexture the client supplies a description of the texture consisting of
|
||||||
|
GrBackendFormat, width, height, and GrMipmapped state. The resulting SkImage can be drawn
|
||||||
|
to a SkDeferredDisplayListRecorder or directly to a GPU-backed SkSurface.
|
||||||
|
|
||||||
|
When the actual texture is required to perform a backend API draw, textureFulfillProc will
|
||||||
|
be called to receive a GrBackendTexture. The properties of the GrBackendTexture must match
|
||||||
|
those set during the SkImage creation, and it must refer to a valid existing texture in the
|
||||||
|
backend API context/device, and be populated with the image pixel data. The texture cannot
|
||||||
|
be deleted until textureReleaseProc is called.
|
||||||
|
|
||||||
|
There is at most one call to each of textureFulfillProc and textureReleaseProc.
|
||||||
|
textureReleaseProc is always called even if image creation fails or if the
|
||||||
|
image is never fulfilled (e.g. it is never drawn or all draws are clipped out)
|
||||||
|
|
||||||
|
@param gpuContextProxy the thread-safe proxy of the gpu context. required.
|
||||||
|
@param backendFormat format of promised gpu texture
|
||||||
|
@param dimensions width & height of promised gpu texture
|
||||||
|
@param mipMapped mip mapped state of promised gpu texture
|
||||||
|
@param origin surface origin of promised gpu texture
|
||||||
|
@param colorType color type of promised gpu texture
|
||||||
|
@param alphaType alpha type of promised gpu texture
|
||||||
|
@param colorSpace range of colors; may be nullptr
|
||||||
|
@param textureFulfillProc function called to get actual gpu texture
|
||||||
|
@param textureReleaseProc function called when texture can be deleted
|
||||||
|
@param textureContext state passed to textureFulfillProc and textureReleaseProc
|
||||||
|
@return created SkImage, or nullptr
|
||||||
|
*/
|
||||||
|
static sk_sp<SkImage> MakePromiseTexture(sk_sp<GrContextThreadSafeProxy> gpuContextProxy,
|
||||||
|
const GrBackendFormat& backendFormat,
|
||||||
|
SkISize dimensions,
|
||||||
|
GrMipmapped mipMapped,
|
||||||
|
GrSurfaceOrigin origin,
|
||||||
|
SkColorType colorType,
|
||||||
|
SkAlphaType alphaType,
|
||||||
|
sk_sp<SkColorSpace> colorSpace,
|
||||||
|
PromiseImageTextureFulfillProc textureFulfillProc,
|
||||||
|
PromiseImageTextureReleaseProc textureReleaseProc,
|
||||||
|
PromiseImageTextureContext textureContext);
|
||||||
|
|
||||||
|
/** This entry point operates like 'MakePromiseTexture' but it is used to construct a SkImage
|
||||||
|
from YUV[A] data. The source data may be planar (i.e. spread across multiple textures). In
|
||||||
|
the extreme Y, U, V, and A are all in different planes and thus the image is specified by
|
||||||
|
four textures. 'backendTextureInfo' describes the planar arrangement, texture formats,
|
||||||
|
conversion to RGB, and origin of the textures. Separate 'textureFulfillProc' and
|
||||||
|
'textureReleaseProc' calls are made for each texture. Each texture has its own
|
||||||
|
PromiseImageTextureContext. If 'backendTextureInfo' is not valid then no release proc
|
||||||
|
calls are made. Otherwise, the calls will be made even on failure. 'textureContexts' has one
|
||||||
|
entry for each of the up to four textures, as indicated by 'backendTextureInfo'.
|
||||||
|
|
||||||
|
Currently the mip mapped property of 'backendTextureInfo' is ignored. However, in the
|
||||||
|
near future it will be required that if it is kYes then textureFulfillProc must return
|
||||||
|
a mip mapped texture for each plane in order to successfully draw the image.
|
||||||
|
|
||||||
|
@param gpuContextProxy the thread-safe proxy of the gpu context. required.
|
||||||
|
@param backendTextureInfo info about the promised yuva gpu texture
|
||||||
|
@param imageColorSpace range of colors; may be nullptr
|
||||||
|
@param textureFulfillProc function called to get actual gpu texture
|
||||||
|
@param textureReleaseProc function called when texture can be deleted
|
||||||
|
@param textureContexts state passed to textureFulfillProc and textureReleaseProc
|
||||||
|
@return created SkImage, or nullptr
|
||||||
|
*/
|
||||||
|
static sk_sp<SkImage> MakePromiseYUVATexture(sk_sp<GrContextThreadSafeProxy> gpuContextProxy,
|
||||||
|
const GrYUVABackendTextureInfo& backendTextureInfo,
|
||||||
|
sk_sp<SkColorSpace> imageColorSpace,
|
||||||
|
PromiseImageTextureFulfillProc textureFulfillProc,
|
||||||
|
PromiseImageTextureReleaseProc textureReleaseProc,
|
||||||
|
PromiseImageTextureContext textureContexts[]);
|
||||||
|
|
||||||
/** Returns a SkImageInfo describing the width, height, color type, alpha type, and color space
|
/** Returns a SkImageInfo describing the width, height, color type, alpha type, and color space
|
||||||
of the SkImage.
|
of the SkImage.
|
||||||
|
|
||||||
|
@ -8,8 +8,11 @@
|
|||||||
#ifndef GrContextThreadSafeProxy_DEFINED
|
#ifndef GrContextThreadSafeProxy_DEFINED
|
||||||
#define GrContextThreadSafeProxy_DEFINED
|
#define GrContextThreadSafeProxy_DEFINED
|
||||||
|
|
||||||
#include "include/core/SkImageInfo.h"
|
|
||||||
#include "include/core/SkRefCnt.h"
|
#include "include/core/SkRefCnt.h"
|
||||||
|
|
||||||
|
#if SK_SUPPORT_GPU
|
||||||
|
|
||||||
|
#include "include/core/SkImageInfo.h"
|
||||||
#include "include/gpu/GrContextOptions.h"
|
#include "include/gpu/GrContextOptions.h"
|
||||||
#include "include/gpu/GrTypes.h"
|
#include "include/gpu/GrTypes.h"
|
||||||
|
|
||||||
@ -138,4 +141,8 @@ private:
|
|||||||
std::atomic<bool> fAbandoned{false};
|
std::atomic<bool> fAbandoned{false};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#else // !SK_SUPPORT_GPU
|
||||||
|
class SK_API GrContextThreadSafeProxy final : public SkNVRefCnt<GrContextThreadSafeProxy> {};
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -234,6 +234,7 @@ sk_sp<SkDeferredDisplayList> SkDeferredDisplayListRecorder::detach() {
|
|||||||
return ddl;
|
return ddl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef SK_MAKE_PROMISE_TEXTURE_DISABLE_LEGACY_API
|
||||||
sk_sp<SkImage> SkDeferredDisplayListRecorder::makePromiseTexture(
|
sk_sp<SkImage> SkDeferredDisplayListRecorder::makePromiseTexture(
|
||||||
const GrBackendFormat& backendFormat,
|
const GrBackendFormat& backendFormat,
|
||||||
int width,
|
int width,
|
||||||
@ -249,7 +250,7 @@ sk_sp<SkImage> SkDeferredDisplayListRecorder::makePromiseTexture(
|
|||||||
if (!fContext) {
|
if (!fContext) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return SkImage_Gpu::MakePromiseTexture(fContext->threadSafeProxy(),
|
return SkImage::MakePromiseTexture(fContext->threadSafeProxy(),
|
||||||
backendFormat,
|
backendFormat,
|
||||||
{width, height},
|
{width, height},
|
||||||
mipMapped,
|
mipMapped,
|
||||||
@ -263,7 +264,7 @@ sk_sp<SkImage> SkDeferredDisplayListRecorder::makePromiseTexture(
|
|||||||
}
|
}
|
||||||
|
|
||||||
sk_sp<SkImage> SkDeferredDisplayListRecorder::makeYUVAPromiseTexture(
|
sk_sp<SkImage> SkDeferredDisplayListRecorder::makeYUVAPromiseTexture(
|
||||||
const GrYUVABackendTextureInfo& yuvaBackendTextureInfo,
|
const GrYUVABackendTextureInfo& backendTextureInfo,
|
||||||
sk_sp<SkColorSpace> imageColorSpace,
|
sk_sp<SkColorSpace> imageColorSpace,
|
||||||
PromiseImageTextureFulfillProc textureFulfillProc,
|
PromiseImageTextureFulfillProc textureFulfillProc,
|
||||||
PromiseImageTextureReleaseProc textureReleaseProc,
|
PromiseImageTextureReleaseProc textureReleaseProc,
|
||||||
@ -271,12 +272,13 @@ sk_sp<SkImage> SkDeferredDisplayListRecorder::makeYUVAPromiseTexture(
|
|||||||
if (!fContext) {
|
if (!fContext) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return SkImage_GpuYUVA::MakePromiseYUVATexture(fContext->threadSafeProxy(),
|
return SkImage::MakePromiseYUVATexture(fContext->threadSafeProxy(),
|
||||||
yuvaBackendTextureInfo,
|
backendTextureInfo,
|
||||||
std::move(imageColorSpace),
|
std::move(imageColorSpace),
|
||||||
textureFulfillProc,
|
textureFulfillProc,
|
||||||
textureReleaseProc,
|
textureReleaseProc,
|
||||||
textureContexts);
|
textureContexts);
|
||||||
}
|
}
|
||||||
|
#endif // !SK_MAKE_PROMISE_TEXTURE_DISABLE_LEGACY_API
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include "src/image/SkImage_Gpu.h"
|
#include "src/image/SkImage_Gpu.h"
|
||||||
#endif
|
#endif
|
||||||
#include "include/gpu/GrBackendSurface.h"
|
#include "include/gpu/GrBackendSurface.h"
|
||||||
|
#include "include/gpu/GrContextThreadSafeProxy.h"
|
||||||
|
|
||||||
SkImage::SkImage(const SkImageInfo& info, uint32_t uniqueID)
|
SkImage::SkImage(const SkImageInfo& info, uint32_t uniqueID)
|
||||||
: fInfo(info)
|
: fInfo(info)
|
||||||
@ -590,6 +591,29 @@ sk_sp<SkImage> SkImage::makeTextureImage(GrDirectContext*, GrMipmapped, SkBudget
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sk_sp<SkImage> SkImage::MakePromiseTexture(sk_sp<GrContextThreadSafeProxy>,
|
||||||
|
const GrBackendFormat&,
|
||||||
|
SkISize,
|
||||||
|
GrMipmapped,
|
||||||
|
GrSurfaceOrigin,
|
||||||
|
SkColorType,
|
||||||
|
SkAlphaType,
|
||||||
|
sk_sp<SkColorSpace>,
|
||||||
|
PromiseImageTextureFulfillProc,
|
||||||
|
PromiseImageTextureReleaseProc,
|
||||||
|
PromiseImageTextureContext) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
sk_sp<SkImage> SkImage::MakePromiseYUVATexture(sk_sp<GrContextThreadSafeProxy>,
|
||||||
|
const GrYUVABackendTextureInfo&,
|
||||||
|
sk_sp<SkColorSpace>,
|
||||||
|
PromiseImageTextureFulfillProc,
|
||||||
|
PromiseImageTextureReleaseProc,
|
||||||
|
PromiseImageTextureContext[]) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -374,7 +374,7 @@ sk_sp<SkImage> SkImage::makeTextureImage(GrDirectContext* dContext,
|
|||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
sk_sp<SkImage> SkImage_Gpu::MakePromiseTexture(sk_sp<GrContextThreadSafeProxy> threadSafeProxy,
|
sk_sp<SkImage> SkImage::MakePromiseTexture(sk_sp<GrContextThreadSafeProxy> threadSafeProxy,
|
||||||
const GrBackendFormat& backendFormat,
|
const GrBackendFormat& backendFormat,
|
||||||
SkISize dimensions,
|
SkISize dimensions,
|
||||||
GrMipmapped mipMapped,
|
GrMipmapped mipMapped,
|
||||||
@ -414,7 +414,7 @@ sk_sp<SkImage> SkImage_Gpu::MakePromiseTexture(sk_sp<GrContextThreadSafeProxy> t
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto proxy = MakePromiseImageLazyProxy(threadSafeProxy.get(),
|
auto proxy = SkImage_GpuBase::MakePromiseImageLazyProxy(threadSafeProxy.get(),
|
||||||
dimensions,
|
dimensions,
|
||||||
backendFormat,
|
backendFormat,
|
||||||
mipMapped,
|
mipMapped,
|
||||||
|
@ -76,22 +76,6 @@ public:
|
|||||||
ReadPixelsCallback,
|
ReadPixelsCallback,
|
||||||
ReadPixelsContext) override;
|
ReadPixelsContext) override;
|
||||||
|
|
||||||
/**
|
|
||||||
* This is the implementation of SkDeferredDisplayListRecorder::makePromiseImage.
|
|
||||||
* TODO: Make this public, and remove the SkDDLRecorder entry point.
|
|
||||||
*/
|
|
||||||
static sk_sp<SkImage> MakePromiseTexture(sk_sp<GrContextThreadSafeProxy>,
|
|
||||||
const GrBackendFormat& backendFormat,
|
|
||||||
SkISize dimensions,
|
|
||||||
GrMipmapped mipMapped,
|
|
||||||
GrSurfaceOrigin origin,
|
|
||||||
SkColorType colorType,
|
|
||||||
SkAlphaType alphaType,
|
|
||||||
sk_sp<SkColorSpace> colorSpace,
|
|
||||||
PromiseImageTextureFulfillProc textureFulfillProc,
|
|
||||||
PromiseImageTextureReleaseProc textureReleaseProc,
|
|
||||||
PromiseImageTextureContext textureContext);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::tuple<GrSurfaceProxyView, GrColorType> onAsView(GrRecordingContext*,
|
std::tuple<GrSurfaceProxyView, GrColorType> onAsView(GrRecordingContext*,
|
||||||
GrMipmapped,
|
GrMipmapped,
|
||||||
|
@ -47,20 +47,8 @@ public:
|
|||||||
static bool ValidateCompressedBackendTexture(const GrCaps*, const GrBackendTexture& tex,
|
static bool ValidateCompressedBackendTexture(const GrCaps*, const GrBackendTexture& tex,
|
||||||
SkAlphaType);
|
SkAlphaType);
|
||||||
|
|
||||||
using PromiseImageTextureContext = SkDeferredDisplayListRecorder::PromiseImageTextureContext;
|
// Helper for making a lazy proxy for a promise image.
|
||||||
using PromiseImageTextureFulfillProc =
|
// PromiseImageTextureFulfillProc must not be null.
|
||||||
SkDeferredDisplayListRecorder::PromiseImageTextureFulfillProc;
|
|
||||||
using PromiseImageTextureReleaseProc =
|
|
||||||
SkDeferredDisplayListRecorder::PromiseImageTextureReleaseProc;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
SkImage_GpuBase(sk_sp<GrImageContext>, SkISize size, uint32_t uniqueID, SkColorType,
|
|
||||||
SkAlphaType, sk_sp<SkColorSpace>);
|
|
||||||
|
|
||||||
// Helper for making a lazy proxy for a promise image. The PromiseDoneProc we be called,
|
|
||||||
// if not null, immediately if this function fails. Othwerwise, it is installed in the
|
|
||||||
// proxy along with the TextureFulfillProc and TextureReleaseProc. PromiseDoneProc must not
|
|
||||||
// be null.
|
|
||||||
static sk_sp<GrTextureProxy> MakePromiseImageLazyProxy(GrContextThreadSafeProxy*,
|
static sk_sp<GrTextureProxy> MakePromiseImageLazyProxy(GrContextThreadSafeProxy*,
|
||||||
SkISize dimensions,
|
SkISize dimensions,
|
||||||
GrBackendFormat,
|
GrBackendFormat,
|
||||||
@ -68,6 +56,10 @@ protected:
|
|||||||
PromiseImageTextureFulfillProc,
|
PromiseImageTextureFulfillProc,
|
||||||
sk_sp<GrRefCntedCallback> releaseHelper);
|
sk_sp<GrRefCntedCallback> releaseHelper);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
SkImage_GpuBase(sk_sp<GrImageContext>, SkISize size, uint32_t uniqueID, SkColorType,
|
||||||
|
SkAlphaType, sk_sp<SkColorSpace>);
|
||||||
|
|
||||||
sk_sp<GrImageContext> fContext;
|
sk_sp<GrImageContext> fContext;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -379,19 +379,18 @@ sk_sp<SkImage> SkImage::MakeFromYUVAPixmaps(GrRecordingContext* context,
|
|||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
sk_sp<SkImage> SkImage_GpuYUVA::MakePromiseYUVATexture(
|
sk_sp<SkImage> SkImage::MakePromiseYUVATexture(sk_sp<GrContextThreadSafeProxy> threadSafeProxy,
|
||||||
sk_sp<GrContextThreadSafeProxy> threadSafeProxy,
|
const GrYUVABackendTextureInfo& backendTextureInfo,
|
||||||
const GrYUVABackendTextureInfo& yuvaBackendTextureInfo,
|
|
||||||
sk_sp<SkColorSpace> imageColorSpace,
|
sk_sp<SkColorSpace> imageColorSpace,
|
||||||
PromiseImageTextureFulfillProc textureFulfillProc,
|
PromiseImageTextureFulfillProc textureFulfillProc,
|
||||||
PromiseImageTextureReleaseProc textureReleaseProc,
|
PromiseImageTextureReleaseProc textureReleaseProc,
|
||||||
PromiseImageTextureContext textureContexts[]) {
|
PromiseImageTextureContext textureContexts[]) {
|
||||||
if (!yuvaBackendTextureInfo.isValid()) {
|
if (!backendTextureInfo.isValid()) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
SkISize planeDimensions[SkYUVAInfo::kMaxPlanes];
|
SkISize planeDimensions[SkYUVAInfo::kMaxPlanes];
|
||||||
int n = yuvaBackendTextureInfo.yuvaInfo().planeDimensions(planeDimensions);
|
int n = backendTextureInfo.yuvaInfo().planeDimensions(planeDimensions);
|
||||||
|
|
||||||
// Our contract is that we will always call the release proc even on failure.
|
// Our contract is that we will always call the release proc even on failure.
|
||||||
// We use the helper to convey the context, so we need to ensure make doesn't fail.
|
// We use the helper to convey the context, so we need to ensure make doesn't fail.
|
||||||
@ -405,9 +404,9 @@ sk_sp<SkImage> SkImage_GpuYUVA::MakePromiseYUVATexture(
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
SkAlphaType at = yuvaBackendTextureInfo.yuvaInfo().hasAlpha() ? kPremul_SkAlphaType
|
SkAlphaType at = backendTextureInfo.yuvaInfo().hasAlpha() ? kPremul_SkAlphaType
|
||||||
: kOpaque_SkAlphaType;
|
: kOpaque_SkAlphaType;
|
||||||
SkImageInfo info = SkImageInfo::Make(yuvaBackendTextureInfo.yuvaInfo().dimensions(),
|
SkImageInfo info = SkImageInfo::Make(backendTextureInfo.yuvaInfo().dimensions(),
|
||||||
kAssumedColorType, at, imageColorSpace);
|
kAssumedColorType, at, imageColorSpace);
|
||||||
if (!SkImageInfoIsValid(info)) {
|
if (!SkImageInfoIsValid(info)) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@ -416,9 +415,9 @@ sk_sp<SkImage> SkImage_GpuYUVA::MakePromiseYUVATexture(
|
|||||||
// Make a lazy proxy for each plane and wrap in a view.
|
// Make a lazy proxy for each plane and wrap in a view.
|
||||||
sk_sp<GrSurfaceProxy> proxies[4];
|
sk_sp<GrSurfaceProxy> proxies[4];
|
||||||
for (int i = 0; i < n; ++i) {
|
for (int i = 0; i < n; ++i) {
|
||||||
proxies[i] = MakePromiseImageLazyProxy(threadSafeProxy.get(),
|
proxies[i] = SkImage_GpuBase::MakePromiseImageLazyProxy(threadSafeProxy.get(),
|
||||||
planeDimensions[i],
|
planeDimensions[i],
|
||||||
yuvaBackendTextureInfo.planeFormat(i),
|
backendTextureInfo.planeFormat(i),
|
||||||
GrMipmapped::kNo,
|
GrMipmapped::kNo,
|
||||||
textureFulfillProc,
|
textureFulfillProc,
|
||||||
std::move(releaseHelpers[i]));
|
std::move(releaseHelpers[i]));
|
||||||
@ -426,9 +425,9 @@ sk_sp<SkImage> SkImage_GpuYUVA::MakePromiseYUVATexture(
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GrYUVATextureProxies yuvaTextureProxies(yuvaBackendTextureInfo.yuvaInfo(),
|
GrYUVATextureProxies yuvaTextureProxies(backendTextureInfo.yuvaInfo(),
|
||||||
proxies,
|
proxies,
|
||||||
yuvaBackendTextureInfo.textureOrigin());
|
backendTextureInfo.textureOrigin());
|
||||||
SkASSERT(yuvaTextureProxies.isValid());
|
SkASSERT(yuvaTextureProxies.isValid());
|
||||||
sk_sp<GrImageContext> ctx(GrImageContextPriv::MakeForPromiseImage(std::move(threadSafeProxy)));
|
sk_sp<GrImageContext> ctx(GrImageContextPriv::MakeForPromiseImage(std::move(threadSafeProxy)));
|
||||||
return sk_make_sp<SkImage_GpuYUVA>(std::move(ctx),
|
return sk_make_sp<SkImage_GpuYUVA>(std::move(ctx),
|
||||||
|
@ -63,17 +63,6 @@ public:
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
|
||||||
* This is the implementation of SkDeferredDisplayListRecorder::makeYUVAPromiseTexture.
|
|
||||||
* TODO: Make this public, and remove the SkDDLRecorder entry point.
|
|
||||||
*/
|
|
||||||
static sk_sp<SkImage> MakePromiseYUVATexture(sk_sp<GrContextThreadSafeProxy>,
|
|
||||||
const GrYUVABackendTextureInfo&,
|
|
||||||
sk_sp<SkColorSpace> imageColorSpace,
|
|
||||||
PromiseImageTextureFulfillProc textureFulfillProc,
|
|
||||||
PromiseImageTextureReleaseProc textureReleaseProc,
|
|
||||||
PromiseImageTextureContext textureContexts[]);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SkImage_GpuYUVA(sk_sp<GrImageContext>, const SkImage_GpuYUVA* image, sk_sp<SkColorSpace>);
|
SkImage_GpuYUVA(sk_sp<GrImageContext>, const SkImage_GpuYUVA* image, sk_sp<SkColorSpace>);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user