Add GM that exercises SkCanvas::discard()
R=robertphillips@google.com Author: bsalomon@google.com Review URL: https://codereview.chromium.org/252443007 git-svn-id: http://skia.googlecode.com/svn/trunk@14365 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
parent
d0306a1593
commit
04f03d1fad
95
gm/discard.cpp
Normal file
95
gm/discard.cpp
Normal file
@ -0,0 +1,95 @@
|
||||
/*
|
||||
* Copyright 2014 Google Inc.
|
||||
*
|
||||
* Use of this source code is governed by a BSD-style license that can be
|
||||
* found in the LICENSE file.
|
||||
*/
|
||||
|
||||
#if SK_SUPPORT_GPU
|
||||
|
||||
#include "gm.h"
|
||||
#include "SkCanvas.h"
|
||||
#include "SkColorShader.h"
|
||||
#include "SkPaint.h"
|
||||
#include "SkSurface.h"
|
||||
|
||||
namespace skiagm {
|
||||
|
||||
/*
|
||||
* This GM exercises SkCanvas::discard() by creating an offscreen SkSurface and repeatedly
|
||||
* discarding it, drawing to it, and then drawing it to the main canvas.
|
||||
*/
|
||||
class DiscardGM : public GM {
|
||||
|
||||
public:
|
||||
DiscardGM() {
|
||||
}
|
||||
|
||||
virtual uint32_t onGetFlags() const SK_OVERRIDE { return kGPUOnly_Flag; }
|
||||
|
||||
protected:
|
||||
virtual SkString onShortName() SK_OVERRIDE {
|
||||
return SkString("discard");
|
||||
}
|
||||
|
||||
virtual SkISize onISize() SK_OVERRIDE {
|
||||
return SkISize::Make(100, 100);
|
||||
}
|
||||
|
||||
virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
|
||||
GrContext* context = canvas->getGrContext();
|
||||
if (NULL == context) {
|
||||
return;
|
||||
}
|
||||
|
||||
SkISize size = this->getISize();
|
||||
size.fWidth /= 10;
|
||||
size.fHeight /= 10;
|
||||
SkImageInfo info = SkImageInfo::MakeN32Premul(size);
|
||||
SkSurface* surface = SkSurface::NewRenderTarget(context, info);
|
||||
|
||||
if (NULL == surface) {
|
||||
return;
|
||||
}
|
||||
|
||||
canvas->clear(SK_ColorBLACK);
|
||||
|
||||
SkRandom rand;
|
||||
for (int x = 0; x < 10; ++x) {
|
||||
for (int y = 0; y < 10; ++y) {
|
||||
surface->getCanvas()->discard();
|
||||
// Make something that isn't too close to the background color, black.
|
||||
SkColor color = rand.nextU() | 0xFF404040;
|
||||
switch (rand.nextULessThan(3)) {
|
||||
case 0:
|
||||
surface->getCanvas()->drawColor(color);
|
||||
break;
|
||||
case 1:
|
||||
surface->getCanvas()->clear(color);
|
||||
break;
|
||||
case 2:
|
||||
SkColorShader shader(color);
|
||||
SkPaint paint;
|
||||
paint.setShader(&shader);
|
||||
surface->getCanvas()->drawPaint(paint);
|
||||
break;
|
||||
}
|
||||
surface->draw(canvas, 10*x, 10*y, NULL);
|
||||
}
|
||||
}
|
||||
|
||||
surface->getCanvas()->discard();
|
||||
surface->unref();
|
||||
}
|
||||
|
||||
private:
|
||||
typedef GM INHERITED;
|
||||
};
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
DEF_GM( return SkNEW(DiscardGM); )
|
||||
|
||||
} // end namespace
|
||||
|
||||
#endif
|
@ -56,6 +56,7 @@
|
||||
'../gm/cubicpaths.cpp',
|
||||
'../gm/cmykjpeg.cpp',
|
||||
'../gm/degeneratesegments.cpp',
|
||||
'../gm/discard.cpp',
|
||||
'../gm/dashcubics.cpp',
|
||||
'../gm/dashing.cpp',
|
||||
'../gm/deviceproperties.cpp',
|
||||
|
Loading…
Reference in New Issue
Block a user