123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240 |
- /*
- * Copyright (c) 2020 Actions Technology Co., Ltd
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- /**
- * @file cube_map.h
- *
- */
- #ifndef FRAMEWORK_DISPLAY_LIBDISPLAY_LVGL_WIDGETS_CUBE_MAP_H_
- #define FRAMEWORK_DISPLAY_LIBDISPLAY_LVGL_WIDGETS_CUBE_MAP_H_
- #ifdef CONFIG_VG_LITE
- #ifdef __cplusplus
- extern "C" {
- #endif
- /*********************
- * INCLUDES
- *********************/
- #include <lvgl/lvgl.h>
- #include <vg_lite/vglite_util.h>
- /*********************
- * DEFINES
- *********************/
- /* workaround for vg_lite_blit() filter whose center located outside of image */
- #define CUBE_MAP_USE_BLIT_WAR 1
- #define CUBE_MAP_FRONT 0
- #define CUBE_MAP_BACK 1
- #define CUBE_MAP_RIGHT 2
- #define CUBE_MAP_LEFT 3
- #define CUBE_MAP_BOTTOM 4
- #define CUBE_MAP_TOP 5
- #define NUM_CUBE_FACES 6
- #define NUM_CUBE_VERTS 8
- /**********************
- * TYPEDEFS
- **********************/
- /** Data of rotate image */
- typedef struct {
- lv_obj_t obj;
- bool visible[NUM_CUBE_FACES];
- vg_lite_buffer_t images[NUM_CUBE_FACES];
- vertex_t verts[NUM_CUBE_VERTS];
- vg_lite_matrix_t extra_rotm;
- #if CUBE_MAP_USE_BLIT_WAR
- int16_t path_data[13];
- vg_lite_path_t path;
- #endif
- /* image transformed area (relative to the top-left of the object) */
- lv_area_t trans_area;
- /* Transformation center of the image, relative to the top-left corner of the image */
- float pivot_x;
- float pivot_y;
- float pivot_z;
- /* Euler angles in ZYX order from world coordinate to camera coordinate in 0.1 degree [0, 3600) */
- uint16_t angle_x; /* Rotation angle around fixed x-axis */
- uint16_t angle_y; /* Rotation angle around fixed y-axis */
- uint16_t angle_z; /* Rotation angle around fixed z-axis */
- uint8_t angle_order; /* Rotation order, see @rotate_order_e, ROT_ZYX by default */
- uint16_t zoom;
- const lv_img_dsc_t *src_dscs;
- lv_img_dsc_t decoded_imgs[NUM_CUBE_FACES];
- } cube_map_t;
- extern const lv_obj_class_t cube_map_class;
- /**********************
- * GLOBAL PROTOTYPES
- **********************/
- /**
- * Create an cube map object
- * @param parent pointer to an object, it will be the parent of the new image object
- * @return pointer to the created image object
- */
- lv_obj_t * cube_map_create(lv_obj_t * parent);
- /*=====================
- * Setter functions
- *====================*/
- /**
- * Set the pixel map to display by the image
- * @param obj pointer to an image object
- * @param src pointer to an image source variable array
- */
- void cube_map_set_src(lv_obj_t *obj, const lv_img_dsc_t * src);
- /**
- * Set the rotation center of the image.
- * The image will be rotated around this point
- * @param obj pointer to an image object
- * @param pivot_x rotation/zoom center x of the image
- * @param pivot_y rotation/zoom center y of the image
- * @param pivot_z rotation/zoom center z of the image
- */
- void cube_map_set_pivot(lv_obj_t * obj, float pivot_x, float pivot_y, float pivot_z);
- /**
- * Set the rotation angle around x-axis.
- * The image will be rotated around the set pivot set by `cube_map_set_pivot()`
- * @param obj pointer to an image object
- * @param angle rotation angle in degree with 0.1 degree resolution
- */
- void cube_map_set_angle_x(lv_obj_t * obj, int16_t angle);
- /**
- * Set the rotation angle around y-axis.
- * The image will be rotated around the set pivot set by `cube_map_set_pivot()`
- * @param obj pointer to an image object
- * @param angle rotation angle in degree with 0.1 degree resolution
- */
- void cube_map_set_angle_y(lv_obj_t * obj, int16_t angle);
- /**
- * Set the rotation angle around z-axis.
- * The image will be rotated around the set pivot set by `cube_map_set_pivot()`
- * @param obj pointer to an image object
- * @param angle rotation angle in degree with 0.1 degree resolution
- */
- void cube_map_set_angle_z(lv_obj_t * obj, int16_t angle);
- /**
- * Set the rotation angle.
- * The image will be rotated by ZYX order.
- * @param obj pointer to an image object
- * @param angle_x rotation angle around x-axis in degree with 0.1 degree resolution
- * @param angle_y rotation angle around y-axis in degree with 0.1 degree resolution
- * @param angle_z rotation angle around z-axis in degree with 0.1 degree resolution
- */
- void cube_map_set_angle(lv_obj_t * obj, int16_t angle_x, int16_t angle_y, int16_t angle_z);
- /**
- * Set axis rotation order
- * @param obj pointer to an image object
- * @param order axis rotation order
- */
- void cube_map_set_rotation_order(lv_obj_t * obj, uint8_t order);
- /**
- * Set the zoom factor of the image.
- * @param obj pointer to an image object
- * @param zoom the zoom factor.
- * @example 256 or LV_ZOOM_IMG_NONE for no zoom
- * @example <256: scale down
- * @example >256 scale up
- * @example 128 half size
- * @example 512 double size
- */
- void cube_map_set_zoom(lv_obj_t * obj, uint16_t zoom);
- /**
- * Reset the appended extra angles.
- * @param obj pointer to an image object
- */
- void cube_map_reset_appended_angles(lv_obj_t * obj);
- /**
- * Append a extra rotation angle around x-axis after Euler angle rotation.
- * The image will be rotated around the set pivot set by `cube_map_set_pivot()`
- * @param obj pointer to an image object
- * @param angle rotation angle in degree with 0.1 degree resolution
- */
- void cube_map_append_angle_x(lv_obj_t * obj, int16_t angle);
- /**
- * Append a extra rotation angle around y-axis after Euler angle rotation.
- * The image will be rotated around the set pivot set by `cube_map_set_pivot()`
- * @param obj pointer to an image object
- * @param angle rotation angle in degree with 0.1 degree resolution
- */
- void cube_map_append_angle_y(lv_obj_t * obj, int16_t angle);
- /**
- * Append a extra rotation angle around z-axis after Euler angle rotation.
- * The image will be rotated around the set pivot set by `cube_map_set_pivot()`
- * @param obj pointer to an image object
- * @param angle rotation angle in degree with 0.1 degree resolution
- */
- void cube_map_append_angle_z(lv_obj_t * obj, int16_t angle);
- /*=====================
- * Getter functions
- *====================*/
- /**
- * Get the source of the image.
- * @param obj pointer to an image object
- * @param face which image of face to get
- * @return the image source (symbol, file name or C array)
- */
- const void * cube_map_get_src(lv_obj_t * obj, uint8_t face);
- /**
- * Get the 8 vertices of the image.
- * @param obj pointer to an image object
- * @param face the image face
- * @param verts where to store the vertices (clock-wise sequence started from top-left corner)
- * @return N/A
- */
- void cube_map_get_vertices(lv_obj_t * obj, uint8_t face, vertex_t * verts);
- /**
- * Query the cube face is visible or not.
- * @param obj pointer to an image object
- * @param face which image of face to get
- * @return visible or not
- */
- bool cube_map_is_visible(lv_obj_t * obj, uint8_t face);
- /*=====================
- * Other functions
- *====================*/
- /**********************
- * MACROS
- **********************/
- #ifdef __cplusplus
- } /* extern "C" */
- #endif
- #endif /* CONFIG_VG_LITE */
- #endif /*FRAMEWORK_DISPLAY_LIBDISPLAY_LVGL_WIDGETS_CUBE_MAP_H_*/
|