Skip to content

lxn/walk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

c389da5 · Jan 12, 2021
Feb 25, 2011
Nov 10, 2020
Sep 1, 2020
Sep 24, 2020
Jul 16, 2013
Jan 12, 2021
Sep 16, 2010
Aug 29, 2019
Sep 27, 2019
Nov 18, 2020
Jun 19, 2019
Sep 17, 2019
Sep 3, 2020
Nov 27, 2019
Sep 27, 2019
Sep 1, 2020
Nov 13, 2019
Sep 2, 2020
Sep 27, 2019
Sep 4, 2019
Nov 13, 2019
Sep 15, 2015
Nov 4, 2020
Nov 21, 2020
Sep 4, 2019
Feb 27, 2017
Jul 29, 2020
Sep 15, 2015
Sep 27, 2019
Sep 17, 2019
Sep 27, 2019
Jul 29, 2020
Sep 27, 2019
Nov 13, 2019
Sep 15, 2015
Nov 13, 2019
Nov 13, 2019
Dec 5, 2018
Sep 27, 2019
Oct 7, 2019
May 14, 2019
Jan 4, 2021
Sep 26, 2019
Sep 27, 2019
Nov 21, 2019
Nov 10, 2020
Oct 31, 2019
Sep 4, 2019
Oct 7, 2019
Nov 6, 2019
Oct 2, 2019
Sep 17, 2019
Nov 13, 2019
Nov 13, 2019
Mar 18, 2019
Nov 13, 2019
Jul 29, 2020
Jul 29, 2020
Sep 27, 2019
Sep 27, 2019
Sep 3, 2020
Sep 20, 2019
Sep 17, 2019
Dec 21, 2020
Sep 15, 2015
Sep 26, 2019
May 22, 2019
Oct 26, 2019
Sep 3, 2020
Nov 13, 2019
Jan 4, 2021
Sep 3, 2020
Jul 29, 2020
Jul 29, 2020
Sep 26, 2019
Sep 27, 2019
Sep 27, 2019
May 16, 2019
Feb 25, 2019
Jul 17, 2019
Jul 17, 2019
Sep 3, 2020
Nov 13, 2019
Sep 15, 2015
Sep 26, 2019
Oct 23, 2019
Sep 27, 2019
Dec 5, 2018
Sep 3, 2020
Sep 27, 2019
Sep 27, 2019
Jul 17, 2019
Sep 27, 2019
Sep 27, 2019
Sep 27, 2019
Jul 29, 2020
Sep 27, 2019
Aug 26, 2019
Nov 13, 2019
Sep 10, 2020
Sep 10, 2020
Jul 29, 2020
Sep 19, 2019
Jul 17, 2019
Nov 4, 2020
Oct 31, 2019
Jul 29, 2020
Oct 24, 2019
Sep 27, 2019
Jul 29, 2020
Nov 21, 2017
Nov 13, 2019
Aug 19, 2020
Oct 26, 2019
Oct 9, 2017
Feb 27, 2017
Sep 4, 2019
Sep 4, 2019
Apr 27, 2018
Sep 4, 2019
Sep 4, 2019
Sep 4, 2019
Sep 4, 2019
Jul 29, 2020
May 16, 2019
Dec 9, 2020
Nov 4, 2019

Repository files navigation

About Walk

Walk is a "Windows Application Library Kit" for the Go Programming Language.

Its primarily useful for Desktop GUI development, but there is some more stuff.

Setup

Make sure you have a working Go installation. See Getting Started

Note

Walk currently requires Go 1.11.x or later.

To Install

Now run go get github.com/lxn/walk

Using Walk

The preferred way to create GUIs with Walk is to use its declarative sub package, as illustrated in this small example:

test.go
package main

import (
	"github.com/lxn/walk"
	. "github.com/lxn/walk/declarative"
	"strings"
)

func main() {
	var inTE, outTE *walk.TextEdit

	MainWindow{
		Title:   "SCREAMO",
		MinSize: Size{600, 400},
		Layout:  VBox{},
		Children: []Widget{
			HSplitter{
				Children: []Widget{
					TextEdit{AssignTo: &inTE},
					TextEdit{AssignTo: &outTE, ReadOnly: true},
				},
			},
			PushButton{
				Text: "SCREAM",
				OnClicked: func() {
					outTE.SetText(strings.ToUpper(inTE.Text()))
				},
			},
		},
	}.Run()
}
Create Manifest test.manifest
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
    <assemblyIdentity version="1.0.0.0" processorArchitecture="*" name="SomeFunkyNameHere" type="win32"/>
    <dependency>
        <dependentAssembly>
            <assemblyIdentity type="win32" name="Microsoft.Windows.Common-Controls" version="6.0.0.0" processorArchitecture="*" publicKeyToken="6595b64144ccf1df" language="*"/>
        </dependentAssembly>
    </dependency>
    <application xmlns="urn:schemas-microsoft-com:asm.v3">
        <windowsSettings>
            <dpiAwareness xmlns="http://schemas.microsoft.com/SMI/2016/WindowsSettings">PerMonitorV2, PerMonitor</dpiAwareness>
            <dpiAware xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">True</dpiAware>
        </windowsSettings>
    </application>
</assembly>

Then either compile the manifest using the rsrc tool, like this:

go get github.com/akavel/rsrc
rsrc -manifest test.manifest -o rsrc.syso

or rename the test.manifest file to test.exe.manifest and distribute it with the application instead.

Build app

In the directory containing test.go run

go build

To get rid of the cmd window, instead run

go build -ldflags="-H windowsgui"
Run app
test.exe
Sample Output (Windows 7)

alt tag

More Examples

There are some examples that should get you started.

Application Manifest Files

Walk requires Common Controls 6. This means that you must put an appropriate application manifest file either next to your executable or embedded as a resource.

You can copy one of the application manifest files that come with the examples.

To embed a manifest file as a resource, you can use the rsrc tool.

IMPORTANT: If you don't embed a manifest as a resource, then you should not launch your executable before the manifest file is in place. If you do anyway, the program will not run properly. And worse, Windows will not recognize a manifest file, you later drop next to the executable. To fix this, rebuild your executable and only launch it with a manifest file in place.

CGo Optimizations

The usual default message loop includes calls to win32 API functions, which incurs a decent amount of runtime overhead coming from Go. As an alternative to this, you may compile Walk using an optional C implementation of the main message loop, by passing the walk_use_cgo build tag:

go build -tags walk_use_cgo