blob: b87f8961749e9bd22278bf697e50e2828bb35d1f [file] [log] [blame]
reed@google.com4384fab2012-06-05 16:14:23 +00001/*
2 * Copyright 2012 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "gm.h"
9#include "SkCanvas.h"
10#include "SkPaint.h"
11#include "SkGradientShader.h"
12
13static void intToScalars(SkScalar dst[], const int src[], int n) {
14 for (int i = 0; i < n; ++i) {
15 dst[i] = SkIntToScalar(src[i]);
16 }
17}
18
19static void drawGrad(SkCanvas* canvas, const SkScalar d0[], const SkScalar d1[]) {
20 SkPoint c0 = { d0[0], d0[1] };
21 SkScalar r0 = d0[2];
22 SkPoint c1 = { d1[0], d1[1] };
23 SkScalar r1 = d1[2];
24
25 SkColor colors[] = { SK_ColorGREEN, SK_ColorRED };
26 SkPaint paint;
27 paint.setAntiAlias(true);
28 paint.setShader(SkGradientShader::CreateTwoPointRadial(c0, r0, c1, r1,
29 colors, NULL, 2,
30 SkShader::kClamp_TileMode))->unref();
31 canvas->drawRect(SkRect::MakeXYWH(SkIntToScalar(-50),
32 SkIntToScalar(-50),
33 SkIntToScalar(200),
34 SkIntToScalar(100)), paint);
35
36 paint.setShader(NULL);
37 paint.setStyle(SkPaint::kStroke_Style);
38 canvas->drawCircle(c0.fX, c0.fY, r0, paint);
39 canvas->drawCircle(c1.fX, c1.fY, r1, paint);
40}
41
42class TwoPointRadialGM : public skiagm::GM {
43public:
44 TwoPointRadialGM() {}
45
46protected:
47 SkString onShortName() {
48 return SkString("two_point_radial");
49 }
50
51 SkISize onISize() { return skiagm::make_isize(480, 725); }
52
reed@google.com070a8002012-06-05 17:15:30 +000053 // BUG: PDF code (at least on mac) fails when we run this
54 virtual uint32_t onGetFlags() const SK_OVERRIDE { return kSkipPDF_Flag; }
55
reed@google.com4384fab2012-06-05 16:14:23 +000056 virtual void onDraw(SkCanvas* canvas) {
57 if (false) {
58 SkPaint paint;
59 paint.setColor(SK_ColorBLUE);
60 canvas->drawRect(SkRect::MakeWH(this->getISize().fWidth, this->getISize().fHeight), paint);
61 }
62 SkPaint paint;
63 const int R0 = 20;
64 const int R1 = 40;
65
66 const SkScalar DX = SkIntToScalar(250);
67 const SkScalar DY = SkIntToScalar(120);
68
69 canvas->translate(SkIntToScalar(60), SkIntToScalar(60));
70
71 static const int gData[] = {
72 0, 0, R0, 0, 0, R1,
73 0, 0, R0, 25, 0, R1,
74 0, 0, R0, 100, 0, R1,
75 0, 0, R0, 0, 0, R0,
76 0, 0, R0, 25, 0, R0,
77 0, 0, R0, 100, 0, R0,
78 };
79
80 int count = SK_ARRAY_COUNT(gData) / 6;
81 for (int i = 0; i < count; ++i) {
82 SkScalar data[6];
83 intToScalars(data, &gData[i * 6], 6);
84
85 int n = canvas->save();
86 drawGrad(canvas, &data[0], &data[3]);
87 canvas->translate(DX, 0);
88 drawGrad(canvas, &data[3], &data[0]);
89 canvas->restoreToCount(n);
90 canvas->translate(0, DY);
91 }
92 }
93};
94
95//////////////////////////////////////////////////////////////////////////////
96
97static skiagm::GM* F(void*) { return new TwoPointRadialGM; }
98
99static skiagm::GMRegistry gR(F);
100