mirror of
https://github.com/lvgl/lvgl.git
synced 2025-01-14 06:42:58 +08:00
740 lines
36 KiB
Python
Executable File
740 lines
36 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
|
|
import os
|
|
import re
|
|
import sys
|
|
|
|
props = [
|
|
{'section': 'Size and position', 'dsc':'Properties related to size, position, alignment and layout of Widgets.' },
|
|
{'name': 'WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':'Widget dependent', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets width of Widget. Pixel, percentage and `LV_SIZE_CONTENT` values can be used. Percentage values are relative to the width of the parent's content area."},
|
|
|
|
{'name': 'MIN_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets a minimal width. Pixel and percentage values can be used. Percentage values are relative to the width of the parent's content area."},
|
|
|
|
{'name': 'MAX_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':'LV_COORD_MAX', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets a maximal width. Pixel and percentage values can be used. Percentage values are relative to the width of the parent's content area."},
|
|
|
|
{'name': 'HEIGHT',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':'Widget dependent', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets height of Widget. Pixel, percentage and `LV_SIZE_CONTENT` can be used. Percentage values are relative to the height of the parent's content area."},
|
|
|
|
{'name': 'MIN_HEIGHT',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets a minimal height. Pixel and percentage values can be used. Percentage values are relative to the width of the parent's content area."},
|
|
|
|
{'name': 'MAX_HEIGHT',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':'LV_COORD_MAX', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets a maximal height. Pixel and percentage values can be used. Percentage values are relative to the height of the parent's content area."},
|
|
|
|
{'name': 'LENGTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':'0', 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Its meaning depends on the type of Widget. For example in case of lv_scale it means the length of the ticks."},
|
|
|
|
{'name': 'X',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set X coordinate of Widget considering the ``align`` setting. Pixel and percentage values can be used. Percentage values are relative to the width of the parent's content area."},
|
|
|
|
{'name': 'Y',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set Y coordinate of Widget considering the ``align`` setting. Pixel and percentage values can be used. Percentage values are relative to the height of the parent's content area."},
|
|
|
|
{'name': 'ALIGN',
|
|
'style_type': 'num', 'var_type': 'lv_align_t', 'default':'`LV_ALIGN_DEFAULT`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set the alignment which tells from which point of the parent the X and Y coordinates should be interpreted. Possible values are: `LV_ALIGN_DEFAULT`, `LV_ALIGN_TOP_LEFT/MID/RIGHT`, `LV_ALIGN_BOTTOM_LEFT/MID/RIGHT`, `LV_ALIGN_LEFT/RIGHT_MID`, `LV_ALIGN_CENTER`. `LV_ALIGN_DEFAULT` means `LV_ALIGN_TOP_LEFT` with LTR base direction and `LV_ALIGN_TOP_RIGHT` with RTL base direction."},
|
|
|
|
{'name': 'TRANSFORM_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Make Widget wider on both sides with this value. Pixel and percentage (with `lv_pct(x)`) values can be used. Percentage values are relative to Widget's width." },
|
|
|
|
{'name': 'TRANSFORM_HEIGHT',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Make Widget higher on both sides with this value. Pixel and percentage (with `lv_pct(x)`) values can be used. Percentage values are relative to Widget's height." },
|
|
|
|
{'name': 'TRANSLATE_X',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Move Widget with this value in X direction. Applied after layouts, aligns and other positioning. Pixel and percentage (with `lv_pct(x)`) values can be used. Percentage values are relative to Widget's width." },
|
|
|
|
{'name': 'TRANSLATE_Y',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Move Widget with this value in Y direction. Applied after layouts, aligns and other positioning. Pixel and percentage (with `lv_pct(x)`) values can be used. Percentage values are relative to Widget's height." },
|
|
|
|
{'name': 'TRANSLATE_RADIAL',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Move object around the centre of the parent object (e.g. around the circumference of a scale)"},
|
|
|
|
{'name': 'TRANSFORM_SCALE_X',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 1,
|
|
'dsc': "Zoom Widget horizontally. The value 256 (or `LV_SCALE_NONE`) means normal size, 128 half size, 512 double size, and so on" },
|
|
|
|
{'name': 'TRANSFORM_SCALE_Y',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 1,
|
|
'dsc': "Zoom Widget vertically. The value 256 (or `LV_SCALE_NONE`) means normal size, 128 half size, 512 double size, and so on" },
|
|
|
|
{'name': 'TRANSFORM_ROTATION',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 1,
|
|
'dsc': "Rotate Widget. The value is interpreted in 0.1 degree units. E.g. 450 means 45 deg."},
|
|
|
|
{'name': 'TRANSFORM_PIVOT_X',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set pivot point's X coordinate for transformations. Relative to Widget's top left corner'"},
|
|
|
|
{'name': 'TRANSFORM_PIVOT_Y',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set pivot point's Y coordinate for transformations. Relative to Widget's top left corner'"},
|
|
|
|
{'name': 'TRANSFORM_SKEW_X',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 1,
|
|
'dsc': "Skew Widget horizontally. The value is interpreted in 0.1 degree units. E.g. 450 means 45 deg."},
|
|
|
|
{'name': 'TRANSFORM_SKEW_Y',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 1,
|
|
'dsc': "Skew Widget vertically. The value is interpreted in 0.1 degree units. E.g. 450 means 45 deg."},
|
|
|
|
{'section': 'Padding', 'dsc' : "Properties to describe spacing between the parent's sides and the children and among the children. Very similar to the padding properties in HTML."},
|
|
{'name': 'PAD_TOP',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets the padding on the top. It makes the content area smaller in this direction."},
|
|
|
|
{'name': 'PAD_BOTTOM',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets the padding on the bottom. It makes the content area smaller in this direction."},
|
|
|
|
{'name': 'PAD_LEFT',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets the padding on the left. It makes the content area smaller in this direction."},
|
|
|
|
{'name': 'PAD_RIGHT',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets the padding on the right. It makes the content area smaller in this direction."},
|
|
|
|
{'name': 'PAD_ROW',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets the padding between the rows. Used by the layouts."},
|
|
|
|
{'name': 'PAD_COLUMN',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets the padding between the columns. Used by the layouts."},
|
|
|
|
{'name': 'PAD_RADIAL',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Pad text labels away from the scale ticks/remainder of the ``LV_PART_``"},
|
|
|
|
{'section': 'Margin', 'dsc' : "Properties to describe spacing around a Widget. Very similar to the margin properties in HTML."},
|
|
{'name': 'MARGIN_TOP',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets margin on the top. Widget will keep this space from its siblings in layouts."},
|
|
|
|
{'name': 'MARGIN_BOTTOM',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets margin on the bottom. Widget will keep this space from its siblings in layouts."},
|
|
|
|
{'name': 'MARGIN_LEFT',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets margin on the left. Widget will keep this space from its siblings in layouts."},
|
|
|
|
{'name': 'MARGIN_RIGHT',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Sets margin on the right. Widget will keep this space from its siblings in layouts."},
|
|
|
|
{'section': 'Background', 'dsc':'Properties to describe the background color and image of Widget.' },
|
|
{'name': 'BG_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t', 'default':'`0xffffff`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set background color of Widget."},
|
|
|
|
{'name': 'BG_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':'`LV_OPA_TRANSP`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of the background. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'name': 'BG_GRAD_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t', 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set gradient color of the background. Used only if `grad_dir` is not `LV_GRAD_DIR_NONE`"},
|
|
|
|
{'name': 'BG_GRAD_DIR',
|
|
'style_type': 'num', 'var_type': 'lv_grad_dir_t', 'default':'`LV_GRAD_DIR_NONE`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set direction of the gradient of the background. Possible values are `LV_GRAD_DIR_NONE/HOR/VER`."},
|
|
|
|
{'name': 'BG_MAIN_STOP',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set point from which background color should start for gradients. 0 means to top/left side, 255 the bottom/right side, 128 the center, and so on"},
|
|
|
|
{'name': 'BG_GRAD_STOP',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':255, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set point from which background's gradient color should start. 0 means to top/left side, 255 the bottom/right side, 128 the center, and so on"},
|
|
|
|
{'name': 'BG_MAIN_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':255, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of the first gradient color"},
|
|
|
|
{'name': 'BG_GRAD_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':255, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of the second gradient color"},
|
|
|
|
{'name': 'BG_GRAD',
|
|
'style_type': 'ptr', 'var_type': 'const lv_grad_dsc_t *', 'default':'`NULL`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set gradient definition. The pointed instance must exist while Widget is alive. NULL to disable. It wraps `BG_GRAD_COLOR`, `BG_GRAD_DIR`, `BG_MAIN_STOP` and `BG_GRAD_STOP` into one descriptor and allows creating gradients with more colors as well. If it's set other gradient related properties will be ignored'"},
|
|
|
|
{'name': 'BG_IMAGE_SRC',
|
|
'style_type': 'ptr', 'var_type': 'const void *', 'default':'`NULL`', 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set a background image. Can be a pointer to `lv_image_dsc_t`, a path to a file or an `LV_SYMBOL_...`"},
|
|
|
|
{'name': 'BG_IMAGE_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':'`LV_OPA_COVER`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of the background image. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'name': 'BG_IMAGE_RECOLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t', 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set a color to mix to the background image."},
|
|
|
|
{'name': 'BG_IMAGE_RECOLOR_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':'`LV_OPA_TRANSP`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set intensity of background image recoloring. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means no mixing, 255, `LV_OPA_100` or `LV_OPA_COVER` means full recoloring, other values or LV_OPA_10, LV_OPA_20, etc are interpreted proportionally."},
|
|
|
|
{'name': 'BG_IMAGE_TILED',
|
|
'style_type': 'num', 'var_type': 'bool', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "If enabled the background image will be tiled. Possible values are `true` or `false`."},
|
|
|
|
{'section': 'Border', 'dsc':'Properties to describe the borders' },
|
|
{'name': 'BORDER_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t', 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set color of the border"},
|
|
|
|
{'name': 'BORDER_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':'`LV_OPA_COVER`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of the border. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'name': 'BORDER_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set width of the border. Only pixel values can be used."},
|
|
|
|
{'name': 'BORDER_SIDE',
|
|
'style_type': 'num', 'var_type': 'lv_border_side_t', 'default':'`LV_BORDER_SIDE_NONE`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set only which side(s) the border should be drawn. Possible values are `LV_BORDER_SIDE_NONE/TOP/BOTTOM/LEFT/RIGHT/INTERNAL`. OR-ed values can be used as well, e.g. `LV_BORDER_SIDE_TOP | LV_BORDER_SIDE_LEFT`."},
|
|
|
|
{'name': 'BORDER_POST',
|
|
'style_type': 'num', 'var_type': 'bool' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Sets whether the border should be drawn before or after the children are drawn. `true`: after children, `false`: before children"},
|
|
|
|
{'section': 'Outline', 'dsc':'Properties to describe the outline. It\'s like a border but drawn outside of the rectangles.' },
|
|
{'name': 'OUTLINE_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set width of outline in pixels. "},
|
|
|
|
{'name': 'OUTLINE_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t' , 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set color of outline."},
|
|
|
|
{'name': 'OUTLINE_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':'`LV_OPA_COVER`', 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set opacity of outline. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'name': 'OUTLINE_PAD',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set padding of outline, i.e. the gap between Widget and the outline."},
|
|
|
|
{'section': 'Shadow', 'dsc':'Properties to describe the shadow drawn under the rectangles.' },
|
|
{'name': 'SHADOW_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set width of the shadow in pixels. The value should be >= 0."},
|
|
|
|
{'name': 'SHADOW_OFFSET_X',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set an offset on the shadow in pixels in X direction."},
|
|
|
|
{'name': 'SHADOW_OFFSET_Y',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set an offset on the shadow in pixels in Y direction."},
|
|
|
|
{'name': 'SHADOW_SPREAD',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Make shadow calculation to use a larger or smaller rectangle as base. The value can be in pixels to make the area larger/smaller"},
|
|
|
|
{'name': 'SHADOW_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t' , 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set color of shadow"},
|
|
|
|
{'name': 'SHADOW_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':'`LV_OPA_COVER`', 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set opacity of shadow. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'section': 'Image', 'dsc':'Properties to describe the images' },
|
|
{'name': 'IMAGE_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':'`LV_OPA_COVER`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of an image. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'name': 'IMAGE_RECOLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t', 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set color to mix with the image."},
|
|
|
|
{'name': 'IMAGE_RECOLOR_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set intensity of color mixing. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'section': 'Line', 'dsc':'Properties to describe line-like Widgets' },
|
|
{'name': 'LINE_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set width of lines in pixels."},
|
|
|
|
{'name': 'LINE_DASH_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set width of dashes in pixels. Note that dash works only on horizontal and vertical lines"},
|
|
|
|
{'name': 'LINE_DASH_GAP',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set gap between dashes in pixels. Note that dash works only on horizontal and vertical lines"},
|
|
|
|
{'name': 'LINE_ROUNDED',
|
|
'style_type': 'num', 'var_type': 'bool' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Make end points of the lines rounded. `true`: rounded, `false`: perpendicular line ending "},
|
|
|
|
{'name': 'LINE_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t' , 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set color of lines."},
|
|
|
|
{'name': 'LINE_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':'`LV_OPA_COVER`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of lines."},
|
|
|
|
{'section': 'Arc', 'dsc':'TODO' },
|
|
{'name': 'ARC_WIDTH',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 1,
|
|
'dsc': "Set width (thickness) of arcs in pixels."},
|
|
|
|
{'name': 'ARC_ROUNDED',
|
|
'style_type': 'num', 'var_type': 'bool' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Make end points of arcs rounded. `true`: rounded, `false`: perpendicular line ending "},
|
|
|
|
{'name': 'ARC_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t', 'default':'`0x000000`', 'inherited': 0, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Set color of arc."},
|
|
|
|
{'name': 'ARC_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':'`LV_OPA_COVER`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of arcs."},
|
|
|
|
{'name': 'ARC_IMAGE_SRC',
|
|
'style_type': 'ptr', 'var_type': 'const void *', 'default':'`NULL`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set an image from which arc will be masked out. It's useful to display complex effects on the arcs. Can be a pointer to `lv_image_dsc_t` or a path to a file"},
|
|
|
|
{'section': 'Text', 'dsc':'Properties to describe the properties of text. All these properties are inherited.' },
|
|
{'name': 'TEXT_COLOR',
|
|
'style_type': 'color', 'var_type': 'lv_color_t', 'default':'`0x000000`', 'inherited': 1, 'layout': 0, 'ext_draw': 0, 'filtered': 1,
|
|
'dsc': "Sets color of text."},
|
|
|
|
{'name': 'TEXT_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':'`LV_OPA_COVER`', 'inherited': 1, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set opacity of text. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency."},
|
|
|
|
{'name': 'TEXT_FONT',
|
|
'style_type': 'ptr', 'var_type': 'const lv_font_t *', 'default':'`LV_FONT_DEFAULT`', 'inherited': 1, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set font of text (a pointer `lv_font_t *`). "},
|
|
|
|
{'name': 'TEXT_LETTER_SPACE',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 1, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set letter space in pixels"},
|
|
|
|
{'name': 'TEXT_LINE_SPACE',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 1, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set line space in pixels."},
|
|
|
|
{'name': 'TEXT_DECOR',
|
|
'style_type': 'num', 'var_type': 'lv_text_decor_t' , 'default':'`LV_TEXT_DECOR_NONE`', 'inherited': 1, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set decoration for the text. Possible values are `LV_TEXT_DECOR_NONE/UNDERLINE/STRIKETHROUGH`. OR-ed values can be used as well." },
|
|
|
|
{'name': 'TEXT_ALIGN',
|
|
'style_type': 'num', 'var_type': 'lv_text_align_t' , 'default':'`LV_TEXT_ALIGN_AUTO`', 'inherited': 1, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set how to align the lines of the text. Note that it doesn't align the Widget itself, only the lines inside the Widget. Possible values are `LV_TEXT_ALIGN_LEFT/CENTER/RIGHT/AUTO`. `LV_TEXT_ALIGN_AUTO` detect the text base direction and uses left or right alignment accordingly"},
|
|
|
|
{'section': 'Miscellaneous', 'dsc':'Mixed properties for various purposes.' },
|
|
{'name': 'RADIUS',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Set radius on every corner. The value is interpreted in pixels (>= 0) or `LV_RADIUS_CIRCLE` for max. radius"},
|
|
|
|
{'name': 'RADIAL_OFFSET',
|
|
'style_type': 'num', 'var_type': 'int32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Move start point of object (e.g. scale tick) radially"},
|
|
|
|
{'name': 'CLIP_CORNER',
|
|
'style_type': 'num', 'var_type': 'bool', 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Enable to clip the overflowed content on the rounded corner. Can be `true` or `false`." },
|
|
|
|
{'name': 'OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':'`LV_OPA_COVER`', 'inherited': 1, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Scale down all opacity values of the Widget by this factor. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency." },
|
|
|
|
{'name': 'OPA_LAYERED',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t', 'default':'`LV_OPA_COVER`', 'inherited': 1, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "First draw Widget on the layer, then scale down layer opacity factor. Value 0, `LV_OPA_0` or `LV_OPA_TRANSP` means fully transparent, 255, `LV_OPA_100` or `LV_OPA_COVER` means fully covering, other values or LV_OPA_10, LV_OPA_20, etc means semi transparency." },
|
|
|
|
{'name': 'COLOR_FILTER_DSC',
|
|
'style_type': 'ptr', 'var_type': 'const lv_color_filter_dsc_t *', 'default':'`NULL`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Mix a color with all colors of the Widget." },
|
|
|
|
{'name': 'COLOR_FILTER_OPA',
|
|
'style_type': 'num', 'var_type': 'lv_opa_t' , 'default':'`LV_OPA_TRANSP`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "The intensity of mixing of color filter."},
|
|
|
|
{'name': 'ANIM',
|
|
'style_type': 'ptr', 'var_type': 'const lv_anim_t *', 'default':'`NULL`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Animation template for Widget's animation. Should be a pointer to `lv_anim_t`. The animation parameters are widget specific, e.g. animation time could be the E.g. blink time of the cursor on the text area or scroll time of a roller. See Widgets' documentation to learn more."},
|
|
|
|
{'name': 'ANIM_DURATION',
|
|
'style_type': 'num', 'var_type': 'uint32_t' , 'default':0, 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Animation duration in milliseconds. Its meaning is widget specific. E.g. blink time of the cursor on the text area or scroll time of a roller. See Widgets' documentation to learn more."},
|
|
|
|
{'name': 'TRANSITION',
|
|
'style_type': 'ptr', 'var_type': 'const lv_style_transition_dsc_t *' , 'default':'`NULL`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "An initialized ``lv_style_transition_dsc_t`` to describe a transition."},
|
|
|
|
{'name': 'BLEND_MODE',
|
|
'style_type': 'num', 'var_type': 'lv_blend_mode_t' , 'default':'`LV_BLEND_MODE_NORMAL`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Describes how to blend the colors to the background. Possible values are `LV_BLEND_MODE_NORMAL/ADDITIVE/SUBTRACTIVE/MULTIPLY`"},
|
|
|
|
{'name': 'LAYOUT',
|
|
'style_type': 'num', 'var_type': 'uint16_t', 'default':0, 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set layout of Widget. Children will be repositioned and resized according to policies set for the layout. For possible values see documentation of the layouts."},
|
|
|
|
{'name': 'BASE_DIR',
|
|
'style_type': 'num', 'var_type': 'lv_base_dir_t', 'default':'`LV_BASE_DIR_AUTO`', 'inherited': 1, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set base direction of Widget. Possible values are `LV_BIDI_DIR_LTR/RTL/AUTO`."},
|
|
|
|
{'name': 'BITMAP_MASK_SRC',
|
|
'style_type': 'ptr', 'var_type': 'const void *', 'default':'`NULL`', 'inherited': 0, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "If set, a layer will be created for the widget and the layer will be masked with this A8 bitmap mask."},
|
|
|
|
{'name': 'ROTARY_SENSITIVITY',
|
|
'style_type': 'num', 'var_type': 'uint32_t', 'default':'`256`', 'inherited': 1, 'layout': 0, 'ext_draw': 0,
|
|
'dsc': "Adjust sensitivity for rotary encoders in 1/256 unit. It means, 128: slow down the rotary to half, 512: speeds up to double, 256: no change"},
|
|
|
|
{'section': 'Flex', 'dsc':'Flex layout properties.', 'guard':'LV_USE_FLEX'},
|
|
|
|
|
|
{'name': 'FLEX_FLOW',
|
|
'style_type': 'num', 'var_type': 'lv_flex_flow_t', 'default':'`LV_FLEX_FLOW_NONE`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Defines in which direct the flex layout should arrange the children"},
|
|
|
|
|
|
{'name': 'FLEX_MAIN_PLACE',
|
|
'style_type': 'num', 'var_type': 'lv_flex_align_t', 'default':'`LV_FLEX_ALIGN_NONE`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Defines how to align the children in the direction of flex flow"},
|
|
|
|
|
|
{'name': 'FLEX_CROSS_PLACE',
|
|
'style_type': 'num', 'var_type': 'lv_flex_align_t', 'default':'`LV_FLEX_ALIGN_NONE`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Defines how to align the children perpendicular to the direction of flex flow"},
|
|
|
|
|
|
{'name': 'FLEX_TRACK_PLACE',
|
|
'style_type': 'num', 'var_type': 'lv_flex_align_t', 'default':'`LV_FLEX_ALIGN_NONE`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Defines how to align the tracks of the flow"},
|
|
|
|
{'name': 'FLEX_GROW',
|
|
'style_type': 'num', 'var_type': 'uint8_t', 'default':'`LV_FLEX_ALIGN_ROW`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Defines how much space to take proportionally from the free space of the Widget's track"},
|
|
|
|
|
|
|
|
{'section': 'Grid', 'dsc':'Grid layout properties.', 'guard':'LV_USE_GRID'},
|
|
|
|
|
|
{'name': 'GRID_COLUMN_DSC_ARRAY',
|
|
'style_type': 'ptr', 'var_type': 'const int32_t *', 'default':'`NULL`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "An array to describe the columns of the grid. Should be LV_GRID_TEMPLATE_LAST terminated"},
|
|
|
|
{'name': 'GRID_COLUMN_ALIGN',
|
|
'style_type': 'num', 'var_type': 'lv_grid_align_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Defines how to distribute the columns"},
|
|
|
|
|
|
{'name': 'GRID_ROW_DSC_ARRAY',
|
|
'style_type': 'ptr', 'var_type': 'const int32_t *', 'default':'`NULL`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "An array to describe the rows of the grid. Should be LV_GRID_TEMPLATE_LAST terminated"},
|
|
|
|
{'name': 'GRID_ROW_ALIGN',
|
|
'style_type': 'num', 'var_type': 'lv_grid_align_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Defines how to distribute the rows."},
|
|
|
|
{'name': 'GRID_CELL_COLUMN_POS',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set column in which Widget should be placed."},
|
|
|
|
{'name': 'GRID_CELL_X_ALIGN',
|
|
'style_type': 'num', 'var_type': 'lv_grid_align_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set how to align Widget horizontally."},
|
|
|
|
{'name': 'GRID_CELL_COLUMN_SPAN',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set how many columns Widget should span. Needs to be >= 1."},
|
|
|
|
{'name': 'GRID_CELL_ROW_POS',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set row in which Widget should be placed."},
|
|
|
|
{'name': 'GRID_CELL_Y_ALIGN',
|
|
'style_type': 'num', 'var_type': 'lv_grid_align_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set how to align Widget vertically."},
|
|
|
|
{'name': 'GRID_CELL_ROW_SPAN',
|
|
'style_type': 'num', 'var_type': 'int32_t', 'default':'`LV_GRID_ALIGN_START`', 'inherited': 0, 'layout': 1, 'ext_draw': 0,
|
|
'dsc': "Set how many rows Widget should span. Needs to be >= 1."},
|
|
]
|
|
|
|
|
|
def style_get_cast(style_type, var_type):
|
|
cast = ""
|
|
if style_type != 'color':
|
|
cast = "(" + var_type + ")"
|
|
return cast
|
|
|
|
|
|
def obj_style_get(p):
|
|
if 'section' in p: return
|
|
|
|
cast = style_get_cast(p['style_type'], p['var_type'])
|
|
print("static inline " + p['var_type'] + " lv_obj_get_style_" + p['name'].lower() +"(const lv_obj_t * obj, lv_part_t part)")
|
|
print("{")
|
|
print(" lv_style_value_t v = lv_obj_get_style_prop(obj, part, LV_STYLE_" + p['name'] + ");")
|
|
print(" return " + cast + "v." + p['style_type'] + ";")
|
|
print("}")
|
|
print("")
|
|
|
|
if 'filtered' in p and p['filtered']:
|
|
print("static inline " + p['var_type'] + " lv_obj_get_style_" + p['name'].lower() +"_filtered(const lv_obj_t * obj, lv_part_t part)")
|
|
print("{")
|
|
print(" lv_style_value_t v = lv_obj_style_apply_color_filter(obj, part, lv_obj_get_style_prop(obj, part, LV_STYLE_" + p['name'] + "));")
|
|
print(" return " + cast + "v." + p['style_type'] + ";")
|
|
print("}")
|
|
print("")
|
|
|
|
|
|
|
|
def style_set_cast(style_type):
|
|
cast = ""
|
|
if style_type == 'num':
|
|
cast = "(int32_t)"
|
|
return cast
|
|
|
|
|
|
def style_set_c(p):
|
|
if 'section' in p: return
|
|
|
|
cast = style_set_cast(p['style_type'])
|
|
print("")
|
|
print("void lv_style_set_" + p['name'].lower() +"(lv_style_t * style, "+ p['var_type'] +" value)")
|
|
print("{")
|
|
print(" lv_style_value_t v = {")
|
|
print(" ." + p['style_type'] +" = " + cast + "value")
|
|
print(" };")
|
|
print(" lv_style_set_prop(style, LV_STYLE_" + p['name'] +", v);")
|
|
print("}")
|
|
|
|
|
|
def style_set_h(p):
|
|
if 'section' in p: return
|
|
|
|
print("void lv_style_set_" + p['name'].lower() +"(lv_style_t * style, "+ p['var_type'] +" value);")
|
|
|
|
|
|
def local_style_set_c(p):
|
|
if 'section' in p: return
|
|
|
|
cast = style_set_cast(p['style_type'])
|
|
print("")
|
|
print("void lv_obj_set_style_" + p['name'].lower() + "(lv_obj_t * obj, " + p['var_type'] +" value, lv_style_selector_t selector)")
|
|
print("{")
|
|
print(" lv_style_value_t v = {")
|
|
print(" ." + p['style_type'] +" = " + cast + "value")
|
|
print(" };")
|
|
print(" lv_obj_set_local_style_prop(obj, LV_STYLE_" + p['name'] +", v, selector);")
|
|
print("}")
|
|
|
|
|
|
def local_style_set_h(p):
|
|
if 'section' in p: return
|
|
print("void lv_obj_set_style_" + p['name'].lower() + "(lv_obj_t * obj, " + p['var_type'] +" value, lv_style_selector_t selector);")
|
|
|
|
|
|
def style_const_set(p):
|
|
if 'section' in p: return
|
|
|
|
cast = style_set_cast(p['style_type'])
|
|
print("")
|
|
print("#define LV_STYLE_CONST_" + p['name'] + "(val) \\")
|
|
print(" { \\")
|
|
print(" .prop = LV_STYLE_" + p['name'] + ", .value = { ." + p['style_type'] +" = " + cast + "val } \\")
|
|
print(" }")
|
|
|
|
|
|
def docs(p):
|
|
if "section" in p:
|
|
print("")
|
|
print(p['section'])
|
|
print("-" * len(p['section']))
|
|
print("")
|
|
print(p['dsc'])
|
|
return
|
|
|
|
if "default" not in p: return
|
|
|
|
d = str(p["default"])
|
|
|
|
i = "No"
|
|
if p["inherited"]: i = "Yes"
|
|
|
|
l = "No"
|
|
if p["layout"]: l = "Yes"
|
|
|
|
e = "No"
|
|
if p["ext_draw"]: e = "Yes"
|
|
|
|
li_style = "style='display:inline-block; margin-right: 20px; margin-left: 0px"
|
|
|
|
dsc = p['dsc']
|
|
|
|
print("")
|
|
print(p["name"].lower())
|
|
print("~" * len(p["name"].lower()))
|
|
print("")
|
|
print(dsc)
|
|
|
|
|
|
print("")
|
|
print(".. raw:: html")
|
|
print("")
|
|
print(" <ul>")
|
|
print(" <li " + li_style + "'><strong>Default</strong> " + d + "</li>")
|
|
print(" <li " + li_style + "'><strong>Inherited</strong> " + i + "</li>")
|
|
print(" <li " + li_style + "'><strong>Layout</strong> " + l + "</li>")
|
|
print(" <li " + li_style + "'><strong>Ext. draw</strong> " + e + "</li>")
|
|
print(" </ul>")
|
|
|
|
def guard_proc(p):
|
|
global guard
|
|
if 'section' in p:
|
|
if guard:
|
|
guard_close()
|
|
if 'guard' in p:
|
|
guard = p['guard']
|
|
print(f"#if {guard}")
|
|
|
|
def guard_close():
|
|
global guard
|
|
if guard:
|
|
print(f"#endif /*{guard}*/\n")
|
|
guard = ""
|
|
|
|
base_dir = os.path.abspath(os.path.dirname(__file__))
|
|
sys.stdout = open(base_dir + '/../src/core/lv_obj_style_gen.h', 'w')
|
|
|
|
|
|
HEADING = f'''
|
|
/*
|
|
**********************************************************************
|
|
* DO NOT EDIT
|
|
* This file is automatically generated by "{os.path.split(__file__)[-1]}"
|
|
**********************************************************************
|
|
*/
|
|
|
|
'''
|
|
|
|
print(HEADING)
|
|
print('#ifndef LV_OBJ_STYLE_GEN_H')
|
|
print('#define LV_OBJ_STYLE_GEN_H')
|
|
print()
|
|
print('''\
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
''')
|
|
print("#include \"../misc/lv_area.h\"")
|
|
print("#include \"../misc/lv_style.h\"")
|
|
print("#include \"../core/lv_obj_style.h\"")
|
|
print("#include \"../misc/lv_types.h\"")
|
|
print()
|
|
|
|
guard = ""
|
|
for p in props:
|
|
guard_proc(p)
|
|
obj_style_get(p)
|
|
guard_close()
|
|
|
|
for p in props:
|
|
guard_proc(p)
|
|
local_style_set_h(p)
|
|
guard_close()
|
|
|
|
print()
|
|
print('''\
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
''')
|
|
|
|
print('#endif /* LV_OBJ_STYLE_GEN_H */')
|
|
|
|
sys.stdout = open(base_dir + '/../src/core/lv_obj_style_gen.c', 'w')
|
|
|
|
print(HEADING)
|
|
print("#include \"lv_obj.h\"")
|
|
print()
|
|
|
|
for p in props:
|
|
guard_proc(p)
|
|
local_style_set_c(p)
|
|
guard_close()
|
|
|
|
sys.stdout = open(base_dir + '/../src/misc/lv_style_gen.c', 'w')
|
|
|
|
print(HEADING)
|
|
print("#include \"lv_style.h\"")
|
|
print()
|
|
|
|
for p in props:
|
|
guard_proc(p)
|
|
style_set_c(p)
|
|
guard_close()
|
|
|
|
sys.stdout = open(base_dir + '/../src/misc/lv_style_gen.h', 'w')
|
|
|
|
print(HEADING)
|
|
print('#ifndef LV_STYLE_GEN_H')
|
|
print('#define LV_STYLE_GEN_H')
|
|
print()
|
|
print('''\
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
''')
|
|
|
|
for p in props:
|
|
guard_proc(p)
|
|
style_set_h(p)
|
|
guard_close()
|
|
|
|
for p in props:
|
|
guard_proc(p)
|
|
style_const_set(p)
|
|
guard_close()
|
|
|
|
print()
|
|
print('''\
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
''')
|
|
print('#endif /* LV_STYLE_GEN_H */')
|
|
|
|
sys.stdout = open(base_dir + '/../docs/details/base-widget/styles/style-properties.rst', 'w')
|
|
|
|
print('.. _style_properties:')
|
|
print()
|
|
print('================')
|
|
print('Style Properties')
|
|
print('================')
|
|
|
|
for p in props:
|
|
docs(p)
|