blob: 801e1480f93129aa3e629a3ba10e25b2f1afa759 [file] [log] [blame]
reed73c25012014-11-17 06:15:42 -08001/*
2 * Copyright 2014 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8// EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL
9// DO NOT USE -- FOR INTERNAL TESTING ONLY
10
11#ifndef sk_path_DEFINED
12#define sk_path_DEFINED
13
14#include "sk_types.h"
15
16SK_C_PLUS_PLUS_BEGIN_GUARD
17
18typedef enum {
19 CW_SK_PATH_DIRECTION,
20 CCW_SK_PATH_DIRECTION,
21} sk_path_direction_t;
22
23sk_path_t* sk_path_new();
24void sk_path_delete(sk_path_t*);
25
26void sk_path_move_to(sk_path_t*, float x, float y);
27void sk_path_line_to(sk_path_t*, float x, float y);
28void sk_path_quad_to(sk_path_t*, float x0, float y0, float x1, float y1);
29void sk_path_conic_to(sk_path_t*, float x0, float y0, float x1, float y1, float w);
30void sk_path_cubic_to(sk_path_t*, float x0, float y0, float x1, float y1, float x2, float y2);
31void sk_path_close(sk_path_t*);
32
33void sk_path_add_rect(sk_path_t*, const sk_rect_t*, sk_path_direction_t);
34void sk_path_add_oval(sk_path_t*, const sk_rect_t*, sk_path_direction_t);
35
36/**
37 * If the path is empty, return false and set the rect parameter to [0, 0, 0, 0].
38 * else return true and set the rect parameter to the bounds of the control-points
39 * of the path.
40 */
41bool sk_path_get_bounds(const sk_path_t*, sk_rect_t*);
42
43SK_C_PLUS_PLUS_END_GUARD
44
45#endif