<\body> In you create and extend the visual interface using . This word means either the basic building blocks you have at your disposal, like buttons, popup lists, etc. or the collections of those into dialogs, menu bars or whatever. This rather loose concept might be confusing, especially when we refer to what usually are know as dialogs as widgets, but it makes sense because all sorts of widgets can be aggregated to build more complicated ones as well.<\footnote> If you miss some particular ``building block'' from your OS, you might see whether it's feasible as an aggregation of simpler ones or try and play with the UI interface code in C++ (but you'll have to add it for every supported platform!). However, it must be kept in mind that items intended to be inserted in a menu bar won't necessarily display as they do in a separate window: complicated aggregations of widgets might be better placed in a separate window or dialogue, as explained in "". A complete reference with all the available widgets is the "", and you can find some examples in the other subsections of "". If you'd rather see the sources, the whole list of keywords is in the table inside . To create a widget, you'll first need to use to define a new one. The call to this function uses its particular syntax, with many keywords for the creation of widgets. But we'll start with some buttons and labels.\ Execute the following two lines to get the unavoidable example and leave your mouse over the ``Hello'' button. <\session|scheme|default> <\input|Scheme] > (tm-widget (example1) ("Hello" "world!")) <\input|Scheme] > (top-window example1 "A first try") As you can see, buttons are implicitly created by simply writing a list with the button's title and a tooltip to be displayed when the user hovers over the button. A bit confusing, and also ugly, because this is intended for buttons. What you probably want is this: <\session|scheme|default> <\input|Scheme] > (tm-widget (example2) (explicit-buttons ("Hello" (noop)))) <\input|Scheme] > (top-window example2 "A nicer button") The second argument is now a command to be executed when the user clicks the button, in this case a no-operation, or . Try changing it for or anything that suits you. The next step is to add some text next to the button, i.e. a label. This is done with the keyword, as in , but in order to have both widgets sit side by side, you'll need a container widget as described in "", such as : <\session|scheme|default> <\unfolded-io|Scheme] > (tm-widget (example3) \ \ (hlist\ \ \ \ \ (text "Hello")\ \ \ \ \ (explicit-buttons ("world" (display "!\\n"))))) <|unfolded-io> \; <\input|Scheme] > (top-window example3 "Some text") That was nice, but as you see, the two widgets are packed together until you resize the window. We need to explicitly tell to insert some space between them: <\session|scheme|default> <\unfolded-io|Scheme] > (tm-widget (example3) \ \ (hlist\ \ \ \ \ (text "Hello") \ \ \ \ \\\ \ \ \ \ (explicit-buttons ("world" (display "!\\n"))))) <|unfolded-io> \; <\input|Scheme] > (top-window example3 "Some text") The special symbol \\> is just one of the predefined glue widgets described in "". Text attributes may be changed for widgets and many others by enclosing them inside what we'll name . These attributes are , , , , and , and respectively: reduce the size of the widget, choose a , set the color to , deactivate the widget (meaning it is rendered, but greyed out and inactive), center it and choose a bold face. Here is an example: <\session|scheme|default> <\unfolded-io|Scheme] > (tm-widget (example3) \ \ (hlist\ \ \ \ \ (bold (text "Hello")) \ \ \ \ \\\ \ \ \ \ (inert (explicit-buttons ("world" (display "!\\n")))))) <|unfolded-io> \; <\input|Scheme] > (top-window example3 "Some text") team.> <\initial> <\collection>