Win32 API and GUI in idiomatic Go.
The UI library is divided in the following packages:
Package | Description |
---|---|
ui |
High-level UI wrappers for windows and controls. |
ui/wm |
High-level event parameters (Windows message callbacks). |
For the Win32 API bindings:
Package | Description |
---|---|
win |
Native Win32 structs, handles and functions. |
win/co |
Native Win32 constants, all typed. |
win/errco |
Native Win32 error codes, with types errco.ERROR and errco.CDERR . |
For the COM bindings, there is the main package, and two subpackages – the co
suffix contains the constants, and the vt
contains the virtual tables:
Packages | Description |
---|---|
win/com/autom win/com/autom/automco win/com/autom/automvt |
Native Win32 Automation COM interfaces. |
win/com/com win/com/com/comco win/com/com/comvt |
Native Win32 COM API base. |
win/com/d2d1 win/com/d2d1/d2d1co win/com/d2d1/d2d1vt |
Native Win32 Direct2D COM interfaces. |
win/com/dshow win/com/dshow/dshowco win/com/dshow/dshowvt |
Native Win32 DirectShow COM interfaces. |
win/com/shell win/com/shell/shellco win/com/shell/shellvt |
Native Win32 Shell COM interfaces. |
Windigo is designed to be familiar to Win32 programmers, using the same concepts, so most C/C++ Win32 tutorials should be applicable.
Windows and controls can be created in two ways:
- programmatically, by specifying the options used in the underlying CreateWindowEx;
- by loading resources from a
.rc
or a.res
file.
CGo is not used, just syscalls.
The native Win32 functions deal with errors in two ways:
-
Recoverable errors will return an
errco.ERROR
value, which implements theerror
interface; -
Unrecoverable errors will simply panic. This avoids the excess of
if err != nil
with errors that cannot be recovered anyway, like internal Windows errors.
The example below creates a window programmatically, and handles the button click. Also, it uses the minimal.syso
provided in the resources folder.
package main
import (
"fmt"
"runtime"
"github.com/rodrigocfd/windigo/ui"
"github.com/rodrigocfd/windigo/win"
"github.com/rodrigocfd/windigo/win/co"
)
func main() {
runtime.LockOSThread()
myWindow := NewMyWindow() // instantiate
myWindow.wnd.RunAsMain() // ...and run
}
// This struct represents our main window.
type MyWindow struct {
wnd ui.WindowMain
lblName ui.Static
txtName ui.Edit
btnShow ui.Button
}
// Creates a new instance of our main window.
func NewMyWindow() *MyWindow {
wnd := ui.NewWindowMain(
ui.WindowMainOpts().
Title("Hello you").
ClientArea(win.SIZE{Cx: 340, Cy: 80}).
IconId(101), // ID of icon resource, see resources folder
)
me := &MyWindow{
wnd: wnd,
lblName: ui.NewStatic(wnd,
ui.StaticOpts().
Text("Your name").
Position(win.POINT{X: 10, Y: 22}),
),
txtName: ui.NewEdit(wnd,
ui.EditOpts().
Position(win.POINT{X: 80, Y: 20}).
Size(win.SIZE{Cx: 150}),
),
btnShow: ui.NewButton(wnd,
ui.ButtonOpts().
Text("&Show").
Position(win.POINT{X: 240, Y: 19}),
),
}
me.btnShow.On().BnClicked(func() {
msg := fmt.Sprintf("Hello, %s!", me.txtName.Text())
me.wnd.Hwnd().MessageBox(msg, "Saying hello", co.MB_ICONINFORMATION)
})
return me
}
Licensed under MIT license, see LICENSE.md for details.