2011-06-19 17:43:10 +00:00
|
|
|
.. _widgettree:
|
|
|
|
|
|
|
|
Widget tree
|
|
|
|
===========
|
|
|
|
|
2012-02-15 03:52:14 +00:00
|
|
|
Like most GUI toolkits, Kivy has a tree for handling a hierarchy of widgets.
|
|
|
|
The top level widget is called "root". Each widget can be connected to other
|
2011-06-19 17:43:10 +00:00
|
|
|
widgets, as a parent or as a child.
|
|
|
|
|
|
|
|
You cannot add into the widget tree something that is not a
|
|
|
|
:class:`~kivy.uix.widget.Widget` subclass.
|
|
|
|
|
|
|
|
Manipulating the tree
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
The tree can be manipulated with 3 methods:
|
|
|
|
|
|
|
|
- :meth:`~kivy.uix.widget.Widget.add_widget`: add a widget as a child
|
|
|
|
- :meth:`~kivy.uix.widget.Widget.remove_widget`: remove a widget from the
|
|
|
|
children list
|
|
|
|
- :meth:`~kivy.uix.widget.Widget.clear_widgets`: remove all children from a
|
|
|
|
widget
|
|
|
|
|
|
|
|
For example, if you want to add a button inside a boxlayout, you can do::
|
|
|
|
|
|
|
|
layout = BoxLayout(padding=10)
|
|
|
|
button = Button(text='My first button')
|
|
|
|
layout.add_widget(button)
|
|
|
|
|
|
|
|
Now, the button parent will be set to layout, and layout will have button in his
|
|
|
|
children list. To remove the button from the layout::
|
|
|
|
|
|
|
|
layout.remove_widget(button)
|
|
|
|
|
|
|
|
The button parent will be set to None, and layout will remove button from his
|
|
|
|
children list.
|
|
|
|
|
|
|
|
If you want to clear all the children inside a widget, use
|
|
|
|
:meth:`~kivy.uix.widget.Widget.clear_widgets` method::
|
|
|
|
|
|
|
|
layout.clear_widgets()
|
|
|
|
|
|
|
|
.. warning::
|
|
|
|
|
|
|
|
Never manipulate the children list yourself, if you don't know what you are
|
|
|
|
doing. The widget tree is associated to a graphic tree. For example, if you
|
2012-02-15 09:22:56 +00:00
|
|
|
add a widget into the children list without adding its canvas to the
|
|
|
|
graphics tree, the widget will be a child yes, but nothing will be drawn
|
2012-02-15 03:52:14 +00:00
|
|
|
on the screen. More than that, you might have issues on further calls of
|
2011-06-19 17:43:10 +00:00
|
|
|
add_widget, remove_widget and clear_widgets.
|
|
|
|
|
|
|
|
|
|
|
|
Traversing the tree
|
|
|
|
-------------------
|
|
|
|
|
2012-02-15 03:52:14 +00:00
|
|
|
The widget class has a :data:`~kivy.uix.widget.Widget.children` list property
|
2012-07-22 15:08:33 +00:00
|
|
|
that contains all the children. You can easily traverse the tree by doing::
|
2011-06-19 17:43:10 +00:00
|
|
|
|
|
|
|
root = BoxLayout()
|
|
|
|
# ... add widgets to root ...
|
|
|
|
for child in root.children:
|
|
|
|
print child
|
|
|
|
|
|
|
|
However, this must be used carefuly. If you intend to modify the children list
|
2012-02-15 03:52:14 +00:00
|
|
|
with one of the methods shown in the previous section, you must use a copy of
|
2011-06-19 17:43:10 +00:00
|
|
|
the list like this::
|
|
|
|
|
|
|
|
for child in root.children[:]:
|
2012-02-15 03:52:14 +00:00
|
|
|
# manipulate the tree. For example here, remove all widgets that have a
|
2011-06-19 17:43:10 +00:00
|
|
|
# width < 100
|
|
|
|
if child.width < 100:
|
|
|
|
root.remove_widget(child)
|