OLD | NEW |
| (Empty) |
1 | |
2 /* | |
3 * Copyright 2011 Google Inc. | |
4 * | |
5 * Use of this source code is governed by a BSD-style license that can be | |
6 * found in the LICENSE file. | |
7 */ | |
8 #ifndef SkLineClipper_DEFINED | |
9 #define SkLineClipper_DEFINED | |
10 | |
11 #include "SkRect.h" | |
12 #include "SkPoint.h" | |
13 | |
14 class SkLineClipper { | |
15 public: | |
16 enum { | |
17 kMaxPoints = 4, | |
18 kMaxClippedLineSegments = kMaxPoints - 1 | |
19 }; | |
20 | |
21 /* Clip the line pts[0]...pts[1] against clip, ignoring segments that | |
22 lie completely above or below the clip. For portions to the left or | |
23 right, turn those into vertical line segments that are aligned to the | |
24 edge of the clip. | |
25 | |
26 Return the number of line segments that result, and store the end-points | |
27 of those segments sequentially in lines as follows: | |
28 1st segment: lines[0]..lines[1] | |
29 2nd segment: lines[1]..lines[2] | |
30 3rd segment: lines[2]..lines[3] | |
31 */ | |
32 static int ClipLine(const SkPoint pts[2], const SkRect& clip, | |
33 SkPoint lines[kMaxPoints]); | |
34 | |
35 /* Intersect the line segment against the rect. If there is a non-empty | |
36 resulting segment, return true and set dst[] to that segment. If not, | |
37 return false and ignore dst[]. | |
38 | |
39 ClipLine is specialized for scan-conversion, as it adds vertical | |
40 segments on the sides to show where the line extended beyond the | |
41 left or right sides. IntersectLine does not. | |
42 */ | |
43 static bool IntersectLine(const SkPoint src[2], const SkRect& clip, | |
44 SkPoint dst[2]); | |
45 }; | |
46 | |
47 #endif | |
OLD | NEW |