Home | History | Annotate | Download | only in c
      1 /*
      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 
     16 SK_C_PLUS_PLUS_BEGIN_GUARD
     17 
     18 typedef enum {
     19     CW_SK_PATH_DIRECTION,
     20     CCW_SK_PATH_DIRECTION,
     21 } sk_path_direction_t;
     22 
     23 sk_path_t* sk_path_new();
     24 void sk_path_delete(sk_path_t*);
     25 
     26 void sk_path_move_to(sk_path_t*, float x, float y);
     27 void sk_path_line_to(sk_path_t*, float x, float y);
     28 void sk_path_quad_to(sk_path_t*, float x0, float y0, float x1, float y1);
     29 void sk_path_conic_to(sk_path_t*, float x0, float y0, float x1, float y1, float w);
     30 void sk_path_cubic_to(sk_path_t*, float x0, float y0, float x1, float y1, float x2, float y2);
     31 void sk_path_close(sk_path_t*);
     32 
     33 void sk_path_add_rect(sk_path_t*, const sk_rect_t*, sk_path_direction_t);
     34 void 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  */
     41 bool sk_path_get_bounds(const sk_path_t*, sk_rect_t*);
     42 
     43 SK_C_PLUS_PLUS_END_GUARD
     44 
     45 #endif
     46