blob: d04cd263598f321f16cfaf86f65b2ccca1e64695 [file] [log] [blame]
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +00001/*
2 * Copyright 2013 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 "SkTArray.h"
11
reedd1bd1d72014-12-31 20:07:01 -080012class ConicPathsGM : public skiagm::GM {
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000013protected:
14
reedd1bd1d72014-12-31 20:07:01 -080015 SkString onShortName() SK_OVERRIDE {
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000016 return SkString("conicpaths");
17 }
18
reedd1bd1d72014-12-31 20:07:01 -080019 SkISize onISize() SK_OVERRIDE {
reed40c85e42015-01-05 10:01:25 -080020 return SkISize::Make(920, 960);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000021 }
22
reedd1bd1d72014-12-31 20:07:01 -080023 void onOnceBeforeDraw() SK_OVERRIDE {
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000024 {
reedd1bd1d72014-12-31 20:07:01 -080025 const SkScalar w = SkScalarSqrt(2)/2;
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000026 SkPath* conicCirlce = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080027 conicCirlce->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080028 conicCirlce->conicTo(0, 50, 50, 50, w);
29 conicCirlce->rConicTo(50, 0, 50, -50, w);
30 conicCirlce->rConicTo(0, -50, -50, -50, w);
31 conicCirlce->rConicTo(-50, 0, -50, 50, w);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000032
33 }
34 {
35 SkPath* hyperbola = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080036 hyperbola->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080037 hyperbola->conicTo(0, 100, 100, 100, 2);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000038 }
39 {
40 SkPath* thinHyperbola = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080041 thinHyperbola->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080042 thinHyperbola->conicTo(100, 100, 5, 0, 2);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000043 }
44 {
45 SkPath* veryThinHyperbola = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080046 veryThinHyperbola->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080047 veryThinHyperbola->conicTo(100, 100, 1, 0, 2);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000048 }
49 {
50 SkPath* closedHyperbola = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080051 closedHyperbola->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080052 closedHyperbola->conicTo(100, 100, 0, 0, 2);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000053 }
54 {
55 // using 1 as weight defaults to using quadTo
56 SkPath* nearParabola = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080057 nearParabola->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080058 nearParabola->conicTo(0, 100, 100, 100, 0.999f);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000059 }
60 {
61 SkPath* thinEllipse = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080062 thinEllipse->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080063 thinEllipse->conicTo(100, 100, 5, 0, SK_ScalarHalf);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000064 }
65 {
66 SkPath* veryThinEllipse = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080067 veryThinEllipse->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080068 veryThinEllipse->conicTo(100, 100, 1, 0, SK_ScalarHalf);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000069 }
70 {
71 SkPath* closedEllipse = &fPaths.push_back();
reed40c85e42015-01-05 10:01:25 -080072 closedEllipse->moveTo(0, 0);
reedd1bd1d72014-12-31 20:07:01 -080073 closedEllipse->conicTo(100, 100, 0, 0, SK_ScalarHalf);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000074 }
75 }
76
reedd1bd1d72014-12-31 20:07:01 -080077 void onDraw(SkCanvas* canvas) SK_OVERRIDE {
78 const SkAlpha kAlphaValue[] = { 0xFF, 0x40 };
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000079
reedd1bd1d72014-12-31 20:07:01 -080080 const SkScalar margin = 15;
81 canvas->translate(margin, margin);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000082
reed40c85e42015-01-05 10:01:25 -080083 SkPaint paint;
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000084 for (int p = 0; p < fPaths.count(); ++p) {
reed40c85e42015-01-05 10:01:25 -080085 canvas->save();
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000086 for (size_t a = 0; a < SK_ARRAY_COUNT(kAlphaValue); ++a) {
reed40c85e42015-01-05 10:01:25 -080087 paint.setARGB(kAlphaValue[a], 0, 0, 0);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000088 for (int aa = 0; aa < 2; ++aa) {
reed40c85e42015-01-05 10:01:25 -080089 paint.setAntiAlias(SkToBool(aa));
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000090 for (int fh = 0; fh < 2; ++fh) {
reed40c85e42015-01-05 10:01:25 -080091 paint.setStyle(fh ? SkPaint::kStroke_Style : SkPaint::kFill_Style);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000092
93 const SkRect& bounds = fPaths[p].getBounds();
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +000094 canvas->save();
95 canvas->translate(-bounds.fLeft, -bounds.fTop);
96 canvas->drawPath(fPaths[p], paint);
97 canvas->restore();
98
reed40c85e42015-01-05 10:01:25 -080099 canvas->translate(110, 0);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +0000100 }
101 }
102 }
reed40c85e42015-01-05 10:01:25 -0800103 canvas->restore();
104 canvas->translate(0, 110);
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +0000105 }
106 canvas->restore();
107 }
108
reedd1bd1d72014-12-31 20:07:01 -0800109 uint32_t onGetFlags() const SK_OVERRIDE {
reed40c85e42015-01-05 10:01:25 -0800110 // tiling w/ non-antialias paths can cause off-by-1-pixels differences which are
111 // unavoidable (chopping in floats -vs- stepping in scan-converter).
112 return kSkipTiled_Flag;
reed@google.comc464cbd2013-06-20 17:37:24 +0000113 }
114
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +0000115private:
116 SkTArray<SkPath> fPaths;
reedd1bd1d72014-12-31 20:07:01 -0800117 typedef skiagm::GM INHERITED;
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +0000118};
reedd1bd1d72014-12-31 20:07:01 -0800119DEF_GM( return SkNEW(ConicPathsGM); )
egdaniel@google.comdef9f6e2013-06-20 16:54:31 +0000120
121//////////////////////////////////////////////////////////////////////////////
122