blob: d8b21b2f2e291cdd10305b67e882eaf4cca4145d [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
mike@reedtribe.orgf2c21cd2011-06-18 00:15:04 +00002/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00003 * Copyright 2011 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
mike@reedtribe.orgf2c21cd2011-06-18 00:15:04 +00007 */
8
9
epoger@google.comec3ed6a2011-07-28 14:26:00 +000010
mike@reedtribe.orgf2c21cd2011-06-18 00:15:04 +000011#include "gm.h"
12#include "SkRandom.h"
13
14namespace skiagm {
15
16#define W 400
17#define H 400
18#define N 50
19
20static const SkScalar SW = SkIntToScalar(W);
21static const SkScalar SH = SkIntToScalar(H);
22
23static void rnd_rect(SkRect* r, SkPaint* paint, SkRandom& rand) {
24 SkScalar x = rand.nextUScalar1() * W;
25 SkScalar y = rand.nextUScalar1() * H;
26 SkScalar w = rand.nextUScalar1() * (W >> 2);
27 SkScalar h = rand.nextUScalar1() * (H >> 2);
epoger@google.com17b78942011-08-26 14:40:38 +000028 SkScalar hoffset = rand.nextSScalar1();
29 SkScalar woffset = rand.nextSScalar1();
mike@reedtribe.orgf2c21cd2011-06-18 00:15:04 +000030
31 r->set(x, y, x + w, y + h);
epoger@google.com17b78942011-08-26 14:40:38 +000032 r->offset(-w/2 + woffset, -h/2 + hoffset);
mike@reedtribe.orgf2c21cd2011-06-18 00:15:04 +000033
34 paint->setColor(rand.nextU());
35 paint->setAlpha(0xFF);
36}
37
38
39class StrokesGM : public GM {
40public:
41 StrokesGM() {}
42
43protected:
44 virtual SkString onShortName() {
45 return SkString("strokes_round");
46 }
47
48 virtual SkISize onISize() {
49 return make_isize(W, H*2);
50 }
51
52 virtual void onDraw(SkCanvas* canvas) {
53 canvas->drawColor(SK_ColorWHITE);
54
55 SkPaint paint;
56 paint.setStyle(SkPaint::kStroke_Style);
57 paint.setStrokeWidth(SkIntToScalar(9)/2);
58
59 for (int y = 0; y < 2; y++) {
60 paint.setAntiAlias(!!y);
61 SkAutoCanvasRestore acr(canvas, true);
62 canvas->translate(0, SH * y);
63 canvas->clipRect(SkRect::MakeLTRB(
64 SkIntToScalar(2), SkIntToScalar(2)
65 , SW - SkIntToScalar(2), SH - SkIntToScalar(2)
66 ));
67
68 SkRandom rand;
69 for (int i = 0; i < N; i++) {
70 SkRect r;
71 rnd_rect(&r, &paint, rand);
72 canvas->drawOval(r, paint);
73 rnd_rect(&r, &paint, rand);
74 canvas->drawRoundRect(r, r.width()/4, r.height()/4, paint);
75 rnd_rect(&r, &paint, rand);
76 }
77 }
78 }
79
80private:
81 typedef GM INHERITED;
82};
83
84class Strokes2GM : public GM {
85 SkPath fPath;
86public:
87 Strokes2GM() {
88 SkRandom rand;
89 fPath.moveTo(0, 0);
90 for (int i = 0; i < 13; i++) {
91 SkScalar x = rand.nextUScalar1() * (W >> 1);
92 SkScalar y = rand.nextUScalar1() * (H >> 1);
93 fPath.lineTo(x, y);
94 }
95 }
96
97protected:
98 virtual SkString onShortName() {
99 return SkString("strokes_poly");
100 }
101
102 virtual SkISize onISize() {
103 return make_isize(W, H*2);
104 }
105
106 static void rotate(SkScalar angle, SkScalar px, SkScalar py, SkCanvas* canvas) {
107 SkMatrix matrix;
108 matrix.setRotate(angle, px, py);
109 canvas->concat(matrix);
110 }
111
112 virtual void onDraw(SkCanvas* canvas) {
113 canvas->drawColor(SK_ColorWHITE);
114
115 SkPaint paint;
116 paint.setStyle(SkPaint::kStroke_Style);
117 paint.setStrokeWidth(SkIntToScalar(9)/2);
118
119 for (int y = 0; y < 2; y++) {
120 paint.setAntiAlias(!!y);
121 SkAutoCanvasRestore acr(canvas, true);
122 canvas->translate(0, SH * y);
123 canvas->clipRect(SkRect::MakeLTRB(SkIntToScalar(2),
124 SkIntToScalar(2),
125 SW - SkIntToScalar(2),
126 SH - SkIntToScalar(2)));
127
128 SkRandom rand;
129 for (int i = 0; i < N/2; i++) {
130 SkRect r;
131 rnd_rect(&r, &paint, rand);
132 rotate(SkIntToScalar(15), SW/2, SH/2, canvas);
133 canvas->drawPath(fPath, paint);
134 }
135 }
136 }
137
138private:
139 typedef GM INHERITED;
140};
141
142//////////////////////////////////////////////////////////////////////////////
143
144static GM* MyFactory(void*) { return new StrokesGM; }
145static GMRegistry reg(MyFactory);
146
147static GM* MyFactory2(void*) { return new Strokes2GM; }
148static GMRegistry reg2(MyFactory2);
149
150}
151