2 * Copyright 2012 Google Inc.
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
11 #include "SkGradientShader.h"
13 static void intToScalars(SkScalar dst[], const int src[], int n) {
14 for (int i = 0; i < n; ++i) {
15 dst[i] = SkIntToScalar(src[i]);
19 static void drawGrad(SkCanvas* canvas, const SkScalar d0[], const SkScalar d1[]) {
20 const SkRect bounds = SkRect::MakeXYWH(SkIntToScalar(-50),
25 SkPoint c0 = { d0[0], d0[1] };
27 SkPoint c1 = { d1[0], d1[1] };
30 SkColor colors[] = { SK_ColorGREEN, SK_ColorRED };
32 paint.setAntiAlias(true);
33 sk_tool_utils::set_portable_typeface(&paint);
36 str.printf("%g,%g,%g %g,%g,%g",
37 SkScalarToFloat(c0.fX), SkScalarToFloat(c0.fY), SkScalarToFloat(r0),
38 SkScalarToFloat(c1.fX), SkScalarToFloat(c1.fY), SkScalarToFloat(r1));
39 canvas->drawText(str.c_str(), str.size(),
40 bounds.fLeft, bounds.fTop - paint.getTextSize()/2, paint);
42 paint.setShader(SkGradientShader::CreateTwoPointConical(c0, r0, c1, r1,
44 SkShader::kClamp_TileMode))->unref();
45 canvas->drawRect(bounds, paint);
47 paint.setShader(NULL);
48 paint.setColor(0x66000000);
49 paint.setStyle(SkPaint::kStroke_Style);
50 canvas->drawCircle(c0.fX, c0.fY, r0, paint);
51 canvas->drawCircle(c1.fX, c1.fY, r1, paint);
52 canvas->drawRect(bounds, paint);
55 class TwoPointRadialGM : public skiagm::GM {
60 SkString onShortName() {
61 return SkString("twopointconical");
64 SkISize onISize() { return SkISize::Make(480, 780); }
66 virtual void onDraw(SkCanvas* canvas) {
69 paint.setColor(SK_ColorBLUE);
71 SkRect::MakeWH(SkIntToScalar(this->getISize().fWidth),
72 SkIntToScalar(this->getISize().fHeight)),
79 const SkScalar DX = SkIntToScalar(250);
80 const SkScalar DY = SkIntToScalar(130);
82 canvas->translate(SkIntToScalar(60), SkIntToScalar(70));
84 static const int gData[] = {
93 int count = SK_ARRAY_COUNT(gData) / 6;
94 for (int i = 0; i < count; ++i) {
96 intToScalars(data, &gData[i * 6], 6);
98 int n = canvas->save();
99 drawGrad(canvas, &data[0], &data[3]);
100 canvas->translate(DX, 0);
101 drawGrad(canvas, &data[3], &data[0]);
102 canvas->restoreToCount(n);
103 canvas->translate(0, DY);
108 //////////////////////////////////////////////////////////////////////////////
110 static skiagm::GM* F(void*) { return new TwoPointRadialGM; }
112 static skiagm::GMRegistry gR(F);