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 // EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL | 8 // EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL |
9 // DO NOT USE -- FOR INTERNAL TESTING ONLY | 9 // DO NOT USE -- FOR INTERNAL TESTING ONLY |
10 | 10 |
11 #ifndef sk_path_DEFINED | 11 #ifndef sk_path_DEFINED |
12 #define sk_path_DEFINED | 12 #define sk_path_DEFINED |
13 | 13 |
14 #include "sk_types.h" | 14 #include "sk_types.h" |
15 | 15 |
16 SK_C_PLUS_PLUS_BEGIN_GUARD | 16 SK_C_PLUS_PLUS_BEGIN_GUARD |
17 | 17 |
18 typedef enum { | 18 typedef enum { |
19 CW_SK_PATH_DIRECTION, | 19 CW_SK_PATH_DIRECTION, |
20 CCW_SK_PATH_DIRECTION, | 20 CCW_SK_PATH_DIRECTION, |
21 } sk_path_direction_t; | 21 } sk_path_direction_t; |
22 | 22 |
| 23 /** Create a new, empty path. */ |
23 SK_API sk_path_t* sk_path_new(); | 24 SK_API sk_path_t* sk_path_new(); |
| 25 /** Release the memory used by a sk_path_t. */ |
24 SK_API void sk_path_delete(sk_path_t*); | 26 SK_API void sk_path_delete(sk_path_t*); |
25 | 27 |
| 28 /** Set the beginning of the next contour to the point (x,y). */ |
26 SK_API void sk_path_move_to(sk_path_t*, float x, float y); | 29 SK_API void sk_path_move_to(sk_path_t*, float x, float y); |
| 30 /** |
| 31 Add a line from the last point to the specified point (x,y). If no |
| 32 sk_path_move_to() call has been made for this contour, the first |
| 33 point is automatically set to (0,0). |
| 34 */ |
27 SK_API void sk_path_line_to(sk_path_t*, float x, float y); | 35 SK_API void sk_path_line_to(sk_path_t*, float x, float y); |
| 36 /** |
| 37 Add a quadratic bezier from the last point, approaching control |
| 38 point (x0,y0), and ending at (x1,y1). If no sk_path_move_to() call |
| 39 has been made for this contour, the first point is automatically |
| 40 set to (0,0). |
| 41 */ |
28 SK_API void sk_path_quad_to(sk_path_t*, float x0, float y0, float x1, float y1); | 42 SK_API void sk_path_quad_to(sk_path_t*, float x0, float y0, float x1, float y1); |
| 43 /** |
| 44 Add a conic curve from the last point, approaching control point |
| 45 (x0,y01), and ending at (x1,y1) with weight w. If no |
| 46 sk_path_move_to() call has been made for this contour, the first |
| 47 point is automatically set to (0,0). |
| 48 */ |
29 SK_API void sk_path_conic_to(sk_path_t*, float x0, float y0, float x1, float y1,
float w); | 49 SK_API void sk_path_conic_to(sk_path_t*, float x0, float y0, float x1, float y1,
float w); |
| 50 /** |
| 51 Add a cubic bezier from the last point, approaching control points |
| 52 (x0,y0) and (x1,y1), and ending at (x2,y2). If no |
| 53 sk_path_move_to() call has been made for this contour, the first |
| 54 point is automatically set to (0,0). |
| 55 */ |
30 SK_API void sk_path_cubic_to(sk_path_t*, | 56 SK_API void sk_path_cubic_to(sk_path_t*, |
31 float x0, float y0, | 57 float x0, float y0, |
32 float x1, float y1, | 58 float x1, float y1, |
33 float x2, float y2); | 59 float x2, float y2); |
| 60 /** |
| 61 Close the current contour. If the current point is not equal to the |
| 62 first point of the contour, a line segment is automatically added. |
| 63 */ |
34 SK_API void sk_path_close(sk_path_t*); | 64 SK_API void sk_path_close(sk_path_t*); |
35 | 65 |
| 66 /** |
| 67 Add a closed rectangle contour to the path. |
| 68 */ |
36 SK_API void sk_path_add_rect(sk_path_t*, const sk_rect_t*, sk_path_direction_t); | 69 SK_API void sk_path_add_rect(sk_path_t*, const sk_rect_t*, sk_path_direction_t); |
| 70 /** |
| 71 Add a closed oval contour to the path |
| 72 */ |
37 SK_API void sk_path_add_oval(sk_path_t*, const sk_rect_t*, sk_path_direction_t); | 73 SK_API void sk_path_add_oval(sk_path_t*, const sk_rect_t*, sk_path_direction_t); |
38 | 74 |
39 /** | 75 /** |
40 * If the path is empty, return false and set the rect parameter to [0, 0, 0, 0
]. | 76 * If the path is empty, return false and set the rect parameter to [0, 0, 0, 0
]. |
41 * else return true and set the rect parameter to the bounds of the control-poi
nts | 77 * else return true and set the rect parameter to the bounds of the control-poi
nts |
42 * of the path. | 78 * of the path. |
43 */ | 79 */ |
44 SK_API bool sk_path_get_bounds(const sk_path_t*, sk_rect_t*); | 80 SK_API bool sk_path_get_bounds(const sk_path_t*, sk_rect_t*); |
45 | 81 |
46 SK_C_PLUS_PLUS_END_GUARD | 82 SK_C_PLUS_PLUS_END_GUARD |
47 | 83 |
48 #endif | 84 #endif |
OLD | NEW |