Add new roundrect GM
R=bsalomon@google.com Author: jvanverth@google.com Review URL: https://chromiumcodereview.appspot.com/14348022 git-svn-id: http://skia.googlecode.com/svn/trunk@8806 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
parent
e49d67edd5
commit
a534b84237
339
gm/roundrects.cpp
Normal file
339
gm/roundrects.cpp
Normal file
@ -0,0 +1,339 @@
|
||||
|
||||
/*
|
||||
* Copyright 2013 Google Inc.
|
||||
*
|
||||
* Use of this source code is governed by a BSD-style license that can be
|
||||
* found in the LICENSE file.
|
||||
*/
|
||||
|
||||
#include "gm.h"
|
||||
#include "SkTArray.h"
|
||||
#include "SkRandom.h"
|
||||
#include "SkMatrix.h"
|
||||
#include "SkBlurMaskFilter.h"
|
||||
#include "SkGradientShader.h"
|
||||
#include "SkBlurDrawLooper.h"
|
||||
#include "SkRect.h"
|
||||
#include "SkRRect.h"
|
||||
|
||||
namespace skiagm {
|
||||
|
||||
class RoundRectGM : public GM {
|
||||
public:
|
||||
RoundRectGM() {
|
||||
this->setBGColor(0xFF000000);
|
||||
this->makePaints();
|
||||
this->makeMatrices();
|
||||
}
|
||||
|
||||
protected:
|
||||
virtual SkString onShortName() SK_OVERRIDE {
|
||||
return SkString("roundrects");
|
||||
}
|
||||
|
||||
virtual SkISize onISize() SK_OVERRIDE {
|
||||
return make_isize(1200, 900);
|
||||
}
|
||||
|
||||
void makePaints() {
|
||||
{
|
||||
// no AA
|
||||
SkPaint p;
|
||||
fPaints.push_back(p);
|
||||
}
|
||||
|
||||
{
|
||||
// AA
|
||||
SkPaint p;
|
||||
p.setAntiAlias(true);
|
||||
fPaints.push_back(p);
|
||||
}
|
||||
|
||||
{
|
||||
// AA with stroke style
|
||||
SkPaint p;
|
||||
p.setAntiAlias(true);
|
||||
p.setStyle(SkPaint::kStroke_Style);
|
||||
p.setStrokeWidth(SkIntToScalar(5));
|
||||
fPaints.push_back(p);
|
||||
}
|
||||
|
||||
{
|
||||
// AA with stroke style, width = 0
|
||||
SkPaint p;
|
||||
p.setAntiAlias(true);
|
||||
p.setStyle(SkPaint::kStroke_Style);
|
||||
fPaints.push_back(p);
|
||||
}
|
||||
|
||||
{
|
||||
// AA with stroke and fill style
|
||||
SkPaint p;
|
||||
p.setAntiAlias(true);
|
||||
p.setStyle(SkPaint::kStrokeAndFill_Style);
|
||||
p.setStrokeWidth(SkIntToScalar(3));
|
||||
fPaints.push_back(p);
|
||||
}
|
||||
}
|
||||
|
||||
void makeMatrices() {
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setIdentity();
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setScale(SkIntToScalar(3), SkIntToScalar(2));
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setScale(SkIntToScalar(2), SkIntToScalar(2));
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setScale(SkIntToScalar(1), SkIntToScalar(2));
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setScale(SkIntToScalar(4), SkIntToScalar(1));
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setRotate(SkIntToScalar(90));
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setSkew(SkIntToScalar(2), SkIntToScalar(3));
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
|
||||
{
|
||||
SkMatrix m;
|
||||
m.setRotate(SkIntToScalar(60));
|
||||
fMatrices.push_back(m);
|
||||
}
|
||||
}
|
||||
|
||||
SkColor genColor(SkMWCRandom* rand) {
|
||||
SkScalar hsv[3];
|
||||
hsv[0] = SkFloatToScalar(rand->nextRangeF(0.0f, 360.0f));
|
||||
hsv[1] = SkFloatToScalar(rand->nextRangeF(0.75f, 1.0f));
|
||||
hsv[2] = SkFloatToScalar(rand->nextRangeF(0.75f, 1.0f));
|
||||
|
||||
return SkHSVToColor(hsv);
|
||||
}
|
||||
|
||||
virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
|
||||
SkMWCRandom rand(1);
|
||||
canvas->translate(20 * SK_Scalar1, 20 * SK_Scalar1);
|
||||
SkRect rect = SkRect::MakeLTRB(-20, -30, 20, 30);
|
||||
SkRRect circleRect;
|
||||
circleRect.setRectXY(rect, 5, 5);
|
||||
|
||||
const SkScalar kXStart = 60.0f;
|
||||
const SkScalar kYStart = 80.0f;
|
||||
const int kXStep = 150;
|
||||
const int kYStep = 160;
|
||||
int maxX = fMatrices.count();
|
||||
|
||||
SkPaint rectPaint;
|
||||
rectPaint.setAntiAlias(true);
|
||||
rectPaint.setStyle(SkPaint::kStroke_Style);
|
||||
rectPaint.setStrokeWidth(SkIntToScalar(0));
|
||||
rectPaint.setColor(SK_ColorLTGRAY);
|
||||
|
||||
int testCount = 0;
|
||||
for (int i = 0; i < fPaints.count(); ++i) {
|
||||
for (int j = 0; j < fMatrices.count(); ++j) {
|
||||
canvas->save();
|
||||
SkMatrix mat = fMatrices[j];
|
||||
// position the roundrect, and make it at off-integer coords.
|
||||
mat.postTranslate(kXStart + SK_Scalar1 * kXStep * (testCount % maxX) +
|
||||
SK_Scalar1 / 4,
|
||||
kYStart + SK_Scalar1 * kYStep * (testCount / maxX) +
|
||||
3 * SK_Scalar1 / 4);
|
||||
canvas->concat(mat);
|
||||
|
||||
SkColor color = genColor(&rand);
|
||||
fPaints[i].setColor(color);
|
||||
|
||||
canvas->drawRect(rect, rectPaint);
|
||||
canvas->drawRRect(circleRect, fPaints[i]);
|
||||
|
||||
canvas->restore();
|
||||
|
||||
++testCount;
|
||||
}
|
||||
}
|
||||
|
||||
// special cases
|
||||
|
||||
// non-scaled tall and skinny roundrect
|
||||
for (int i = 0; i < fPaints.count(); ++i) {
|
||||
SkRect rect = SkRect::MakeLTRB(-20, -60, 20, 60);
|
||||
SkRRect ellipseRect;
|
||||
ellipseRect.setRectXY(rect, 5, 10);
|
||||
|
||||
canvas->save();
|
||||
// position the roundrect, and make it at off-integer coords.
|
||||
canvas->translate(kXStart + SK_Scalar1 * kXStep * 2.55f + SK_Scalar1 / 4,
|
||||
kYStart + SK_Scalar1 * kYStep * i + 3 * SK_Scalar1 / 4);
|
||||
|
||||
SkColor color = genColor(&rand);
|
||||
fPaints[i].setColor(color);
|
||||
|
||||
canvas->drawRect(rect, rectPaint);
|
||||
canvas->drawRRect(ellipseRect, fPaints[i]);
|
||||
canvas->restore();
|
||||
}
|
||||
|
||||
// non-scaled wide and short roundrect
|
||||
for (int i = 0; i < fPaints.count(); ++i) {
|
||||
SkRect rect = SkRect::MakeLTRB(-80, -30, 80, 30);
|
||||
SkRRect ellipseRect;
|
||||
ellipseRect.setRectXY(rect, 20, 5);
|
||||
|
||||
canvas->save();
|
||||
// position the roundrect, and make it at off-integer coords.
|
||||
canvas->translate(kXStart + SK_Scalar1 * kXStep * 4 + SK_Scalar1 / 4,
|
||||
kYStart + SK_Scalar1 * kYStep * i + 3 * SK_Scalar1 / 4 +
|
||||
SK_ScalarHalf * kYStep);
|
||||
|
||||
SkColor color = genColor(&rand);
|
||||
fPaints[i].setColor(color);
|
||||
|
||||
canvas->drawRect(rect, rectPaint);
|
||||
canvas->drawRRect(ellipseRect, fPaints[i]);
|
||||
canvas->restore();
|
||||
}
|
||||
|
||||
// super skinny roundrect
|
||||
for (int i = 0; i < fPaints.count(); ++i) {
|
||||
SkRect rect = SkRect::MakeLTRB(0, -60, 1, 60);
|
||||
SkRRect circleRect;
|
||||
circleRect.setRectXY(rect, 5, 5);
|
||||
|
||||
canvas->save();
|
||||
// position the roundrect, and make it at off-integer coords.
|
||||
canvas->translate(kXStart + SK_Scalar1 * kXStep * 3.25f + SK_Scalar1 / 4,
|
||||
kYStart + SK_Scalar1 * kYStep * i + 3 * SK_Scalar1 / 4);
|
||||
|
||||
SkColor color = genColor(&rand);
|
||||
fPaints[i].setColor(color);
|
||||
|
||||
canvas->drawRRect(circleRect, fPaints[i]);
|
||||
canvas->restore();
|
||||
}
|
||||
|
||||
// super short roundrect
|
||||
for (int i = 0; i < fPaints.count(); ++i) {
|
||||
SkRect rect = SkRect::MakeLTRB(-80, -1, 80, 0);
|
||||
SkRRect circleRect;
|
||||
circleRect.setRectXY(rect, 5, 5);
|
||||
|
||||
canvas->save();
|
||||
// position the roundrect, and make it at off-integer coords.
|
||||
canvas->translate(kXStart + SK_Scalar1 * kXStep * 2.5f + SK_Scalar1 / 4,
|
||||
kYStart + SK_Scalar1 * kYStep * i + 3 * SK_Scalar1 / 4 +
|
||||
SK_ScalarHalf * kYStep);
|
||||
|
||||
SkColor color = genColor(&rand);
|
||||
fPaints[i].setColor(color);
|
||||
|
||||
canvas->drawRRect(circleRect, fPaints[i]);
|
||||
canvas->restore();
|
||||
}
|
||||
|
||||
// radial gradient
|
||||
SkPoint center = SkPoint::Make(SkIntToScalar(0), SkIntToScalar(0));
|
||||
SkColor colors[] = { SK_ColorBLUE, SK_ColorRED, SK_ColorGREEN };
|
||||
SkScalar pos[] = { 0, SK_ScalarHalf, SK_Scalar1 };
|
||||
SkAutoTUnref<SkShader> shader(SkGradientShader::CreateRadial(center,
|
||||
SkIntToScalar(20),
|
||||
colors,
|
||||
pos,
|
||||
SK_ARRAY_COUNT(colors),
|
||||
SkShader::kClamp_TileMode));
|
||||
|
||||
for (int i = 0; i < fPaints.count(); ++i) {
|
||||
canvas->save();
|
||||
// position the path, and make it at off-integer coords.
|
||||
canvas->translate(kXStart + SK_Scalar1 * kXStep * 0 + SK_Scalar1 / 4,
|
||||
kYStart + SK_Scalar1 * kYStep * i + 3 * SK_Scalar1 / 4 +
|
||||
SK_ScalarHalf * kYStep);
|
||||
|
||||
SkColor color = genColor(&rand);
|
||||
fPaints[i].setColor(color);
|
||||
fPaints[i].setShader(shader);
|
||||
|
||||
canvas->drawRect(rect, rectPaint);
|
||||
canvas->drawRRect(circleRect, fPaints[i]);
|
||||
|
||||
fPaints[i].setShader(NULL);
|
||||
|
||||
canvas->restore();
|
||||
}
|
||||
|
||||
// strokes and radii
|
||||
{
|
||||
SkScalar radii[][2] = {
|
||||
{10,10},
|
||||
{5,15},
|
||||
{5,15},
|
||||
{5,15}
|
||||
};
|
||||
|
||||
SkScalar strokeWidths[] = {
|
||||
20, 10, 20, 40
|
||||
};
|
||||
|
||||
for (int i = 0; i < 4; ++i) {
|
||||
SkRRect circleRect;
|
||||
circleRect.setRectXY(rect, radii[i][0], radii[i][1]);
|
||||
|
||||
canvas->save();
|
||||
// position the roundrect, and make it at off-integer coords.
|
||||
canvas->translate(kXStart + SK_Scalar1 * kXStep * 5 + SK_Scalar1 / 4,
|
||||
kYStart + SK_Scalar1 * kYStep * i + 3 * SK_Scalar1 / 4 +
|
||||
SK_ScalarHalf * kYStep);
|
||||
|
||||
SkColor color = genColor(&rand);
|
||||
|
||||
SkPaint p;
|
||||
p.setAntiAlias(true);
|
||||
p.setStyle(SkPaint::kStroke_Style);
|
||||
p.setStrokeWidth(strokeWidths[i]);
|
||||
p.setColor(color);
|
||||
|
||||
canvas->drawRRect(circleRect, p);
|
||||
canvas->restore();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private:
|
||||
SkTArray<SkPaint> fPaints;
|
||||
SkTArray<SkMatrix> fMatrices;
|
||||
|
||||
typedef GM INHERITED;
|
||||
};
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
static GM* MyFactory(void*) { return new RoundRectGM; }
|
||||
static GMRegistry reg(MyFactory);
|
||||
|
||||
}
|
@ -78,6 +78,7 @@
|
||||
'../gm/rects.cpp',
|
||||
'../gm/rrect.cpp',
|
||||
'../gm/rrects.cpp',
|
||||
'../gm/roundrects.cpp',
|
||||
'../gm/samplerstress.cpp',
|
||||
'../gm/shaderbounds.cpp',
|
||||
'../gm/selftest.cpp',
|
||||
|
Loading…
Reference in New Issue
Block a user