File: tips.rst

package info (click to toggle)
python-traitsui 4.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 13,292 kB
  • sloc: python: 39,867; makefile: 120; sh: 5
file content (70 lines) | stat: -rw-r--r-- 2,691 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70

.. _tips-tricks-and-gotchas:

========================
Tips, Tricks and Gotchas
========================

Getting and Setting Model View Elements 
---------------------------------------

For some applications, it can be necessary to retrieve or manipulate the View
objects associated with a given model object. The HasTraits class defines two
methods for this purpose: trait_views() and trait_view().

.. _trait-views:

trait_views()
`````````````

The trait_views() method, when called without arguments, returns a list
containing the names of all Views defined in the object's class. For example, if
**sam** is an object of type SimpleEmployee3 (from 
:ref:`Example 6 <example-6-defining-multiple-view-objects-in-a-hastraits-class>`), 
the method call ``sam.trait_views()`` returns the list ``['all_view',
'traits_view']``.

Alternatively, a call to :samp:`trait_views({view_element_type})` returns a list
of all named instances of class *view_element_type* defined in the object's
class. The possible values of *view_element_type* are:

- :term:`View`
- :term:`Group`
- :term:`Item`
- :term:`ViewElement`
- ViewSubElement

Thus calling ``trait_views(View)`` is identical to calling ``trait_views()``.
Note that the call ``sam.trait_views(Group)`` returns an empty list, even though
both of the Views defined in SimpleEmployee contain Groups. This is because only
*named* elements are returned by the method.

Group and Item are both subclasses of ViewSubElement, while ViewSubElement and
View are both subclasses of ViewElement. Thus, a call to
``trait_views(ViewSubElement)`` returns a list of named Items and Groups, while
``trait_views(ViewElement)`` returns a list of named Items, Groups and Views.

trait_view()
````````````

The trait_view() method is used for three distinct purposes: 

- To retrieve the default View associated with an object
- To retrieve a particular named ViewElement (i.e., Item, Group or View)
- To define a new named ViewElement 

For example:

- ``obj.trait_view()`` returns the default View associated with object *obj*.
  For example, ``sam.trait_view()`` returns the View object called 
  ``traits_view``. Note that unlike trait_views(), trait_view() returns the
  View itself, not its name.
- ``obj.trait_view('my_view')`` returns the view element named ``my_view`` 
  (or None if ``my_view`` is not defined).
- ``obj.trait_view('my_group', Group('a', 'b'))`` defines a Group with the name
  ``my_group``. Note that although this Group can be retrieved using 
  ``trait_view()``, its name does not appear in the list returned by 
  ``traits_view(Group)``. This is because ``my_group`` is associated with
  *obj* itself, rather than with its class.