Revert "Add unit test for SkDeferredDisplayLists"
This reverts commit 8458a2807b
.
Reason for revert: ??
Original change's description:
> Add unit test for SkDeferredDisplayLists
>
> Change-Id: I015094145cb0af6cfe368c570a5d5280c11c8f28
> Reviewed-on: https://skia-review.googlesource.com/78660
> Reviewed-by: Brian Salomon <bsalomon@google.com>
> Commit-Queue: Robert Phillips <robertphillips@google.com>
TBR=egdaniel@google.com,bsalomon@google.com,robertphillips@google.com
Change-Id: Iec3abb18d3ed41fcfbec72bc2de14603f659f8ce
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Reviewed-on: https://skia-review.googlesource.com/79720
Reviewed-by: Robert Phillips <robertphillips@google.com>
Commit-Queue: Robert Phillips <robertphillips@google.com>
This commit is contained in:
parent
3e794595fd
commit
8172c0a24a
@ -47,9 +47,8 @@ tests_sources = [
|
|||||||
"$_tests/CTest.cpp",
|
"$_tests/CTest.cpp",
|
||||||
"$_tests/DashPathEffectTest.cpp",
|
"$_tests/DashPathEffectTest.cpp",
|
||||||
"$_tests/DataRefTest.cpp",
|
"$_tests/DataRefTest.cpp",
|
||||||
"$_tests/DefaultPathRendererTest.cpp",
|
|
||||||
"$_tests/DeferredDisplayListTest.cpp",
|
|
||||||
"$_tests/DequeTest.cpp",
|
"$_tests/DequeTest.cpp",
|
||||||
|
"$_tests/DefaultPathRendererTest.cpp",
|
||||||
"$_tests/DetermineDomainModeTest.cpp",
|
"$_tests/DetermineDomainModeTest.cpp",
|
||||||
"$_tests/DeviceLooperTest.cpp",
|
"$_tests/DeviceLooperTest.cpp",
|
||||||
"$_tests/DeviceTest.cpp",
|
"$_tests/DeviceTest.cpp",
|
||||||
|
@ -362,7 +362,7 @@ public:
|
|||||||
* The draw will be skipped if the characterization stored in the display list
|
* The draw will be skipped if the characterization stored in the display list
|
||||||
* isn't compatible with this surface.
|
* isn't compatible with this surface.
|
||||||
*/
|
*/
|
||||||
bool draw(SkDeferredDisplayList* deferredDisplayList);
|
void draw(SkDeferredDisplayList* deferredDisplayList);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
SkSurface(int width, int height, const SkSurfaceProps* surfaceProps);
|
SkSurface(int width, int height, const SkSurfaceProps* surfaceProps);
|
||||||
|
@ -32,7 +32,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO: remove this. It is just scaffolding to get something up & running
|
// TODO: remove this. It is just scaffolding to get something up & running
|
||||||
bool draw(SkSurface*);
|
void draw(SkSurface*);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const SkSurfaceCharacterization fCharacterization;
|
const SkSurfaceCharacterization fCharacterization;
|
||||||
|
@ -11,7 +11,6 @@
|
|||||||
#include "GrTypes.h"
|
#include "GrTypes.h"
|
||||||
|
|
||||||
#if SK_SUPPORT_GPU
|
#if SK_SUPPORT_GPU
|
||||||
#include "GrTypesPriv.h"
|
|
||||||
#include "SkSurfaceProps.h"
|
#include "SkSurfaceProps.h"
|
||||||
|
|
||||||
class GrContextThreadSafeProxy;
|
class GrContextThreadSafeProxy;
|
||||||
@ -22,7 +21,7 @@ class SkColorSpace;
|
|||||||
rendering decisions. When passed into a SkDeferredDisplayListRecorder it will copy the
|
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
|
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
|
those objects (the Recorder and the DisplayList) will take a ref on the
|
||||||
GrContextThreadSafeProxy and SkColorSpace objects.
|
GrContextThreadSafeProxy object.
|
||||||
*/
|
*/
|
||||||
class SkSurfaceCharacterization {
|
class SkSurfaceCharacterization {
|
||||||
public:
|
public:
|
||||||
@ -31,8 +30,7 @@ public:
|
|||||||
, fWidth(0)
|
, fWidth(0)
|
||||||
, fHeight(0)
|
, fHeight(0)
|
||||||
, fConfig(kUnknown_GrPixelConfig)
|
, fConfig(kUnknown_GrPixelConfig)
|
||||||
, fFSAAType(GrFSAAType::kNone)
|
, fSampleCnt(0)
|
||||||
, fStencilCnt(0)
|
|
||||||
, fSurfaceProps(0, kUnknown_SkPixelGeometry) {
|
, fSurfaceProps(0, kUnknown_SkPixelGeometry) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,8 +45,7 @@ public:
|
|||||||
int width() const { return fWidth; }
|
int width() const { return fWidth; }
|
||||||
int height() const { return fHeight; }
|
int height() const { return fHeight; }
|
||||||
GrPixelConfig config() const { return fConfig; }
|
GrPixelConfig config() const { return fConfig; }
|
||||||
GrFSAAType fsaaType() const { return fFSAAType; }
|
int sampleCount() const { return fSampleCnt; }
|
||||||
int stencilCount() const { return fStencilCnt; }
|
|
||||||
SkColorSpace* colorSpace() const { return fColorSpace.get(); }
|
SkColorSpace* colorSpace() const { return fColorSpace.get(); }
|
||||||
sk_sp<SkColorSpace> refColorSpace() const { return fColorSpace; }
|
sk_sp<SkColorSpace> refColorSpace() const { return fColorSpace; }
|
||||||
const SkSurfaceProps& surfaceProps()const { return fSurfaceProps; }
|
const SkSurfaceProps& surfaceProps()const { return fSurfaceProps; }
|
||||||
@ -60,8 +57,7 @@ private:
|
|||||||
GrSurfaceOrigin origin,
|
GrSurfaceOrigin origin,
|
||||||
int width, int height,
|
int width, int height,
|
||||||
GrPixelConfig config,
|
GrPixelConfig config,
|
||||||
GrFSAAType fsaaType,
|
int sampleCnt,
|
||||||
int stencilCnt,
|
|
||||||
sk_sp<SkColorSpace> colorSpace,
|
sk_sp<SkColorSpace> colorSpace,
|
||||||
const SkSurfaceProps& surfaceProps) {
|
const SkSurfaceProps& surfaceProps) {
|
||||||
fContextInfo = contextInfo;
|
fContextInfo = contextInfo;
|
||||||
@ -69,8 +65,7 @@ private:
|
|||||||
fWidth = width;
|
fWidth = width;
|
||||||
fHeight = height;
|
fHeight = height;
|
||||||
fConfig = config;
|
fConfig = config;
|
||||||
fFSAAType = fsaaType;
|
fSampleCnt = sampleCnt;
|
||||||
fStencilCnt = stencilCnt;
|
|
||||||
fColorSpace = std::move(colorSpace);
|
fColorSpace = std::move(colorSpace);
|
||||||
fSurfaceProps = surfaceProps;
|
fSurfaceProps = surfaceProps;
|
||||||
}
|
}
|
||||||
@ -80,8 +75,7 @@ private:
|
|||||||
int fWidth;
|
int fWidth;
|
||||||
int fHeight;
|
int fHeight;
|
||||||
GrPixelConfig fConfig;
|
GrPixelConfig fConfig;
|
||||||
GrFSAAType fFSAAType;
|
int fSampleCnt;
|
||||||
int fStencilCnt;
|
|
||||||
sk_sp<SkColorSpace> fColorSpace;
|
sk_sp<SkColorSpace> fColorSpace;
|
||||||
SkSurfaceProps fSurfaceProps;
|
SkSurfaceProps fSurfaceProps;
|
||||||
};
|
};
|
||||||
|
@ -43,7 +43,6 @@ std::unique_ptr<SkDeferredDisplayList> SkDeferredDisplayListRecorder::detach() {
|
|||||||
|
|
||||||
// Placeholder. Ultimately, the SkSurface_Gpu will pass the wrapped opLists to its
|
// Placeholder. Ultimately, the SkSurface_Gpu will pass the wrapped opLists to its
|
||||||
// renderTargetContext.
|
// renderTargetContext.
|
||||||
bool SkDeferredDisplayList::draw(SkSurface* surface) {
|
void SkDeferredDisplayList::draw(SkSurface* surface) {
|
||||||
surface->getCanvas()->drawImage(fImage.get(), 0, 0);
|
surface->getCanvas()->drawImage(fImage.get(), 0, 0);
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
@ -213,7 +213,7 @@ bool SkSurface::characterize(SkSurfaceCharacterization* characterization) const
|
|||||||
return asSB(const_cast<SkSurface*>(this))->onCharacterize(characterization);
|
return asSB(const_cast<SkSurface*>(this))->onCharacterize(characterization);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkSurface::draw(SkDeferredDisplayList* ddl) {
|
void SkSurface::draw(SkDeferredDisplayList* ddl) {
|
||||||
return asSB(this)->onDraw(ddl);
|
return asSB(this)->onDraw(ddl);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,7 +95,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
virtual bool onCharacterize(SkSurfaceCharacterization*) const { return false; }
|
virtual bool onCharacterize(SkSurfaceCharacterization*) const { return false; }
|
||||||
virtual bool onDraw(SkDeferredDisplayList*) { return false; }
|
virtual void onDraw(SkDeferredDisplayList*) { }
|
||||||
|
|
||||||
inline SkCanvas* getCachedCanvas();
|
inline SkCanvas* getCachedCanvas();
|
||||||
inline sk_sp<SkImage> refCachedImage();
|
inline sk_sp<SkImage> refCachedImage();
|
||||||
|
@ -165,7 +165,7 @@ bool SkSurface_Gpu::onCharacterize(SkSurfaceCharacterization* data) const {
|
|||||||
GrContext* ctx = fDevice->context();
|
GrContext* ctx = fDevice->context();
|
||||||
|
|
||||||
data->set(ctx->threadSafeProxy(), rtc->origin(), rtc->width(), rtc->height(),
|
data->set(ctx->threadSafeProxy(), rtc->origin(), rtc->width(), rtc->height(),
|
||||||
rtc->colorSpaceInfo().config(), rtc->fsaaType(), rtc->numStencilSamples(),
|
rtc->colorSpaceInfo().config(), rtc->numColorSamples(),
|
||||||
rtc->colorSpaceInfo().refColorSpace(), this->props());
|
rtc->colorSpaceInfo().refColorSpace(), this->props());
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -178,19 +178,19 @@ bool SkSurface_Gpu::isCompatible(const SkSurfaceCharacterization& data) const {
|
|||||||
return data.contextInfo() && data.contextInfo()->matches(ctx) &&
|
return data.contextInfo() && data.contextInfo()->matches(ctx) &&
|
||||||
data.origin() == rtc->origin() && data.width() == rtc->width() &&
|
data.origin() == rtc->origin() && data.width() == rtc->width() &&
|
||||||
data.height() == rtc->height() && data.config() == rtc->colorSpaceInfo().config() &&
|
data.height() == rtc->height() && data.config() == rtc->colorSpaceInfo().config() &&
|
||||||
data.fsaaType() == rtc->fsaaType() && data.stencilCount() == rtc->numStencilSamples() &&
|
data.sampleCount() == rtc->numColorSamples() &&
|
||||||
SkColorSpace::Equals(data.colorSpace(), rtc->colorSpaceInfo().colorSpace()) &&
|
SkColorSpace::Equals(data.colorSpace(), rtc->colorSpaceInfo().colorSpace()) &&
|
||||||
data.surfaceProps() == rtc->surfaceProps();
|
data.surfaceProps() == rtc->surfaceProps();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkSurface_Gpu::onDraw(SkDeferredDisplayList* dl) {
|
void SkSurface_Gpu::onDraw(SkDeferredDisplayList* dl) {
|
||||||
if (!this->isCompatible(dl->characterization())) {
|
if (!this->isCompatible(dl->characterization())) {
|
||||||
return false;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ultimately need to pass opLists from the DeferredDisplayList on to the
|
// Ultimately need to pass opLists from the DeferredDisplayList on to the
|
||||||
// SkGpuDevice's renderTargetContext.
|
// SkGpuDevice's renderTargetContext.
|
||||||
return dl->draw(this);
|
dl->draw(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ public:
|
|||||||
bool onWait(int numSemaphores, const GrBackendSemaphore* waitSemaphores) override;
|
bool onWait(int numSemaphores, const GrBackendSemaphore* waitSemaphores) override;
|
||||||
bool onCharacterize(SkSurfaceCharacterization*) const override;
|
bool onCharacterize(SkSurfaceCharacterization*) const override;
|
||||||
bool isCompatible(const SkSurfaceCharacterization&) const;
|
bool isCompatible(const SkSurfaceCharacterization&) const;
|
||||||
bool onDraw(SkDeferredDisplayList*) override;
|
void onDraw(SkDeferredDisplayList*) override;
|
||||||
|
|
||||||
SkGpuDevice* getDevice() { return fDevice.get(); }
|
SkGpuDevice* getDevice() { return fDevice.get(); }
|
||||||
|
|
||||||
|
@ -1,142 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2017 Google Inc.
|
|
||||||
*
|
|
||||||
* Use of this source code is governed by a BSD-style license that can be
|
|
||||||
* found in the LICENSE file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "SkTypes.h"
|
|
||||||
|
|
||||||
#if SK_SUPPORT_GPU
|
|
||||||
|
|
||||||
#include "SkCanvas.h"
|
|
||||||
#include "SkDeferredDisplayListRecorder.h"
|
|
||||||
#include "SkGpuDevice.h"
|
|
||||||
#include "SkSurface.h"
|
|
||||||
#include "SkSurface_Gpu.h"
|
|
||||||
#include "SkSurfaceCharacterization.h"
|
|
||||||
#include "SkSurfaceProps.h"
|
|
||||||
#include "Test.h"
|
|
||||||
|
|
||||||
class SurfaceParameters {
|
|
||||||
public:
|
|
||||||
static const int kNumParams = 8;
|
|
||||||
static const int kSampleCount = 5;
|
|
||||||
|
|
||||||
SurfaceParameters()
|
|
||||||
: fWidth(64)
|
|
||||||
, fHeight(64)
|
|
||||||
, fOrigin(kTopLeft_GrSurfaceOrigin)
|
|
||||||
, fColorType(kRGBA_8888_SkColorType)
|
|
||||||
, fColorSpace(SkColorSpace::MakeSRGB())
|
|
||||||
, fSampleCount(0)
|
|
||||||
, fSurfaceProps(0x0, kUnknown_SkPixelGeometry) {
|
|
||||||
}
|
|
||||||
|
|
||||||
int sampleCount() const { return fSampleCount; }
|
|
||||||
|
|
||||||
// Modify the SurfaceParameters in just one way
|
|
||||||
void modify(int i) {
|
|
||||||
switch (i) {
|
|
||||||
case 0:
|
|
||||||
fWidth = 63;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
fHeight = 63;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
fOrigin = kBottomLeft_GrSurfaceOrigin;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
fColorType = kRGBA_F16_SkColorType;
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
fColorSpace = SkColorSpace::MakeSRGBLinear();
|
|
||||||
break;
|
|
||||||
case kSampleCount:
|
|
||||||
fSampleCount = 4;
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
fSurfaceProps = SkSurfaceProps(0x0, kRGB_H_SkPixelGeometry);
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
fSurfaceProps = SkSurfaceProps(SkSurfaceProps::kUseDeviceIndependentFonts_Flag,
|
|
||||||
kUnknown_SkPixelGeometry);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create the surface with the current set of parameters
|
|
||||||
sk_sp<SkSurface> make(GrContext* context) const {
|
|
||||||
// Note that Ganesh doesn't make use of the SkImageInfo's alphaType
|
|
||||||
SkImageInfo ii = SkImageInfo::Make(fWidth, fHeight, fColorType,
|
|
||||||
kPremul_SkAlphaType, fColorSpace);
|
|
||||||
|
|
||||||
return SkSurface::MakeRenderTarget(context, SkBudgeted::kYes, ii, fSampleCount,
|
|
||||||
fOrigin, &fSurfaceProps);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
int fWidth;
|
|
||||||
int fHeight;
|
|
||||||
GrSurfaceOrigin fOrigin;
|
|
||||||
SkColorType fColorType;
|
|
||||||
sk_sp<SkColorSpace> fColorSpace;
|
|
||||||
int fSampleCount;
|
|
||||||
SkSurfaceProps fSurfaceProps;
|
|
||||||
};
|
|
||||||
|
|
||||||
// This tests SkSurfaceCharacterization/SkSurface compatibility
|
|
||||||
DEF_GPUTEST_FOR_ALL_CONTEXTS(SkSurfaceCharacterization, reporter, ctxInfo) {
|
|
||||||
GrContext* context = ctxInfo.grContext();
|
|
||||||
|
|
||||||
std::unique_ptr<SkDeferredDisplayList> ddl;
|
|
||||||
|
|
||||||
// First, create a DDL using the stock SkSurface parameters
|
|
||||||
{
|
|
||||||
SurfaceParameters params;
|
|
||||||
|
|
||||||
sk_sp<SkSurface> s = params.make(context);
|
|
||||||
if (!s) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
SkSurfaceCharacterization c;
|
|
||||||
SkAssertResult(s->characterize(&c));
|
|
||||||
|
|
||||||
SkDeferredDisplayListRecorder r(c);
|
|
||||||
SkCanvas* canvas = r.getCanvas();
|
|
||||||
canvas->drawRect(SkRect::MakeXYWH(10, 10, 10, 10), SkPaint());
|
|
||||||
ddl = r.detach();
|
|
||||||
|
|
||||||
REPORTER_ASSERT(reporter, s->draw(ddl.get()));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Then, alter each parameter in turn and check that the DDL & surface are incompatible
|
|
||||||
for (int i = 0; i < SurfaceParameters::kNumParams; ++i) {
|
|
||||||
SurfaceParameters params;
|
|
||||||
params.modify(i);
|
|
||||||
|
|
||||||
sk_sp<SkSurface> s = params.make(context);
|
|
||||||
if (!s) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (SurfaceParameters::kSampleCount == i) {
|
|
||||||
SkSurface_Gpu* gpuSurf = static_cast<SkSurface_Gpu*>(s.get());
|
|
||||||
|
|
||||||
int supportedSampleCount = context->caps()->getSampleCount(
|
|
||||||
params.sampleCount(),
|
|
||||||
gpuSurf->getDevice()->accessRenderTargetContext()->asRenderTargetProxy()->config());
|
|
||||||
if (0 == supportedSampleCount) {
|
|
||||||
// If changing the sample count won't result in a different
|
|
||||||
// surface characterization, skip this step
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
REPORTER_ASSERT(reporter, !s->draw(ddl.get()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
Loading…
Reference in New Issue
Block a user