| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "SampleCode.h" | 8 #include "SampleCode.h" |
| 9 #include "SkAnimTimer.h" | 9 #include "SkAnimTimer.h" |
| 10 #include "SkView.h" | 10 #include "SkView.h" |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 74 | 74 |
| 75 SkRect onGetBounds() override { | 75 SkRect onGetBounds() override { |
| 76 SkRect r(fR); | 76 SkRect r(fR); |
| 77 r.outset(2, 2); | 77 r.outset(2, 2); |
| 78 return r; | 78 return r; |
| 79 } | 79 } |
| 80 }; | 80 }; |
| 81 | 81 |
| 82 public: | 82 public: |
| 83 SkRect fRect; | 83 SkRect fRect; |
| 84 MyDrawable* fAnimatingDrawable; | 84 sk_sp<MyDrawable> fAnimatingDrawable; |
| 85 SkDrawable* fRootDrawable; | 85 sk_sp<SkDrawable> fRootDrawable; |
| 86 | 86 |
| 87 ArcsView() { | 87 ArcsView() { |
| 88 testparse(); | 88 testparse(); |
| 89 fSweep = SkIntToScalar(100); | 89 fSweep = SkIntToScalar(100); |
| 90 this->setBGColor(0xFFDDDDDD); | 90 this->setBGColor(0xFFDDDDDD); |
| 91 | 91 |
| 92 fRect.set(0, 0, SkIntToScalar(200), SkIntToScalar(200)); | 92 fRect.set(0, 0, SkIntToScalar(200), SkIntToScalar(200)); |
| 93 fRect.offset(SkIntToScalar(20), SkIntToScalar(20)); | 93 fRect.offset(SkIntToScalar(20), SkIntToScalar(20)); |
| 94 fAnimatingDrawable = new MyDrawable(fRect); | 94 fAnimatingDrawable = sk_make_sp<MyDrawable>(fRect); |
| 95 | 95 |
| 96 SkPictureRecorder recorder; | 96 SkPictureRecorder recorder; |
| 97 this->drawRoot(recorder.beginRecording(SkRect::MakeWH(800, 500))); | 97 this->drawRoot(recorder.beginRecording(SkRect::MakeWH(800, 500))); |
| 98 fRootDrawable = recorder.endRecordingAsDrawable(); | 98 fRootDrawable = recorder.finishRecordingAsDrawable(); |
| 99 } | |
| 100 | |
| 101 ~ArcsView() override { | |
| 102 fAnimatingDrawable->unref(); | |
| 103 fRootDrawable->unref(); | |
| 104 } | 99 } |
| 105 | 100 |
| 106 protected: | 101 protected: |
| 107 // overrides from SkEventSink | 102 // overrides from SkEventSink |
| 108 bool onQuery(SkEvent* evt) override { | 103 bool onQuery(SkEvent* evt) override { |
| 109 if (SampleCode::TitleQ(*evt)) { | 104 if (SampleCode::TitleQ(*evt)) { |
| 110 SampleCode::TitleR(evt, "Arcs"); | 105 SampleCode::TitleR(evt, "Arcs"); |
| 111 return true; | 106 return true; |
| 112 } | 107 } |
| 113 return this->INHERITED::onQuery(evt); | 108 return this->INHERITED::onQuery(evt); |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 179 } | 174 } |
| 180 | 175 |
| 181 void drawRoot(SkCanvas* canvas) { | 176 void drawRoot(SkCanvas* canvas) { |
| 182 SkPaint paint; | 177 SkPaint paint; |
| 183 paint.setAntiAlias(true); | 178 paint.setAntiAlias(true); |
| 184 paint.setStrokeWidth(SkIntToScalar(2)); | 179 paint.setStrokeWidth(SkIntToScalar(2)); |
| 185 paint.setStyle(SkPaint::kStroke_Style); | 180 paint.setStyle(SkPaint::kStroke_Style); |
| 186 | 181 |
| 187 DrawRectWithLines(canvas, fRect, paint); | 182 DrawRectWithLines(canvas, fRect, paint); |
| 188 | 183 |
| 189 canvas->drawDrawable(fAnimatingDrawable); | 184 canvas->drawDrawable(fAnimatingDrawable.get()); |
| 190 | 185 |
| 191 DrawArcs(canvas); | 186 DrawArcs(canvas); |
| 192 } | 187 } |
| 193 | 188 |
| 194 void onDrawContent(SkCanvas* canvas) override { | 189 void onDrawContent(SkCanvas* canvas) override { |
| 195 canvas->drawDrawable(fRootDrawable); | 190 canvas->drawDrawable(fRootDrawable.get()); |
| 196 } | 191 } |
| 197 | 192 |
| 198 bool onAnimate(const SkAnimTimer& timer) override { | 193 bool onAnimate(const SkAnimTimer& timer) override { |
| 199 SkScalar angle = SkDoubleToScalar(fmod(timer.secs() * 360 / 24, 360)); | 194 SkScalar angle = SkDoubleToScalar(fmod(timer.secs() * 360 / 24, 360)); |
| 200 fAnimatingDrawable->setSweep(angle); | 195 fAnimatingDrawable->setSweep(angle); |
| 201 return true; | 196 return true; |
| 202 } | 197 } |
| 203 | 198 |
| 204 SkView::Click* onFindClickHandler(SkScalar x, SkScalar y, unsigned modi) ove
rride { | 199 SkView::Click* onFindClickHandler(SkScalar x, SkScalar y, unsigned modi) ove
rride { |
| 205 // fSweep += SK_Scalar1; | 200 // fSweep += SK_Scalar1; |
| 206 this->inval(nullptr); | 201 this->inval(nullptr); |
| 207 return this->INHERITED::onFindClickHandler(x, y, modi); | 202 return this->INHERITED::onFindClickHandler(x, y, modi); |
| 208 } | 203 } |
| 209 | 204 |
| 210 private: | 205 private: |
| 211 SkScalar fSweep; | 206 SkScalar fSweep; |
| 212 | 207 |
| 213 typedef SampleView INHERITED; | 208 typedef SampleView INHERITED; |
| 214 }; | 209 }; |
| 215 | 210 |
| 216 ////////////////////////////////////////////////////////////////////////////// | 211 ////////////////////////////////////////////////////////////////////////////// |
| 217 | 212 |
| 218 static SkView* MyFactory() { return new ArcsView; } | 213 static SkView* MyFactory() { return new ArcsView; } |
| 219 static SkViewRegister reg(MyFactory); | 214 static SkViewRegister reg(MyFactory); |
| OLD | NEW |