2014-11-17 14:15:42 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2014 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
// EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL EXPERIMENTAL
|
|
|
|
// DO NOT USE -- FOR INTERNAL TESTING ONLY
|
|
|
|
|
|
|
|
#ifndef sk_paint_DEFINED
|
|
|
|
#define sk_paint_DEFINED
|
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/c/sk_types.h"
|
2014-11-17 14:15:42 +00:00
|
|
|
|
|
|
|
SK_C_PLUS_PLUS_BEGIN_GUARD
|
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Create a new paint with default settings:
|
|
|
|
antialias : false
|
|
|
|
stroke : false
|
|
|
|
stroke width : 0.0f (hairline)
|
|
|
|
stroke miter : 4.0f
|
|
|
|
stroke cap : BUTT_SK_STROKE_CAP
|
|
|
|
stroke join : MITER_SK_STROKE_JOIN
|
|
|
|
color : opaque black
|
|
|
|
shader : NULL
|
|
|
|
maskfilter : NULL
|
|
|
|
xfermode_mode : SRCOVER_SK_XFERMODE_MODE
|
|
|
|
*/
|
2016-12-28 20:56:16 +00:00
|
|
|
SK_API sk_paint_t* sk_paint_new(void);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Release the memory storing the sk_paint_t and unref() all
|
|
|
|
associated objects.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_delete(sk_paint_t*);
|
2014-11-25 03:11:48 +00:00
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return true iff the paint has antialiasing enabled.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API bool sk_paint_is_antialias(const sk_paint_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Set to true to enable antialiasing, false to disable it on this
|
|
|
|
sk_paint_t.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_antialias(sk_paint_t*, bool);
|
2014-11-25 03:11:48 +00:00
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return the paint's curent drawing color.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API sk_color_t sk_paint_get_color(const sk_paint_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Set the paint's curent drawing color.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_color(sk_paint_t*, sk_color_t);
|
2014-11-17 14:15:42 +00:00
|
|
|
|
2015-01-11 01:59:31 +00:00
|
|
|
/* stroke settings */
|
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return true iff stroking is enabled rather than filling on this
|
|
|
|
sk_paint_t.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API bool sk_paint_is_stroke(const sk_paint_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Set to true to enable stroking rather than filling with this
|
|
|
|
sk_paint_t.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_stroke(sk_paint_t*, bool);
|
2015-01-11 01:59:31 +00:00
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return the width for stroking. A value of 0 strokes in hairline mode.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API float sk_paint_get_stroke_width(const sk_paint_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Set the width for stroking. A value of 0 strokes in hairline mode
|
|
|
|
(always draw 1-pixel wide, regardless of the matrix).
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_stroke_width(sk_paint_t*, float width);
|
2015-01-11 01:59:31 +00:00
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return the paint's stroke miter value. This is used to control the
|
|
|
|
behavior of miter joins when the joins angle is sharp.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API float sk_paint_get_stroke_miter(const sk_paint_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Set the paint's stroke miter value. This is used to control the
|
|
|
|
behavior of miter joins when the joins angle is sharp. This value
|
|
|
|
must be >= 0.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_stroke_miter(sk_paint_t*, float miter);
|
2015-01-11 01:59:31 +00:00
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
BUTT_SK_STROKE_CAP,
|
|
|
|
ROUND_SK_STROKE_CAP,
|
|
|
|
SQUARE_SK_STROKE_CAP
|
|
|
|
} sk_stroke_cap_t;
|
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return the paint's stroke cap type, controlling how the start and
|
|
|
|
end of stroked lines and paths are treated.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API sk_stroke_cap_t sk_paint_get_stroke_cap(const sk_paint_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Set the paint's stroke cap type, controlling how the start and
|
|
|
|
end of stroked lines and paths are treated.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_stroke_cap(sk_paint_t*, sk_stroke_cap_t);
|
2015-01-11 01:59:31 +00:00
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
MITER_SK_STROKE_JOIN,
|
|
|
|
ROUND_SK_STROKE_JOIN,
|
|
|
|
BEVEL_SK_STROKE_JOIN
|
|
|
|
} sk_stroke_join_t;
|
|
|
|
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Return the paint's stroke join type, specifies the treatment that
|
|
|
|
is applied to corners in paths and rectangles
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API sk_stroke_join_t sk_paint_get_stroke_join(const sk_paint_t*);
|
2015-09-01 17:45:09 +00:00
|
|
|
/**
|
|
|
|
Set the paint's stroke join type, specifies the treatment that
|
|
|
|
is applied to corners in paths and rectangles
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_stroke_join(sk_paint_t*, sk_stroke_join_t);
|
2015-01-11 01:59:31 +00:00
|
|
|
|
2014-11-25 03:11:48 +00:00
|
|
|
/**
|
|
|
|
* Set the paint's shader to the specified parameter. This will automatically call unref() on
|
|
|
|
* any previous value, and call ref() on the new value.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_shader(sk_paint_t*, sk_shader_t*);
|
2014-11-25 03:11:48 +00:00
|
|
|
|
2014-12-23 22:11:11 +00:00
|
|
|
/**
|
|
|
|
* Set the paint's maskfilter to the specified parameter. This will automatically call unref() on
|
|
|
|
* any previous value, and call ref() on the new value.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_maskfilter(sk_paint_t*, sk_maskfilter_t*);
|
2014-12-23 22:11:11 +00:00
|
|
|
|
2015-07-31 20:38:06 +00:00
|
|
|
/**
|
|
|
|
* Set the paint's xfermode to the specified parameter.
|
|
|
|
*/
|
2015-09-01 17:01:38 +00:00
|
|
|
SK_API void sk_paint_set_xfermode_mode(sk_paint_t*, sk_xfermode_mode_t);
|
2015-07-31 20:38:06 +00:00
|
|
|
|
2014-11-17 14:15:42 +00:00
|
|
|
SK_C_PLUS_PLUS_END_GUARD
|
|
|
|
|
|
|
|
#endif
|