aboutsummaryrefslogtreecommitdiffhomepage
path: root/gm
diff options
context:
space:
mode:
authorGravatar commit-bot@chromium.org <commit-bot@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2013-04-22 18:05:19 +0000
committerGravatar commit-bot@chromium.org <commit-bot@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2013-04-22 18:05:19 +0000
commita534b84237ae492e70078238f8a3f6fd0b162b79 (patch)
tree21af5456b6527ee2cd6b75d2ae03ca65d1c26a68 /gm
parente49d67edd5ac1789b235eb51aeed558a85a7f628 (diff)
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
Diffstat (limited to 'gm')
-rw-r--r--gm/roundrects.cpp339
1 files changed, 339 insertions, 0 deletions
diff --git a/gm/roundrects.cpp b/gm/roundrects.cpp
new file mode 100644
index 0000000000..a5b4858cb9
--- /dev/null
+++ b/gm/roundrects.cpp
@@ -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);
+
+}