BigW Consortium Gitlab
Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
L
lvgl
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Forest Godfrey
lvgl
Commits
280e039e
Commit
280e039e
authored
Sep 22, 2017
by
Kiss-Vamosi Gabor
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
lv_ddlist: change auto_size to fix_height
parent
4935b885
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
26 additions
and
30 deletions
+26
-30
lv_ddlist.c
lv_objx/lv_ddlist.c
+17
-22
lv_ddlist.h
lv_objx/lv_ddlist.h
+9
-8
No files found.
lv_objx/lv_ddlist.c
View file @
280e039e
...
@@ -69,7 +69,7 @@ lv_obj_t * lv_ddlist_create(lv_obj_t * par, lv_obj_t * copy)
...
@@ -69,7 +69,7 @@ lv_obj_t * lv_ddlist_create(lv_obj_t * par, lv_obj_t * copy)
ext
->
opt_label
=
NULL
;
ext
->
opt_label
=
NULL
;
ext
->
cb
=
NULL
;
ext
->
cb
=
NULL
;
ext
->
opened
=
0
;
ext
->
opened
=
0
;
ext
->
auto_size
=
0
;
ext
->
fix_height
=
0
;
ext
->
sel_opt
=
0
;
ext
->
sel_opt
=
0
;
ext
->
num_opt
=
0
;
ext
->
num_opt
=
0
;
ext
->
anim_time
=
LV_DDLIST_DEF_ANIM_TIME
;
ext
->
anim_time
=
LV_DDLIST_DEF_ANIM_TIME
;
...
@@ -85,7 +85,7 @@ lv_obj_t * lv_ddlist_create(lv_obj_t * par, lv_obj_t * copy)
...
@@ -85,7 +85,7 @@ lv_obj_t * lv_ddlist_create(lv_obj_t * par, lv_obj_t * copy)
if
(
copy
==
NULL
)
{
if
(
copy
==
NULL
)
{
lv_obj_t
*
scrl
=
lv_page_get_scrl
(
new_ddlist
);
lv_obj_t
*
scrl
=
lv_page_get_scrl
(
new_ddlist
);
lv_obj_set_drag
(
scrl
,
false
);
lv_obj_set_drag
(
scrl
,
false
);
lv_obj_set_style
(
scrl
,
lv_style_get
(
LV_STYLE_TRANSP
,
NULL
));
;
lv_obj_set_style
(
scrl
,
lv_style_get
(
LV_STYLE_TRANSP
,
NULL
));
lv_cont_set_fit
(
scrl
,
true
,
true
);
lv_cont_set_fit
(
scrl
,
true
,
true
);
ext
->
opt_label
=
lv_label_create
(
new_ddlist
,
NULL
);
ext
->
opt_label
=
lv_label_create
(
new_ddlist
,
NULL
);
...
@@ -101,7 +101,7 @@ lv_obj_t * lv_ddlist_create(lv_obj_t * par, lv_obj_t * copy)
...
@@ -101,7 +101,7 @@ lv_obj_t * lv_ddlist_create(lv_obj_t * par, lv_obj_t * copy)
ext
->
opt_label
=
lv_label_create
(
new_ddlist
,
copy_ext
->
opt_label
);
ext
->
opt_label
=
lv_label_create
(
new_ddlist
,
copy_ext
->
opt_label
);
lv_label_set_text
(
ext
->
opt_label
,
lv_label_get_text
(
copy_ext
->
opt_label
));
lv_label_set_text
(
ext
->
opt_label
,
lv_label_get_text
(
copy_ext
->
opt_label
));
ext
->
sel_opt
=
copy_ext
->
sel_opt
;
ext
->
sel_opt
=
copy_ext
->
sel_opt
;
ext
->
auto_size
=
copy_ext
->
auto_size
;
ext
->
fix_height
=
copy_ext
->
fix_height
;
ext
->
cb
=
copy_ext
->
cb
;
ext
->
cb
=
copy_ext
->
cb
;
ext
->
num_opt
=
copy_ext
->
num_opt
;
ext
->
num_opt
=
copy_ext
->
num_opt
;
...
@@ -130,8 +130,6 @@ bool lv_ddlist_signal(lv_obj_t * ddlist, lv_signal_t sign, void * param)
...
@@ -130,8 +130,6 @@ bool lv_ddlist_signal(lv_obj_t * ddlist, lv_signal_t sign, void * param)
* make the object specific signal handling */
* make the object specific signal handling */
if
(
valid
!=
false
)
{
if
(
valid
!=
false
)
{
if
(
sign
==
LV_SIGNAL_STYLE_CHG
)
{
if
(
sign
==
LV_SIGNAL_STYLE_CHG
)
{
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
lv_obj_set_style
(
ext
->
opt_label
,
lv_obj_get_style
(
ddlist
));
lv_ddlist_refr_size
(
ddlist
,
0
);
lv_ddlist_refr_size
(
ddlist
,
0
);
}
else
if
(
sign
==
LV_SIGNAL_FOCUS
)
{
}
else
if
(
sign
==
LV_SIGNAL_FOCUS
)
{
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
...
@@ -256,15 +254,16 @@ void lv_ddlist_set_action(lv_obj_t * ddlist, lv_action_t cb)
...
@@ -256,15 +254,16 @@ void lv_ddlist_set_action(lv_obj_t * ddlist, lv_action_t cb)
}
}
/**
/**
* Set the
auto size attribute. If enabled the height will reduced to be visible on the parent
.
* Set the
fix height value
.
* I
n this case the drop down list can be scroll
ed.
* I
f 0 then the opened ddlist will be auto. sized else the set height will be appli
ed.
* @param ddlist pointer to a drop down list
* @param ddlist pointer to a drop down list
* @param
auto_size true: enable auto size, false: disable
* @param
h the height when the list is opened (0: auto size)
*/
*/
void
lv_ddlist_set_
auto_size
(
lv_obj_t
*
ddlist
,
bool
auto_size
)
void
lv_ddlist_set_
fix_height
(
lv_obj_t
*
ddlist
,
cord_t
h
)
{
{
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
ext
->
auto_size
=
auto_size
==
false
?
0
:
1
;
ext
->
fix_height
=
h
;
lv_ddlist_refr_size
(
ddlist
,
0
);
}
}
/**
/**
...
@@ -356,14 +355,14 @@ void lv_ddlist_get_selected_str(lv_obj_t * ddlist, char * buf)
...
@@ -356,14 +355,14 @@ void lv_ddlist_get_selected_str(lv_obj_t * ddlist, char * buf)
}
}
/**
/**
* Get the
auto size attribut
e.
* Get the
fix height valu
e.
* @param ddlist pointer to a drop down list object
* @param ddlist pointer to a drop down list object
* @return t
rue: the auto_size is enabled, false: disabled
* @return t
he height if the ddlist is opened (0: auto size)
*/
*/
bool
lv_ddlist_get_auto_size
(
lv_obj_t
*
ddlist
,
bool
auto_size
)
cord_t
lv_ddlist_get_fix_height
(
lv_obj_t
*
ddlist
)
{
{
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
return
ext
->
auto_size
==
0
?
false
:
true
;
return
ext
->
fix_height
;
}
}
/**
/**
...
@@ -484,7 +483,7 @@ static lv_action_res_t lv_ddlist_rel_action(lv_obj_t * ddlist, lv_dispi_t * disp
...
@@ -484,7 +483,7 @@ static lv_action_res_t lv_ddlist_rel_action(lv_obj_t * ddlist, lv_dispi_t * disp
}
}
/**
/**
* Refresh the size of drop down list according its status (open or closed)
* Refresh the size of drop down list according
to
its status (open or closed)
* @param ddlist pointer to a drop down list object
* @param ddlist pointer to a drop down list object
* @param anim_time animations time for open/close [ms]
* @param anim_time animations time for open/close [ms]
*/
*/
...
@@ -493,13 +492,9 @@ static void lv_ddlist_refr_size(lv_obj_t * ddlist, uint16_t anim_time)
...
@@ -493,13 +492,9 @@ static void lv_ddlist_refr_size(lv_obj_t * ddlist, uint16_t anim_time)
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
lv_ddlist_ext_t
*
ext
=
lv_obj_get_ext
(
ddlist
);
lv_style_t
*
style
=
lv_obj_get_style
(
ddlist
);
lv_style_t
*
style
=
lv_obj_get_style
(
ddlist
);
cord_t
new_height
;
cord_t
new_height
;
if
(
ext
->
opened
!=
0
)
{
/*Open the list*/
if
(
ext
->
opened
)
{
/*Open the list*/
new_height
=
lv_obj_get_height
(
lv_page_get_scrl
(
ddlist
))
+
2
*
style
->
vpad
;
if
(
ext
->
fix_height
==
0
)
new_height
=
lv_obj_get_height
(
lv_page_get_scrl
(
ddlist
))
+
2
*
style
->
vpad
;
lv_obj_t
*
parent
=
lv_obj_get_parent
(
ddlist
);
else
new_height
=
ext
->
fix_height
;
/*Reduce the height if enabled and required*/
if
(
ext
->
auto_size
!=
0
&&
new_height
+
ddlist
->
cords
.
y1
>
parent
->
cords
.
y2
)
{
new_height
=
parent
->
cords
.
y2
-
ddlist
->
cords
.
y1
;
}
}
else
{
/*Close the list*/
}
else
{
/*Close the list*/
const
font_t
*
font
=
style
->
font
;
const
font_t
*
font
=
style
->
font
;
lv_style_t
*
label_style
=
lv_obj_get_style
(
ext
->
opt_label
);
lv_style_t
*
label_style
=
lv_obj_get_style
(
ext
->
opt_label
);
...
...
lv_objx/lv_ddlist.h
View file @
280e039e
...
@@ -48,7 +48,7 @@ typedef struct
...
@@ -48,7 +48,7 @@ typedef struct
uint16_t
sel_opt
;
/*Index of the current option*/
uint16_t
sel_opt
;
/*Index of the current option*/
uint16_t
anim_time
;
/*Open/Close animation time [ms]*/
uint16_t
anim_time
;
/*Open/Close animation time [ms]*/
uint8_t
opened
:
1
;
/*1: The list is opened*/
uint8_t
opened
:
1
;
/*1: The list is opened*/
uint8_t
auto_size
:
1
;
/*1: Set height to show all options. 0: Set height maximum to the parent bottom
*/
cord_t
fix_height
;
/*Height if the ddlist is opened. (0: auto-size)
*/
}
lv_ddlist_ext_t
;
}
lv_ddlist_ext_t
;
...
@@ -99,12 +99,12 @@ void lv_ddlist_set_selected(lv_obj_t * ddlist, uint16_t sel_opt);
...
@@ -99,12 +99,12 @@ void lv_ddlist_set_selected(lv_obj_t * ddlist, uint16_t sel_opt);
void
lv_ddlist_set_action
(
lv_obj_t
*
ddlist
,
lv_action_t
cb
);
void
lv_ddlist_set_action
(
lv_obj_t
*
ddlist
,
lv_action_t
cb
);
/**
/**
* Set the
auto size attribute. If enabled the height will reduced to be visible on the parent
.
* Set the
fix height value
.
* I
n this case the drop down list can be scroll
ed.
* I
f 0 then the opened ddlist will be auto. sized else the set height will be appli
ed.
* @param ddlist pointer to a drop down list
* @param ddlist pointer to a drop down list
* @param
auto_size true: enable auto size, false: disable
* @param
h the height when the list is opened (0: auto size)
*/
*/
void
lv_ddlist_set_
auto_size
(
lv_obj_t
*
ddlist
,
bool
auto_size
);
void
lv_ddlist_set_
fix_height
(
lv_obj_t
*
ddlist
,
cord_t
h
);
/**
/**
* Set the style of the rectangle on the selected option
* Set the style of the rectangle on the selected option
...
@@ -142,12 +142,13 @@ uint16_t lv_ddlist_get_selected(lv_obj_t * ddlist);
...
@@ -142,12 +142,13 @@ uint16_t lv_ddlist_get_selected(lv_obj_t * ddlist);
*/
*/
void
lv_ddlist_get_selected_str
(
lv_obj_t
*
ddlist
,
char
*
buf
);
void
lv_ddlist_get_selected_str
(
lv_obj_t
*
ddlist
,
char
*
buf
);
/**
/**
* Get the
auto size attribut
e.
* Get the
fix height valu
e.
* @param ddlist pointer to a drop down list object
* @param ddlist pointer to a drop down list object
* @return t
rue: the auto_size is enabled, false: disabled
* @return t
he height if the ddlist is opened (0: auto size)
*/
*/
bool
lv_ddlist_get_auto_size
(
lv_obj_t
*
ddlist
,
bool
auto_size
);
cord_t
lv_ddlist_get_fix_height
(
lv_obj_t
*
ddlist
);
/**
/**
* Get the style of the rectangle on the selected option
* Get the style of the rectangle on the selected option
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment