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_paint_DEFINED
     12 #define sk_paint_DEFINED
     13 
     14 #include "sk_types.h"
     15 
     16 SK_C_PLUS_PLUS_BEGIN_GUARD
     17 
     18 /**
     19     Create a new paint with default settings:
     20         antialias : false
     21         stroke : false
     22         stroke width : 0.0f (hairline)
     23         stroke miter : 4.0f
     24         stroke cap : BUTT_SK_STROKE_CAP
     25         stroke join : MITER_SK_STROKE_JOIN
     26         color : opaque black
     27         shader : NULL
     28         maskfilter : NULL
     29         xfermode_mode : SRCOVER_SK_XFERMODE_MODE
     30 */
     31 SK_API sk_paint_t* sk_paint_new(void);
     32 /**
     33     Release the memory storing the sk_paint_t and unref() all
     34     associated objects.
     35 */
     36 SK_API void sk_paint_delete(sk_paint_t*);
     37 
     38 /**
     39     Return true iff the paint has antialiasing enabled.
     40 */
     41 SK_API bool sk_paint_is_antialias(const sk_paint_t*);
     42 /**
     43     Set to true to enable antialiasing, false to disable it on this
     44     sk_paint_t.
     45 */
     46 SK_API void sk_paint_set_antialias(sk_paint_t*, bool);
     47 
     48 /**
     49     Return the paint's curent drawing color.
     50 */
     51 SK_API sk_color_t sk_paint_get_color(const sk_paint_t*);
     52 /**
     53     Set the paint's curent drawing color.
     54 */
     55 SK_API void sk_paint_set_color(sk_paint_t*, sk_color_t);
     56 
     57 /* stroke settings */
     58 
     59 /**
     60     Return true iff stroking is enabled rather than filling on this
     61     sk_paint_t.
     62 */
     63 SK_API bool sk_paint_is_stroke(const sk_paint_t*);
     64 /**
     65     Set to true to enable stroking rather than filling with this
     66     sk_paint_t.
     67 */
     68 SK_API void sk_paint_set_stroke(sk_paint_t*, bool);
     69 
     70 /**
     71     Return the width for stroking.  A value of 0 strokes in hairline mode.
     72  */
     73 SK_API float sk_paint_get_stroke_width(const sk_paint_t*);
     74 /**
     75    Set the width for stroking.  A value of 0 strokes in hairline mode
     76    (always draw 1-pixel wide, regardless of the matrix).
     77  */
     78 SK_API void sk_paint_set_stroke_width(sk_paint_t*, float width);
     79 
     80 /**
     81     Return the paint's stroke miter value. This is used to control the
     82     behavior of miter joins when the joins angle is sharp.
     83 */
     84 SK_API float sk_paint_get_stroke_miter(const sk_paint_t*);
     85 /**
     86    Set the paint's stroke miter value. This is used to control the
     87    behavior of miter joins when the joins angle is sharp. This value
     88    must be >= 0.
     89 */
     90 SK_API void sk_paint_set_stroke_miter(sk_paint_t*, float miter);
     91 
     92 typedef enum {
     93     BUTT_SK_STROKE_CAP,
     94     ROUND_SK_STROKE_CAP,
     95     SQUARE_SK_STROKE_CAP
     96 } sk_stroke_cap_t;
     97 
     98 /**
     99     Return the paint's stroke cap type, controlling how the start and
    100     end of stroked lines and paths are treated.
    101 */
    102 SK_API sk_stroke_cap_t sk_paint_get_stroke_cap(const sk_paint_t*);
    103 /**
    104     Set the paint's stroke cap type, controlling how the start and
    105     end of stroked lines and paths are treated.
    106 */
    107 SK_API void sk_paint_set_stroke_cap(sk_paint_t*, sk_stroke_cap_t);
    108 
    109 typedef enum {
    110     MITER_SK_STROKE_JOIN,
    111     ROUND_SK_STROKE_JOIN,
    112     BEVEL_SK_STROKE_JOIN
    113 } sk_stroke_join_t;
    114 
    115 /**
    116     Return the paint's stroke join type, specifies the treatment that
    117     is applied to corners in paths and rectangles
    118  */
    119 SK_API sk_stroke_join_t sk_paint_get_stroke_join(const sk_paint_t*);
    120 /**
    121     Set the paint's stroke join type, specifies the treatment that
    122     is applied to corners in paths and rectangles
    123  */
    124 SK_API void sk_paint_set_stroke_join(sk_paint_t*, sk_stroke_join_t);
    125 
    126 /**
    127  *  Set the paint's shader to the specified parameter. This will automatically call unref() on
    128  *  any previous value, and call ref() on the new value.
    129  */
    130 SK_API void sk_paint_set_shader(sk_paint_t*, sk_shader_t*);
    131 
    132 /**
    133  *  Set the paint's maskfilter to the specified parameter. This will automatically call unref() on
    134  *  any previous value, and call ref() on the new value.
    135  */
    136 SK_API void sk_paint_set_maskfilter(sk_paint_t*, sk_maskfilter_t*);
    137 
    138 /**
    139  *  Set the paint's xfermode to the specified parameter.
    140  */
    141 SK_API void sk_paint_set_xfermode_mode(sk_paint_t*, sk_xfermode_mode_t);
    142 
    143 SK_C_PLUS_PLUS_END_GUARD
    144 
    145 #endif
    146