/** * @file lv_draw.h * */ #ifndef LV_DRAW_H #define LV_DRAW_H #ifdef __cplusplus extern "C" { #endif /********************* * INCLUDES *********************/ #include "../lv_obj/lv_style.h" #include "../lv_misc/lv_txt.h" /********************* * DEFINES *********************/ /********************** * TYPEDEFS **********************/ /* Image header it is compatible with * the result image converter utility*/ typedef struct { uint32_t w:12; /*Width of the image map*/ uint32_t h:12; /*Height of the image map*/ uint32_t transp:1; /*1: The image contains transparent pixels with LV_LV_COLOR_TRANSP color*/ uint32_t cd:3; /*Color depth (0: reserved, 1: 8 bit, 2: 16 bit or 3: 24 bit, 4-7: reserved)*/ uint32_t res :4; /*Reserved*/ }lv_img_raw_header_t; /********************** * GLOBAL PROTOTYPES **********************/ /** * Draw a rectangle * @param cords_p the coordinates of the rectangle * @param mask_p the rectangle will be drawn only in this mask * @param style_p pointer to a style */ void lv_draw_rect(const lv_area_t * cords_p, const lv_area_t * mask_p, const lv_style_t * style_p); /*Experimental use for 3D modeling*/ #define USE_LV_TRIANGLE 0 #if USE_LV_TRIANGLE != 0 /** * * @param points pointer to an array with 3 points * @param mask_p the triangle will be drawn only in this mask * @param color color of the triangle */ void lv_draw_triangle(const lv_point_t * points, const lv_area_t * mask_p, lv_color_t color); #endif /** * Write a text * @param cords_p coordinates of the label * @param mask_p the label will be drawn only in this area * @param style_p pointer to a style * @param txt 0 terminated text to write * @param flags settings for the text from 'txt_flag_t' enum * @param offset text offset in x and y direction (NULL if unused) */ void lv_draw_label(const lv_area_t * cords_p,const lv_area_t * mask_p, const lv_style_t * style_p, const char * txt, lv_txt_flag_t flag, lv_point_t * offset); /** * Draw an image * @param cords_p the coordinates of the image * @param mask_p the image will be drawn only in this area * @param map_p pointer to a lv_color_t array which contains the pixels of the image */ void lv_draw_img(const lv_area_t * cords_p, const lv_area_t * mask_p, const lv_style_t * style_p, const char * fn); /** * Draw a line * @param p1 first point of the line * @param p2 second point of the line * @param mask_pthe line will be drawn only on this area * @param style_p pointer to a style */ void lv_draw_line(const lv_point_t * p1, const lv_point_t * p2, const lv_area_t * mask_p, const lv_style_t * style_p); /********************** * MACROS **********************/ #ifdef __cplusplus } /* extern "C" */ #endif #endif /*LV_DRAW_H*/