kivy/doc/sources/gettingstarted/properties.rst

45 lines
1.5 KiB
ReStructuredText
Raw Normal View History

Properties
----------
2012-04-04 10:04:52 +00:00
Kivy introduce a new way of declaring the properties within a class.
Before::
class MyClass(object):
def __init__(self):
super(MyClass, self).__init__()
self.numeric_var = 1
After, using Kivy's properties::
class MyClass(EventDispatcher):
numeric_var = NumericProperty(1)
Theses properties implement the `Observer pattern
<http://en.wikipedia.org/wiki/Observer_pattern>`_. You can:
2012-04-04 10:04:52 +00:00
2012-05-28 16:42:11 +00:00
- Allow manipulating your widgets in kv language more easily
2012-04-18 19:12:50 +00:00
- Automatically observe any changes and dispatch functions/code accordingly
- Check and validate values
- Optimize memory management
2012-04-04 10:04:52 +00:00
2012-05-28 16:42:11 +00:00
To use them, **you have to declare them at class level**. That is, directly in
the class, not in any method of the class. A property is a class attribute
2012-05-28 16:42:11 +00:00
that will automatically create instance attributes. Each property by default
provides an ``on_<propertyname>`` event that is called whenever the property's
2012-05-28 16:42:11 +00:00
state/value changes .
2012-04-04 10:04:52 +00:00
2012-04-18 19:12:50 +00:00
Kivy provides the following properties:
:mod:`~kivy.properties.NumericProperty`,
:mod:`~kivy.properties.StringProperty`,
:mod:`~kivy.properties.ListProperty`,
:mod:`~kivy.properties.ObjectProperty`,
:mod:`~kivy.properties.BooleanProperty`,
:mod:`~kivy.properties.BoundedNumericProperty`,
:mod:`~kivy.properties.OptionProperty`,
:mod:`~kivy.properties.ReferenceListProperty`,
:mod:`~kivy.properties.AliasProperty`,
:mod:`~kivy.properties.DictProperty`,
For an in-depth explaination, look at :doc:`/api-kivy.properties`