lv_draw_sw_gradient.h
Typedefs
-
typedef lv_color_t lv_grad_color_t
Functions
-
void lv_gradient_color_calculate(const lv_grad_dsc_t *dsc, int32_t range, int32_t frac, lv_grad_color_t *color_out, lv_opa_t *opa_out)
Compute the color in the given gradient and fraction Gradient are specified in a virtual [0-255] range, so this function scales the virtual range to the given range
- Parameters:
dsc -- The gradient descriptor to use
range -- The range to use in computation.
frac -- The current part used in the range. frac is in [0; range]
color_out -- Calculated gradient color
opa_out -- Calculated opacity
-
lv_grad_t *lv_gradient_get(const lv_grad_dsc_t *gradient, int32_t w, int32_t h)
Get a gradient cache from the given parameters
-
void lv_gradient_cleanup(lv_grad_t *grad)
Clean up the gradient item after it was get with
lv_grad_get_from_cache
.- Parameters:
grad -- pointer to a gradient
-
void lv_gradient_init_stops(lv_grad_dsc_t *grad, const lv_color_t colors[], const lv_opa_t opa[], const uint8_t fracs[], int num_stops)
Initialize gradient color map from a table
- Parameters:
grad -- pointer to a gradient descriptor
colors -- color array
fracs -- position array (0..255): if NULL, then colors are distributed evenly
opa -- opacity array: if NULL, then LV_OPA_COVER is assumed
num_stops -- number of gradient stops (1..LV_GRADIENT_MAX_STOPS)
-
void lv_grad_linear_init(lv_grad_dsc_t *dsc, int32_t from_x, int32_t from_y, int32_t to_x, int32_t to_y, lv_grad_extend_t extend)
Helper function to initialize linear gradient
- Parameters:
dsc -- gradient descriptor
from_x -- start x position: can be a coordinate or an lv_pct() value predefined constants LV_GRAD_LEFT, LV_GRAD_RIGHT, LV_GRAD_TOP, LV_GRAD_BOTTOM, LV_GRAD_CENTER can be used as well
from_y -- start y position
to_x -- end x position
to_y -- end y position
extend -- one of LV_GRAD_EXTEND_PAD, LV_GRAD_EXTEND_REPEAT or LV_GRAD_EXTEND_REFLECT
-
void lv_grad_radial_init(lv_grad_dsc_t *dsc, int32_t center_x, int32_t center_y, int32_t to_x, int32_t to_y, lv_grad_extend_t extend)
Helper function to initialize radial gradient
- Parameters:
dsc -- gradient descriptor
center_x -- center x position: can be a coordinate or an lv_pct() value predefined constants LV_GRAD_LEFT, LV_GRAD_RIGHT, LV_GRAD_TOP, LV_GRAD_BOTTOM, LV_GRAD_CENTER can be used as well
center_y -- center y position
to_x -- point on the end circle x position
to_y -- point on the end circle y position
extend -- one of LV_GRAD_EXTEND_PAD, LV_GRAD_EXTEND_REPEAT or LV_GRAD_EXTEND_REFLECT
-
void lv_grad_radial_set_focal(lv_grad_dsc_t *dsc, int32_t center_x, int32_t center_y, int32_t radius)
Set focal (starting) circle of a radial gradient
- Parameters:
dsc -- gradient descriptor
center_x -- center x position: can be a coordinate or an lv_pct() value predefined constants LV_GRAD_LEFT, LV_GRAD_RIGHT, LV_GRAD_TOP, LV_GRAD_BOTTOM, LV_GRAD_CENTER can be used as well
center_y -- center y position
radius -- radius of the starting circle (NOTE: this must be a scalar number, not percentage)
-
void lv_grad_conical_init(lv_grad_dsc_t *dsc, int32_t center_x, int32_t center_y, int32_t start_angle, int32_t end_angle, lv_grad_extend_t extend)
Helper function to initialize conical gradient
- Parameters:
dsc -- gradient descriptor
center_x -- center x position: can be a coordinate or an lv_pct() value predefined constants LV_GRAD_LEFT, LV_GRAD_RIGHT, LV_GRAD_TOP, LV_GRAD_BOTTOM, LV_GRAD_CENTER can be used as well
center_y -- center y position
start_angle -- start angle in degrees
end_angle -- end angle in degrees
extend -- one of LV_GRAD_EXTEND_PAD, LV_GRAD_EXTEND_REPEAT or LV_GRAD_EXTEND_REFLECT
-
void lv_gradient_linear_setup(lv_grad_dsc_t *dsc, const lv_area_t *coords)
Calculate constants from the given parameters that are used during rendering
- Parameters:
dsc -- gradient descriptor
-
void lv_gradient_linear_cleanup(lv_grad_dsc_t *dsc)
Free up the allocated memory for the gradient calculation
- Parameters:
dsc -- gradient descriptor
-
void lv_gradient_linear_get_line(lv_grad_dsc_t *dsc, int32_t xp, int32_t yp, int32_t width, lv_grad_t *result)
Calculate a line segment of a linear gradient
- Parameters:
dsc -- gradient descriptor
xp -- starting point x coordinate in gradient space
yp -- starting point y coordinate in gradient space
width -- width of the line segment in pixels
result -- color buffer for the resulting line segment
-
void lv_gradient_radial_setup(lv_grad_dsc_t *dsc, const lv_area_t *coords)
Calculate constants from the given parameters that are used during rendering
- Parameters:
dsc -- gradient descriptor
-
void lv_gradient_radial_cleanup(lv_grad_dsc_t *dsc)
Free up the allocated memory for the gradient calculation
- Parameters:
dsc -- gradient descriptor
-
void lv_gradient_radial_get_line(lv_grad_dsc_t *dsc, int32_t xp, int32_t yp, int32_t width, lv_grad_t *result)
Calculate a line segment of a radial gradient
- Parameters:
dsc -- gradient descriptor
xp -- starting point x coordinate in gradient space
yp -- starting point y coordinate in gradient space
width -- width of the line segment in pixels
result -- color buffer for the resulting line segment
-
void lv_gradient_conical_setup(lv_grad_dsc_t *dsc, const lv_area_t *coords)
Calculate constants from the given parameters that are used during rendering
- Parameters:
dsc -- gradient descriptor
-
void lv_gradient_conical_cleanup(lv_grad_dsc_t *dsc)
Free up the allocated memory for the gradient calculation
- Parameters:
dsc -- gradient descriptor
-
void lv_gradient_conical_get_line(lv_grad_dsc_t *dsc, int32_t xp, int32_t yp, int32_t width, lv_grad_t *result)
Calculate a line segment of a conical gradient
- Parameters:
dsc -- gradient descriptor
xp -- starting point x coordinate in gradient space
yp -- starting point y coordinate in gradient space
width -- width of the line segment in pixels
result -- color buffer for the resulting line segment