1Prima::VB::Classes(3) User Contributed Perl DocumentationPrima::VB::Classes(3)
2
3
4
6 Prima::VB::Classes - Visual Builder widgets and types
7
9 Visual Builder is designed without a prior knowledge of the widget
10 classes that would be contained in its widget palette. Instead, it
11 provides a registration interface for new widgets and their specific
12 properties.
13
14 This document describes API, provided by the builder, and the widget
15 interface. Through the document, widget or widget class mean not the
16 original widget or class, but their representatives.
17
19 The widget must provide specific methods to cooperate with the builder.
20 It is not required, however, to contain these methods in its base
21 module or package; it can delegate its representation to another,
22 usually very light class, which is used by the builder.
23
24 Such a class must be derived from "Prima::VB::Object", which provides
25 base functionality. One of basic features here is overloading of
26 property change method. Since the user can change any property
27 interactively, the class can catch the properties of interest by
28 declaring "prf_XXX" method, where XXX is the property name.
29 "Prima::VB::Widget" declares set of these methods, assuming that a
30 widget would repaint when, for example, its "color" or "font"
31 properties change.
32
33 The hierarchy of VB classes mimics the one of the core toolkit classes,
34 but this is a mere resemblance, no other dependencies except the names
35 are present. The hierarchy is as follows:
36
37 Prima::VB::Object Prima::Widget
38 Prima::VB::Component
39 Prima::VB::Drawable
40 Prima::VB::Widget
41 Prima::VB::Control
42 Prima::VB::Window
43
44 NB: "Prima::VB::CoreClasses" extends the hierarchy to the full set of
45 default widget palette in the builder. This module is not provided with
46 documentation though since its function is obvious and its code is
47 trivial.
48
49 Since the real widgets are used in the interaction with the builder,
50 their properties are not touched when changed by the object inspector
51 or otherwise. The widgets keep the set of properties in a separated
52 hash. The properties are accessible by "prf" and "prf_set" methods.
53
54 A type object is a class used to represent a particular type of
55 property in object inspector window in the builder. The type objects,
56 like the widget classes, also are not hard-coded. The builder presents
57 a basic set of the type objects, which can be easily expanded. The
58 hierarchy ( incomplete ) of the type objects classes is as follows:
59
60 Prima::VB::Types::generic
61 Prima::VB::Types::bool
62 Prima::VB::Types::color
63 Prima::VB::Types::point
64 Prima::VB::Types::icon
65 Prima::VB::Types::Handle
66 Prima::VB::Types::textee
67 Prima::VB::Types::text
68 Prima::VB::Types::string
69 Prima::VB::Types::char
70 Prima::VB::Types::name
71 Prima::VB::Types::iv
72 Prima::VB::Types::uiv
73
74 The document does not describe the types, since their function can be
75 observed at runtime in the object inspector. Only
76 "Prima::VB::Types::generic" API is documented.
77
79 Properties
80 class STRING
81 Selects the original widget class. Create-only property.
82
83 creationOrder INTEGER
84 Selects the creation order of the widget.
85
86 module STRING
87 Selects the module that contains the original widget class. Create-
88 only property.
89
90 profile HASH
91 Selects the original widget profile. Create-only property. Changes
92 to profile at run-time performed by "prf_set" method.
93
94 Methods
95 act_profile
96 Returns hash of callbacks to be stored in the form file and
97 executed by "Prima::VB::VBLoader" when the form file is loaded.
98 The hash keys are names of VBLoader events and values - strings
99 with code to be eval'ed. See "Events" in Prima::VB::VBLoader for
100 description and format of the callbacks.
101
102 Called when the builder writes a form file.
103
104 add_hooks @PROPERTIES
105 Registers the object as a watcher to set of PROPERTIES. When any
106 object changes a property listed in the hook record, "on_hook"
107 callback is triggered.
108
109 Special name 'DESTROY' can be used to set a hook on object
110 destruction event.
111
112 ext_profile
113 Returns a class-specific hash, written in a form file. Its use is
114 to serve as a set of extra parameters, passed from the builder to
115 "act_profile" events.
116
117 prf_set %PROIFLE
118 A main method for setting a property of an object. PROFILE keys
119 are property names, and value are property values.
120
121 prf_adjust_default PROFILE, DEFAULT_PROFILE
122 DEFAULT_PROFILE is a result of "profile_default" call of the real
123 object class. However, not all properties usually are exported to
124 the object inspector. "prf_adjust_default" deletes the unneeded
125 property keys from PROFILE hash.
126
127 prf_delete @PROPERTIES
128 Removes PROPERTIES from internal properties hash. This action
129 results in that the PROPERTIES in the object inspector are set back
130 to their default values.
131
132 prf_events
133 Returns hash of a class-specific events. These appear in the object
134 inspector on "Events" page. The hash keys are event names; the hash
135 values are default code pieces, that describe format of the event
136 parameters. Example:
137
138 sub prf_events { return (
139 $_[0]-> SUPER::prf_events,
140 onSelectItem => 'my ( $self, $index, $selectState) = @_;',
141 )}
142
143 prf @PROPERTIES
144 Maps array of PROPERTIES names to their values. If called in scalar
145 context, returns the first value only; if in array context, returns
146 array of property values.
147
148 prf_types
149 Returns an anonymous hash, where keys are names of the type class
150 without "Prima::VB::Types::" prefix, and values are arrays of
151 property names.
152
153 This callback returns an inverse mapping of properties by the
154 types.
155
156 prf_types_add PROFILE1, PROFILE2
157 Adds PROFILE2 content to PROFILE1. PROFILE1 and PROFILE2 are hashes
158 in format of result of "prf_types" method.
159
160 prf_types_delete PROFILE, @NAMES
161 Removes @NAMES from PROFILE. Need to be called if property type if
162 redefined through the inheritance.
163
164 remove_hooks @PROPERTIES
165 Cancels watch for set of PROPERTIES.
166
167 Events
168 on_hook NAME, PROPERTY, OLD_VALUE, NEW_VALUE, WIDGET
169 Called for all objects, registered as watchers by "add_hooks" when
170 PROPERTY on object NAME is changed from OLD_VALUE to NEW_VALUE.
171 Special PROPERTY 'DESTROY' hook is called when object NAME is
172 destroyed.
173
175 Properties
176 marked MARKED , EXCLUSIVE
177 Selects marked state of a widget. If MARKED flag is 1, the widget
178 is selected as marked. If 0, it is selected as unmarked. If
179 EXCLUSIVE flag is set to 1, then all marked widgets are unmarked
180 before the object mark flag is set.
181
182 sizeable BOOLEAN
183 If 1, the widget can be resized by the user. If 0, in can only be
184 moved.
185
186 mainEvent STRING
187 Selects the event name, that will be opened in the object inspector
188 when the user double clicks on the widget.
189
190 Methods
191 common_paint CANVAS
192 Draws selection and resize marks on the widget if it is in the
193 selected state. To be called from all "on_paint" callbacks.
194
195 get_o_delta
196 Returns offset to the owner widget. Since the builder does not
197 insert widgets in widgets to reflect the user-designed object
198 hierarchy, this method is to be used to calculate children widgets
199 relative positions.
200
201 xy2part X, Y
202 Maps X, Y point into part of widget. If result is not equal to
203 'client' string, the event in X, Y point must be ignored.
204
205 iterate_children SUB, @ARGS
206 Traverses all children widget in the hierarchy, calling SUB routine
207 with widget, self, and @ARGS parameters on each.
208
209 altpopup
210 Invokes an alternative, class-specific popup menu, if present. The
211 popup object must be named 'AltPopup'.
212
213 Events
214 Load
215 Called when the widget is loaded from a file or the clipboard.
216
218 Root of all type classes.
219
220 A type class can be used with and without object instance. The
221 instantiated class contains reference to ID string, which is a property
222 name that the object presents in the object inspector, and WIDGET,
223 which is the property applied to. When the object inspector switches
224 widgets, the type object is commanded to update the references.
225
226 A class must also be usable without object instance, in particular, in
227 "write" method. It is called to export the property value in a storable
228 format as a string, better as a perl-evaluable expression.
229
230 Methods
231 new CONTAINER, ID, WIDGET
232 Constructor method. CONTAINER is a panel widget in the object
233 inspector, where the type object can insert property value selector
234 widgets.
235
236 renew ID, WIDGET
237 Resets property name and the widget.
238
239 quotable STRING
240 Returns quotable STRING.
241
242 printable STRING
243 Returns a string that can be stored in a file.
244
245 Callbacks
246 change
247 Called when the widget property value is changed.
248
249 change_id
250 Called when the property name ( ID ) is changed. The type object
251 may consider update its look or eventual internal variables on this
252 event.
253
254 get Returns property value, based on the selector widgets value.
255
256 open
257 Called when the type object is to be visualized first time. The
258 object must create property value selector widgets in the
259 "{container}" panel widget.
260
261 preload_modules
262 Returns array of strings of modules, needed to be pre-loaded before
263 a form file with type class-specific information can be loaded.
264 Usually it is used when "write" method exports constant values,
265 which are defined in another module.
266
267 set DATA
268 Called when a new value is set to the widget property by means
269 other than the selector widgets, so these can be updated. DATA is
270 the property new value.
271
272 valid
273 Checks internal state of data and returns a boolean flag, if the
274 type object data can be exported and set to widget profile.
275
276 write CLASS, ID, DATA
277 Called when DATA is to be written in form. "write" must return
278 such a string that can be loaded by "Prima::VB::VBLoader" later.
279
281 Dmitry Karasik, <dmitry@karasik.eu.org>.
282
284 VB, Prima::VB::VBLoader, Prima::VB::CfgMaint.
285
286
287
288perl v5.30.0 2019-08-21 Prima::VB::Classes(3)