You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
255 lines
10 KiB
255 lines
10 KiB
4 months ago
|
/*
|
||
|
* Copyright 2017 Google Inc.
|
||
|
*
|
||
|
* Use of this source code is governed by a BSD-style license that can be
|
||
|
* found in the LICENSE file.
|
||
|
*/
|
||
|
|
||
|
#ifndef SkSurfaceCharacterization_DEFINED
|
||
|
#define SkSurfaceCharacterization_DEFINED
|
||
|
|
||
|
#include "include/gpu/GrTypes.h"
|
||
|
|
||
|
#include "include/core/SkColorSpace.h"
|
||
|
#include "include/core/SkImageInfo.h"
|
||
|
#include "include/core/SkRefCnt.h"
|
||
|
#include "include/core/SkSurfaceProps.h"
|
||
|
|
||
|
class SkColorSpace;
|
||
|
|
||
|
#include "include/gpu/GrBackendSurface.h"
|
||
|
|
||
|
#if SK_SUPPORT_GPU
|
||
|
#include "include/gpu/GrContextThreadSafeProxy.h"
|
||
|
|
||
|
/** \class SkSurfaceCharacterization
|
||
|
A surface characterization contains all the information Ganesh requires to makes its internal
|
||
|
rendering decisions. When passed into a SkDeferredDisplayListRecorder it will copy the
|
||
|
data and pass it on to the SkDeferredDisplayList if/when it is created. Note that both of
|
||
|
those objects (the Recorder and the DisplayList) will take a ref on the
|
||
|
GrContextThreadSafeProxy and SkColorSpace objects.
|
||
|
*/
|
||
|
class SK_API SkSurfaceCharacterization {
|
||
|
public:
|
||
|
enum class Textureable : bool { kNo = false, kYes = true };
|
||
|
enum class MipMapped : bool { kNo = false, kYes = true };
|
||
|
enum class UsesGLFBO0 : bool { kNo = false, kYes = true };
|
||
|
// This flag indicates that the backing VkImage for this Vulkan surface will have the
|
||
|
// VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT set. This bit allows skia to handle advanced blends
|
||
|
// more optimally in a shader by being able to directly read the dst values.
|
||
|
enum class VkRTSupportsInputAttachment : bool { kNo = false, kYes = true };
|
||
|
// This flag indicates if the surface is wrapping a raw Vulkan secondary command buffer.
|
||
|
enum class VulkanSecondaryCBCompatible : bool { kNo = false, kYes = true };
|
||
|
|
||
|
SkSurfaceCharacterization()
|
||
|
: fCacheMaxResourceBytes(0)
|
||
|
, fOrigin(kBottomLeft_GrSurfaceOrigin)
|
||
|
, fSampleCnt(0)
|
||
|
, fIsTextureable(Textureable::kYes)
|
||
|
, fIsMipMapped(MipMapped::kYes)
|
||
|
, fUsesGLFBO0(UsesGLFBO0::kNo)
|
||
|
, fVulkanSecondaryCBCompatible(VulkanSecondaryCBCompatible::kNo)
|
||
|
, fIsProtected(GrProtected::kNo)
|
||
|
, fSurfaceProps(0, kUnknown_SkPixelGeometry) {
|
||
|
}
|
||
|
|
||
|
SkSurfaceCharacterization(SkSurfaceCharacterization&&) = default;
|
||
|
SkSurfaceCharacterization& operator=(SkSurfaceCharacterization&&) = default;
|
||
|
|
||
|
SkSurfaceCharacterization(const SkSurfaceCharacterization&) = default;
|
||
|
SkSurfaceCharacterization& operator=(const SkSurfaceCharacterization& other) = default;
|
||
|
bool operator==(const SkSurfaceCharacterization& other) const;
|
||
|
bool operator!=(const SkSurfaceCharacterization& other) const {
|
||
|
return !(*this == other);
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* Return a new surface characterization with the only difference being a different width
|
||
|
* and height
|
||
|
*/
|
||
|
SkSurfaceCharacterization createResized(int width, int height) const;
|
||
|
|
||
|
/*
|
||
|
* Return a new surface characterization with only a replaced color space
|
||
|
*/
|
||
|
SkSurfaceCharacterization createColorSpace(sk_sp<SkColorSpace>) const;
|
||
|
|
||
|
/*
|
||
|
* Return a new surface characterization with the backend format replaced. A colorType
|
||
|
* must also be supplied to indicate the interpretation of the new format.
|
||
|
*/
|
||
|
SkSurfaceCharacterization createBackendFormat(SkColorType colorType,
|
||
|
const GrBackendFormat& backendFormat) const;
|
||
|
|
||
|
/*
|
||
|
* Return a new surface characterization with just a different use of FBO0 (in GL)
|
||
|
*/
|
||
|
SkSurfaceCharacterization createFBO0(bool usesGLFBO0) const;
|
||
|
|
||
|
GrContextThreadSafeProxy* contextInfo() const { return fContextInfo.get(); }
|
||
|
sk_sp<GrContextThreadSafeProxy> refContextInfo() const { return fContextInfo; }
|
||
|
size_t cacheMaxResourceBytes() const { return fCacheMaxResourceBytes; }
|
||
|
|
||
|
bool isValid() const { return kUnknown_SkColorType != fImageInfo.colorType(); }
|
||
|
|
||
|
const SkImageInfo& imageInfo() const { return fImageInfo; }
|
||
|
const GrBackendFormat& backendFormat() const { return fBackendFormat; }
|
||
|
GrSurfaceOrigin origin() const { return fOrigin; }
|
||
|
SkISize dimensions() const { return fImageInfo.dimensions(); }
|
||
|
int width() const { return fImageInfo.width(); }
|
||
|
int height() const { return fImageInfo.height(); }
|
||
|
SkColorType colorType() const { return fImageInfo.colorType(); }
|
||
|
int sampleCount() const { return fSampleCnt; }
|
||
|
bool isTextureable() const { return Textureable::kYes == fIsTextureable; }
|
||
|
bool isMipMapped() const { return MipMapped::kYes == fIsMipMapped; }
|
||
|
bool usesGLFBO0() const { return UsesGLFBO0::kYes == fUsesGLFBO0; }
|
||
|
bool vkRTSupportsInputAttachment() const {
|
||
|
return VkRTSupportsInputAttachment::kYes == fVkRTSupportsInputAttachment;
|
||
|
}
|
||
|
bool vulkanSecondaryCBCompatible() const {
|
||
|
return VulkanSecondaryCBCompatible::kYes == fVulkanSecondaryCBCompatible;
|
||
|
}
|
||
|
GrProtected isProtected() const { return fIsProtected; }
|
||
|
SkColorSpace* colorSpace() const { return fImageInfo.colorSpace(); }
|
||
|
sk_sp<SkColorSpace> refColorSpace() const { return fImageInfo.refColorSpace(); }
|
||
|
const SkSurfaceProps& surfaceProps()const { return fSurfaceProps; }
|
||
|
|
||
|
// Is the provided backend texture compatible with this surface characterization?
|
||
|
bool isCompatible(const GrBackendTexture&) const;
|
||
|
|
||
|
private:
|
||
|
friend class SkSurface_Gpu; // for 'set' & 'config'
|
||
|
friend class GrVkSecondaryCBDrawContext; // for 'set' & 'config'
|
||
|
friend class GrContextThreadSafeProxy; // for private ctor
|
||
|
friend class SkDeferredDisplayListRecorder; // for 'config'
|
||
|
friend class SkSurface; // for 'config'
|
||
|
|
||
|
SkDEBUGCODE(void validate() const;)
|
||
|
|
||
|
SkSurfaceCharacterization(sk_sp<GrContextThreadSafeProxy> contextInfo,
|
||
|
size_t cacheMaxResourceBytes,
|
||
|
const SkImageInfo& ii,
|
||
|
const GrBackendFormat& backendFormat,
|
||
|
GrSurfaceOrigin origin,
|
||
|
int sampleCnt,
|
||
|
Textureable isTextureable,
|
||
|
MipMapped isMipMapped,
|
||
|
UsesGLFBO0 usesGLFBO0,
|
||
|
VkRTSupportsInputAttachment vkRTSupportsInputAttachment,
|
||
|
VulkanSecondaryCBCompatible vulkanSecondaryCBCompatible,
|
||
|
GrProtected isProtected,
|
||
|
const SkSurfaceProps& surfaceProps)
|
||
|
: fContextInfo(std::move(contextInfo))
|
||
|
, fCacheMaxResourceBytes(cacheMaxResourceBytes)
|
||
|
, fImageInfo(ii)
|
||
|
, fBackendFormat(backendFormat)
|
||
|
, fOrigin(origin)
|
||
|
, fSampleCnt(sampleCnt)
|
||
|
, fIsTextureable(isTextureable)
|
||
|
, fIsMipMapped(isMipMapped)
|
||
|
, fUsesGLFBO0(usesGLFBO0)
|
||
|
, fVkRTSupportsInputAttachment(vkRTSupportsInputAttachment)
|
||
|
, fVulkanSecondaryCBCompatible(vulkanSecondaryCBCompatible)
|
||
|
, fIsProtected(isProtected)
|
||
|
, fSurfaceProps(surfaceProps) {
|
||
|
SkDEBUGCODE(this->validate());
|
||
|
}
|
||
|
|
||
|
void set(sk_sp<GrContextThreadSafeProxy> contextInfo,
|
||
|
size_t cacheMaxResourceBytes,
|
||
|
const SkImageInfo& ii,
|
||
|
const GrBackendFormat& backendFormat,
|
||
|
GrSurfaceOrigin origin,
|
||
|
int sampleCnt,
|
||
|
Textureable isTextureable,
|
||
|
MipMapped isMipMapped,
|
||
|
UsesGLFBO0 usesGLFBO0,
|
||
|
VkRTSupportsInputAttachment vkRTSupportsInputAttachment,
|
||
|
VulkanSecondaryCBCompatible vulkanSecondaryCBCompatible,
|
||
|
GrProtected isProtected,
|
||
|
const SkSurfaceProps& surfaceProps) {
|
||
|
fContextInfo = contextInfo;
|
||
|
fCacheMaxResourceBytes = cacheMaxResourceBytes;
|
||
|
|
||
|
fImageInfo = ii;
|
||
|
fBackendFormat = backendFormat;
|
||
|
fOrigin = origin;
|
||
|
fSampleCnt = sampleCnt;
|
||
|
fIsTextureable = isTextureable;
|
||
|
fIsMipMapped = isMipMapped;
|
||
|
fUsesGLFBO0 = usesGLFBO0;
|
||
|
fVkRTSupportsInputAttachment = vkRTSupportsInputAttachment;
|
||
|
fVulkanSecondaryCBCompatible = vulkanSecondaryCBCompatible;
|
||
|
fIsProtected = isProtected;
|
||
|
fSurfaceProps = surfaceProps;
|
||
|
|
||
|
SkDEBUGCODE(this->validate());
|
||
|
}
|
||
|
|
||
|
sk_sp<GrContextThreadSafeProxy> fContextInfo;
|
||
|
size_t fCacheMaxResourceBytes;
|
||
|
|
||
|
SkImageInfo fImageInfo;
|
||
|
GrBackendFormat fBackendFormat;
|
||
|
GrSurfaceOrigin fOrigin;
|
||
|
int fSampleCnt;
|
||
|
Textureable fIsTextureable;
|
||
|
MipMapped fIsMipMapped;
|
||
|
UsesGLFBO0 fUsesGLFBO0;
|
||
|
VkRTSupportsInputAttachment fVkRTSupportsInputAttachment;
|
||
|
VulkanSecondaryCBCompatible fVulkanSecondaryCBCompatible;
|
||
|
GrProtected fIsProtected;
|
||
|
SkSurfaceProps fSurfaceProps;
|
||
|
};
|
||
|
|
||
|
#else// !SK_SUPPORT_GPU
|
||
|
|
||
|
class SK_API SkSurfaceCharacterization {
|
||
|
public:
|
||
|
SkSurfaceCharacterization() : fSurfaceProps(0, kUnknown_SkPixelGeometry) { }
|
||
|
|
||
|
SkSurfaceCharacterization createResized(int width, int height) const {
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
SkSurfaceCharacterization createColorSpace(sk_sp<SkColorSpace>) const {
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
SkSurfaceCharacterization createBackendFormat(SkColorType, const GrBackendFormat&) const {
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
SkSurfaceCharacterization createFBO0(bool usesGLFBO0) const {
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
bool operator==(const SkSurfaceCharacterization& other) const { return false; }
|
||
|
bool operator!=(const SkSurfaceCharacterization& other) const {
|
||
|
return !(*this == other);
|
||
|
}
|
||
|
|
||
|
size_t cacheMaxResourceBytes() const { return 0; }
|
||
|
|
||
|
bool isValid() const { return false; }
|
||
|
|
||
|
int width() const { return 0; }
|
||
|
int height() const { return 0; }
|
||
|
int stencilCount() const { return 0; }
|
||
|
bool isTextureable() const { return false; }
|
||
|
bool isMipMapped() const { return false; }
|
||
|
bool usesGLFBO0() const { return false; }
|
||
|
bool vkRTSupportsAttachmentInput() const { return false; }
|
||
|
bool vulkanSecondaryCBCompatible() const { return false; }
|
||
|
SkColorSpace* colorSpace() const { return nullptr; }
|
||
|
sk_sp<SkColorSpace> refColorSpace() const { return nullptr; }
|
||
|
const SkSurfaceProps& surfaceProps()const { return fSurfaceProps; }
|
||
|
|
||
|
private:
|
||
|
SkSurfaceProps fSurfaceProps;
|
||
|
};
|
||
|
|
||
|
#endif
|
||
|
|
||
|
#endif
|