#ifndef PLUTOVG_PRIVATE_H #define PLUTOVG_PRIVATE_H #include #include #include #include #include "plutovg.h" struct plutovg_surface { int ref; unsigned char* data; int owndata; int width; int height; int stride; }; struct plutovg_path { int ref; int contours; plutovg_point_t start; struct { plutovg_path_element_t* data; int size; int capacity; } elements; struct { plutovg_point_t* data; int size; int capacity; } points; }; struct plutovg_gradient { int ref; plutovg_gradient_type_t type; plutovg_spread_method_t spread; plutovg_matrix_t matrix; double values[6]; double opacity; struct { plutovg_gradient_stop_t* data; int size; int capacity; } stops; }; struct plutovg_texture { int ref; plutovg_texture_type_t type; plutovg_surface_t* surface; plutovg_matrix_t matrix; double opacity; }; struct plutovg_paint { int ref; plutovg_paint_type_t type; union { plutovg_color_t* color; plutovg_gradient_t* gradient; plutovg_texture_t* texture; }; }; typedef struct { short x; short y; unsigned short len; unsigned char coverage; } plutovg_span_t; typedef struct { struct { plutovg_span_t* data; int size; int capacity; } spans; int x; int y; int w; int h; } plutovg_rle_t; typedef struct { double offset; double* data; int size; } plutovg_dash_t; typedef struct { double width; double miterlimit; plutovg_line_cap_t cap; plutovg_line_join_t join; plutovg_dash_t* dash; } plutovg_stroke_data_t; typedef struct plutovg_state { plutovg_rle_t* clippath; plutovg_paint_t* source; plutovg_matrix_t matrix; plutovg_fill_rule_t winding; plutovg_stroke_data_t stroke; plutovg_operator_t op; double opacity; struct plutovg_state* next; } plutovg_state_t; struct plutovg { int ref; plutovg_surface_t* surface; plutovg_state_t* state; plutovg_path_t* path; plutovg_rle_t* rle; plutovg_rle_t* clippath; plutovg_rect_t clip; }; plutovg_rle_t* plutovg_rle_create(void); void plutovg_rle_destroy(plutovg_rle_t* rle); void plutovg_rle_rasterize(plutovg_rle_t* rle, const plutovg_path_t* path, const plutovg_matrix_t* matrix, const plutovg_rect_t* clip, const plutovg_stroke_data_t* stroke, plutovg_fill_rule_t winding); plutovg_rle_t* plutovg_rle_intersection(const plutovg_rle_t* a, const plutovg_rle_t* b); void plutovg_rle_clip_path(plutovg_rle_t* rle, const plutovg_rle_t* clip); plutovg_rle_t* plutovg_rle_clone(const plutovg_rle_t* rle); void plutovg_rle_clear(plutovg_rle_t* rle); plutovg_dash_t* plutovg_dash_create(double offset, const double* data, int size); plutovg_dash_t* plutovg_dash_clone(const plutovg_dash_t* dash); void plutovg_dash_destroy(plutovg_dash_t* dash); plutovg_path_t* plutovg_dash_path(const plutovg_dash_t* dash, const plutovg_path_t* path); plutovg_state_t* plutovg_state_create(void); plutovg_state_t* plutovg_state_clone(const plutovg_state_t* state); void plutovg_state_destroy(plutovg_state_t* state); void plutovg_blend(plutovg_t* pluto, const plutovg_rle_t* rle); void plutovg_blend_color(plutovg_t* pluto, const plutovg_rle_t* rle, const plutovg_color_t* color); void plutovg_blend_gradient(plutovg_t* pluto, const plutovg_rle_t* rle, const plutovg_gradient_t* gradient); void plutovg_blend_texture(plutovg_t* pluto, const plutovg_rle_t* rle, const plutovg_texture_t* texture); #define plutovg_alpha(c) ((c) >> 24) #define plutovg_red(c) (((c) >> 16) & 0xff) #define plutovg_green(c) (((c) >> 8) & 0xff) #define plutovg_blue(c) (((c) >> 0) & 0xff) #define plutovg_array_init(array) \ do { \ array.data = NULL; \ array.size = 0; \ array.capacity = 0; \ } while(0) #define plutovg_array_ensure(array, count) \ do { \ if(array.size + count > array.capacity) { \ int capacity = array.size + count; \ int newcapacity = array.capacity == 0 ? 8 : array.capacity; \ while(newcapacity < capacity) { newcapacity *= 2; } \ array.data = realloc(array.data, (size_t)newcapacity * sizeof(array.data[0])); \ array.capacity = newcapacity; \ } \ } while(0) #endif // PLUTOVG_PRIVATE_H