| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 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 "gm.h" | 8 #include "gm.h" |
| 9 #include "SkBlurMask.h" | 9 #include "SkBlurMask.h" |
| 10 #include "SkBlurMaskFilter.h" | 10 #include "SkBlurMaskFilter.h" |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 } | 24 } |
| 25 | 25 |
| 26 SkISize onISize() override { | 26 SkISize onISize() override { |
| 27 return SkISize::Make(950, 950); | 27 return SkISize::Make(950, 950); |
| 28 } | 28 } |
| 29 | 29 |
| 30 void onOnceBeforeDraw() override { | 30 void onOnceBeforeDraw() override { |
| 31 const float blurRadii[kNumBlurs] = { 1,5,10,20 }; | 31 const float blurRadii[kNumBlurs] = { 1,5,10,20 }; |
| 32 | 32 |
| 33 for (int i = 0; i < kNumBlurs; ++i) { | 33 for (int i = 0; i < kNumBlurs; ++i) { |
| 34 fBlurFilters[i].reset(SkBlurMaskFilter::Create( | 34 fBlurFilters[i] = SkBlurMaskFilter::Make( |
| 35 kNormal_SkBlurStyle, | 35 kNormal_SkBlurStyle, |
| 36 SkBlurMask::ConvertRadiusToSigma(SkIntToScal
ar(blurRadii[i])), | 36 SkBlurMask::ConvertRadiusToSigma(SkIntToScal
ar(blurRadii[i])), |
| 37 SkBlurMaskFilter::kHighQuality_BlurFlag)); | 37 SkBlurMaskFilter::kHighQuality_BlurFlag); |
| 38 } | 38 } |
| 39 } | 39 } |
| 40 | 40 |
| 41 void onDraw(SkCanvas* canvas) override { | 41 void onDraw(SkCanvas* canvas) override { |
| 42 canvas->scale(1.5f, 1.5f); | 42 canvas->scale(1.5f, 1.5f); |
| 43 canvas->translate(50,50); | 43 canvas->translate(50,50); |
| 44 | 44 |
| 45 const int circleRadii[] = { 5,10,25,50 }; | 45 const int circleRadii[] = { 5,10,25,50 }; |
| 46 | 46 |
| 47 for (size_t i = 0; i < kNumBlurs; ++i) { | 47 for (size_t i = 0; i < kNumBlurs; ++i) { |
| 48 SkAutoCanvasRestore autoRestore(canvas, true); | 48 SkAutoCanvasRestore autoRestore(canvas, true); |
| 49 canvas->translate(0, SkIntToScalar(150*i)); | 49 canvas->translate(0, SkIntToScalar(150*i)); |
| 50 for (size_t j = 0; j < SK_ARRAY_COUNT(circleRadii); ++j) { | 50 for (size_t j = 0; j < SK_ARRAY_COUNT(circleRadii); ++j) { |
| 51 SkPaint paint; | 51 SkPaint paint; |
| 52 paint.setColor(SK_ColorBLACK); | 52 paint.setColor(SK_ColorBLACK); |
| 53 paint.setMaskFilter(fBlurFilters[i]); | 53 paint.setMaskFilter(fBlurFilters[i]); |
| 54 | 54 |
| 55 canvas->drawCircle(SkIntToScalar(50),SkIntToScalar(50),SkIntToSc
alar(circleRadii[j]),paint); | 55 canvas->drawCircle(SkIntToScalar(50),SkIntToScalar(50),SkIntToSc
alar(circleRadii[j]),paint); |
| 56 canvas->translate(SkIntToScalar(150), 0); | 56 canvas->translate(SkIntToScalar(150), 0); |
| 57 } | 57 } |
| 58 } | 58 } |
| 59 } | 59 } |
| 60 private: | 60 private: |
| 61 static const int kNumBlurs = 4; | 61 static const int kNumBlurs = 4; |
| 62 | 62 |
| 63 SkAutoTUnref<SkMaskFilter> fBlurFilters[kNumBlurs]; | 63 sk_sp<SkMaskFilter> fBlurFilters[kNumBlurs]; |
| 64 | 64 |
| 65 typedef skiagm::GM INHERITED; | 65 typedef skiagm::GM INHERITED; |
| 66 }; | 66 }; |
| 67 | 67 |
| 68 DEF_GM(return new BlurCirclesGM();) | 68 DEF_GM(return new BlurCirclesGM();) |
| OLD | NEW |