Hal Canary | 8751512 | 2019-03-15 14:22:51 -0400 | [diff] [blame] | 1 | // Copyright 2019 Google LLC. |
| 2 | // Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. |
Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 3 | #include "tools/fiddle/examples.h" |
Hal Canary | 8751512 | 2019-03-15 14:22:51 -0400 | [diff] [blame] | 4 | // HASH=77e4394caf9fa083c19c21c2462efe14 |
Hal Canary | a7181e7c | 2019-03-18 16:06:34 -0400 | [diff] [blame] | 5 | REG_FIDDLE(Path_isNestedFillRects, 256, 256, true, 0) { |
Hal Canary | 8751512 | 2019-03-15 14:22:51 -0400 | [diff] [blame] | 6 | void draw(SkCanvas* canvas) { |
| 7 | SkPaint paint; |
| 8 | paint.setStyle(SkPaint::kStroke_Style); |
| 9 | paint.setStrokeWidth(5); |
| 10 | SkPath path; |
| 11 | path.addRect({10, 20, 30, 40}); |
| 12 | paint.getFillPath(path, &path); |
| 13 | SkRect rects[2]; |
| 14 | SkPath::Direction directions[2]; |
| 15 | if (path.isNestedFillRects(rects, directions)) { |
| 16 | for (int i = 0; i < 2; ++i) { |
| 17 | SkDebugf("%s (%g, %g, %g, %g); direction %s\n", i ? "inner" : "outer", |
| 18 | rects[i].fLeft, rects[i].fTop, rects[i].fRight, rects[i].fBottom, |
| 19 | SkPath::kCW_Direction == directions[i] ? "CW" : "CCW"); |
| 20 | } |
| 21 | } else { |
| 22 | SkDebugf("is not nested rectangles\n"); |
| 23 | } |
| 24 | } |
| 25 | } // END FIDDLE |