The interface that you have designed contains a complete description of the layouts and menus that are available, but does not yet specify what any of the various elements do. To do this, you need to specify callbacks in the interface definition. As you might expect, this is done by setting attribute values for the appropriate elements in the interface.
In this example, the callbacks that you supply are calls to other functions, the definitions for which are assumed to be available in a separate source code file, and are discussed in Defining the callbacks. Note that you do not have to take this approach; you can just as easily specify callback functions within the interface definition itself, using lambda notation. It is up to you whether you do this within the Interface Builder, or by loading the code in the editor. If you choose the former, note that it may be easier to use the code view, rather than typing lambda functions into the Attributes dialog.
This section shows you how to specify all the callbacks necessary for each element in the example interface, together with other attributes that are required for correct operation of the callback functions. You need to specify attribute values for the display pane, the list panel and the graph pane.
Selection-Text
in the layout hierarchy and display the Attributes dialog.selection-reader
and click
OK
.This reader allows the display pane to be identified by the callback code.
For the list panel, you need to specify four callbacks and a reader.
List
in the layout hierarchy and display its Attributes dialog.list-reader
. Do not click
OK
yet.Like the display pane, this reader is necessary so that the list panel can be identified by the callback code.
Next, you need to specify the following four types of callback (make sure you click the Callbacks tab):
Selection callback. The function that is called when you select a list item.
Extend callback. The function that is called when you extend the current selection.
Retract callback. The function that is called when you deselect a list item.
Action callback. The function that is called when you double-click on a list item.
Selection-Callback to
'update-selection-select
Extend-Callback to
'update-selection-extend
Retract-Callback to
'update-selection-retract
Action-Callback to
'display-selection-in-dialog
Graph
graph pane and display its Attributes dialog.For the graph pane, you need to set the same four callbacks, as well as a reader, and two other attributes that are important for the callback code to run correctly.
Selection-Callback to
'update-selection-select
Extend-Callback to
'update-selection-extend
Retract-Callback to
'update-selection-retract
Action-Callback to
'display-selection-in-dialog
graph-reader
.(defun children-function (x)
(when (< x 8)
(list (* x 2) (1+ (* x 2)))))
Now set the Children-Function attribute to 'children-function
.
The children function defines what is drawn in the graph, and so is vital for any graph pane. It is called when displaying the prototype interface, so it is best to define it before setting this attribute.
The callbacks that are necessary for the menu system are much simpler than for the layouts; the example interface only contains two menu commands, and they only require one callback each.
"Graph"
menu item, display its Attributes dialog and change the Callback attribute to 'display-graph-selection
. Click
OK
."List Panel"
menu item, display its Attributes dialog and change the Callback attribute to 'display-list-selection
. Click
OK
.LispWorks IDE User Guide (Unix version) - 13 Sep 2017