-
Notifications
You must be signed in to change notification settings - Fork 651
Getting Started
In this example we will make a program that asks the user to enter their name, then prints it.
The complete code for this program is as follows. I will discuss each part of the code below.
package main
import (
"github.com/andlabs/ui"
)
var window ui.Window
func main() {
go ui.Do(func() {
name := ui.NewTextField()
button := ui.NewButton("Greet")
greeting := ui.NewStandaloneLabel("")
stack := ui.NewVerticalStack(
ui.NewStandaloneLabel("Enter your name:"),
name,
button,
greeting)
button.OnClicked(func() {
greeting.SetText("Hello, " + name.Text() + "!")
})
window = ui.NewWindow("Hello", 200, 100, stack)
window.OnClosing(func() bool {
ui.Stop()
return true
})
window.Show()
})
err := ui.Go()
if err != nil {
panic(err)
}
}
First, we declare a global variable of type ui.Window
. Windows hold other controls; all controls must belong to a Window in order for them to be visible on screen. (A Window is itself not a control.) For technical reasons, we keep the Window global so as to prevent it (and thus its children) from being moved around in memory (as it would have been if it was a stack variable).
You'll notice that all our UI work is done inside a closure passed to the function ui.Do()
. Most windowing systems actually hate being run on multiple threads, so ui.Do()
is a compromise to keep things nice and serialized for the underlying OS. Except for event handlers, all UI code should be passed to ui.Do()
.
We run ui.Do()
as a goroutine because t will wait for the function to finish running before it returns, and we haven't even launched the UI main loop yet.
The next few assignments should be straightforward: we create a text field, a button, and a label where our greeting will go. The only odd thing here is the use of StandaloneLabel
: by default, labels have their positions adjusted so that they look correct when placed to the left of another control. Standalone labels don't have this adjustment, and both the greeting label and the instructional text (added later) stand on their own.
Controls in package ui are arranged using layout containers, similar to how GTK+ and Qt do things. The most basic of these is the stack, which arranges controls horizontally or vertically, giving each control the same height or width (respectively). In this case, we use a vertical stack to arrange our controls vertically. We also add an extra instructional label; since we don't need to do anything with it later, we add it directly without saving i t in a variable.