2012-03-16 14:42:35 +00:00
|
|
|
Layouts
|
2012-04-04 19:38:00 +00:00
|
|
|
--------
|
2012-03-16 14:42:35 +00:00
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
.. container:: title
|
2012-03-16 14:42:35 +00:00
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
Arranging Your Widgets
|
2012-04-04 10:04:52 +00:00
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
Layouts are used to arrange widgets in a perticular manner. ::
|
|
|
|
|
|
|
|
AnchorLayout: widgets can be anchored to 'top', 'bottom', 'left', 'right'
|
|
|
|
BoxLayout: widgets arranged in a box either in 'vertical' or 'horizontal' orientation
|
|
|
|
FloatLayout: Widgets are essentially unrestricted
|
|
|
|
GridLayout: widgets arranged in grids of rows and columns defined by ``rows`` and ``cols`` properties
|
|
|
|
StackLayout: widgets are stacked in ``lr-tp`` (left to right then top to bottom) or ``tp-lr``
|
|
|
|
|
|
|
|
**Size_hint**: defines the size of a widget in parent space in percentages, values restricted to range 0 - 1 i.e. 0.01 = 1% and 1. = 100%.
|
|
|
|
|
|
|
|
Eg. ::
|
|
|
|
|
|
|
|
widget.size_hint_x = .5
|
|
|
|
|
|
|
|
sets the width of the widget to 50% of free space in parent.
|
2012-04-04 10:04:52 +00:00
|
|
|
|
|
|
|
Consider widgets w1, w2, w3
|
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
w1.size_hint_x = 1, w2.size_hint_x = 1, w3.size_hint_x = 1 ::
|
|
|
|
|
2012-04-04 10:04:52 +00:00
|
|
|
[(111111111111)]<-parent width = 12
|
|
|
|
w1
|
2012-04-04 19:38:00 +00:00
|
|
|
width: 12
|
|
|
|
|
2012-04-04 10:04:52 +00:00
|
|
|
[(1111)(1111)(1111)]<-parent width = 12
|
|
|
|
w1 w2 w3
|
|
|
|
width: 4 4 4
|
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
w2.size_hint_x = .5 ::
|
|
|
|
|
2012-04-04 10:04:52 +00:00
|
|
|
[(11111)(11)(11111)]<-parent width: 12
|
|
|
|
w1 w2 w3
|
|
|
|
width: 5 2 5
|
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
w2.size_hint_x = 2 ::
|
|
|
|
|
2012-04-04 10:04:52 +00:00
|
|
|
[(11)(11111111)(11)]<-parent width: 12
|
|
|
|
w1 w2 w3
|
|
|
|
width: 2 8 2
|
|
|
|
|
|
|
|
The above notation doesn't work on float layouts. There widgets size when set using size_hint is not dependent on it's sibblings sizes.
|
|
|
|
|
|
|
|
size_hint_x or size_hint_y is used to calculate widget's size only if the value/s are not set to None.
|
|
|
|
|
|
|
|
|
|
|
|
Layout illustrations:
|
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
.. image:: ../images/anchorlayout.gif
|
|
|
|
:alt: AnchorLayout illustration
|
|
|
|
:class: gs-layoutimage
|
|
|
|
|
|
|
|
.. image:: ../images/boxlayout.gif
|
|
|
|
:alt: AnchorLayout illustration
|
|
|
|
:class: gs-layoutimage
|
|
|
|
|
|
|
|
.. image:: ../images/floatlayout.gif
|
2012-04-04 10:04:52 +00:00
|
|
|
:alt: AnchorLayout illustration
|
|
|
|
:class: gs-layoutimage
|
2012-03-16 14:42:35 +00:00
|
|
|
|
2012-04-04 19:38:00 +00:00
|
|
|
.. image:: ../images/gridlayout.gif
|
|
|
|
:alt: AnchorLayout illustration
|
|
|
|
:class: gs-layoutimage
|
|
|
|
|
|
|
|
.. image:: ../images/stacklayout.gif
|
|
|
|
:alt: AnchorLayout illustration
|
|
|
|
:class: gs-layoutimage
|