1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
| /*
| * Copyright 2017 Google Inc.
| *
| * Use of this source code is governed by a BSD-style license that can be
| * found in the LICENSE file.
| */
|
| #include "gm.h"
| #include "SkBlurImageFilter.h"
|
| // For all sigma, the black box should be centered in the red outline. For small sigma,
| // the rectangle is not blurred, but still must be centered properly.
|
| DEF_SIMPLE_GM(check_small_sigma_offset, canvas, 200, 1200) {
|
| for (auto sigma : {0.0, 0.1, 0.2, 0.3, 0.4, 0.6, 0.8, 1.0, 1.2}) {
| // border calculation from SkBlurImageFilter
| int border = SkScalarCeilToInt(sigma * 3);
|
| SkRect r = SkRect::MakeXYWH(50, 50, 100, 50);
| SkRect b = r.makeOutset(border + 1, border + 1);
| b.inset(0.5f, 0.5f);
| SkPaint p;
| p.setColor(SK_ColorRED);
| p.setStyle(SkPaint::Style::kStroke_Style);
|
| canvas->drawRect(b, p);
|
| p.reset();
| p.setColor(SK_ColorBLACK);
| p.setImageFilter(SkBlurImageFilter::Make(sigma, sigma, nullptr));
| canvas->drawRect(r, p);
|
| canvas->translate(0, 100);
| }
| }
|
|