Cute (Qt) binding for Go (Golang) with support for Windows / macOS / Linux / FreeBSD / Android / iOS / Sailfish OS / Raspberry Pi / AsteroidOS / Ubuntu Touch / JavaScript / WebAssembly
Find a file
2016-05-28 18:18:42 +02:00
androidextras build minimal binaries 2016-05-28 18:18:42 +02:00
bluetooth build minimal binaries 2016-05-28 18:18:42 +02:00
core build minimal binaries 2016-05-28 18:18:42 +02:00
dbus build minimal binaries 2016-05-28 18:18:42 +02:00
designer build minimal binaries 2016-05-28 18:18:42 +02:00
gui build minimal binaries 2016-05-28 18:18:42 +02:00
help build minimal binaries 2016-05-28 18:18:42 +02:00
internal build minimal binaries 2016-05-28 18:18:42 +02:00
location build minimal binaries 2016-05-28 18:18:42 +02:00
macextras build minimal binaries 2016-05-28 18:18:42 +02:00
multimedia build minimal binaries 2016-05-28 18:18:42 +02:00
network build minimal binaries 2016-05-28 18:18:42 +02:00
nfc build minimal binaries 2016-05-28 18:18:42 +02:00
positioning build minimal binaries 2016-05-28 18:18:42 +02:00
printsupport build minimal binaries 2016-05-28 18:18:42 +02:00
qml build minimal binaries 2016-05-28 18:18:42 +02:00
quick build minimal binaries 2016-05-28 18:18:42 +02:00
script build minimal binaries 2016-05-28 18:18:42 +02:00
scripttools build minimal binaries 2016-05-28 18:18:42 +02:00
sensors build minimal binaries 2016-05-28 18:18:42 +02:00
serialport build minimal binaries 2016-05-28 18:18:42 +02:00
sql build minimal binaries 2016-05-28 18:18:42 +02:00
svg build minimal binaries 2016-05-28 18:18:42 +02:00
testlib build minimal binaries 2016-05-28 18:18:42 +02:00
uitools build minimal binaries 2016-05-28 18:18:42 +02:00
webchannel build minimal binaries 2016-05-28 18:18:42 +02:00
webengine build minimal binaries 2016-05-28 18:18:42 +02:00
websockets build minimal binaries 2016-05-28 18:18:42 +02:00
widgets build minimal binaries 2016-05-28 18:18:42 +02:00
xml build minimal binaries 2016-05-28 18:18:42 +02:00
xmlpatterns build minimal binaries 2016-05-28 18:18:42 +02:00
.gitignore build minimal binaries 2016-05-28 18:18:42 +02:00
LICENSE complete rewrite 2015-10-24 17:18:24 +02:00
qt.go use gradle + minor android and ios fixes 2016-05-19 21:28:54 +02:00
README.md fat binaries for iOS + always strip on darwin + raised minVersion for darwin and iOS 2016-05-25 23:13:17 +02:00
setup.bat support for androidextras 2015-11-19 19:29:30 +01:00
setup.sh support for androidextras 2015-11-19 19:29:30 +01:00

Screenshots

Windows

Mac OS X

Linux

Android

Portrait

Landscape

iOS

Portrait

Landscape

source


Getting Started

Desktop (Windows / Mac OS X / Linux)

  1. Install Go >= 1.6.2 and setup a proper GOPATH

  2. Install Qt 5.6.0 in C:\Qt\Qt5.6.0\ or /usr/local/Qt5.6.0/

  3. Setup the environment

    • Windows

      • Add the directory that contains g++.exe to your PATH

        C:\Qt\Qt5.6.0\Tools\mingw492_32\bin

    • Mac OS X

      • Install Xcode >= 7.3.1
    • Linux

      • Install g++

        sudo apt-get install g++

      • Install OpenGL dependencies

        sudo apt-get install mesa-common-dev

  4. Download the binding

    go get github.com/therecipe/qt

  5. Generate, install and test

    cd %GOPATH%\src\github.com\therecipe\qt && setup.bat (run as admin)

    or

    cd $GOPATH/src/github.com/therecipe/qt && ./setup.sh


Mobile (Android)

  1. Set up the desktop version

  2. Install the Android SDK in C:\android\android-sdk\ or /opt/android-sdk/

  3. Install the SDK dependencies with C:\android\android-sdk\tools\android.bat or /opt/android-sdk/tools/android

    • Tools
      • Android SDK Build-tools (23.0.3)
    • Android 6.0 (API 23)
      • SDK Platform
    • Extras (Windows only)
      • Google USB Driver
  4. Install the Android NDK in C:\android\android-ndk\ or /opt/android-ndk/

  5. Install Java SE Development Kit (Linux: install in /opt/jdk/)

  6. Install and test

    cd %GOPATH%\src\github.com\therecipe\qt && setup.bat android (run as admin)

    or

    cd $GOPATH/src/github.com/therecipe/qt && ./setup.sh android


Mobile (iOS)

  1. Set up the desktop version on Mac OS X

  2. Install and test

    cd $GOPATH/src/github.com/therecipe/qt && ./setup.sh ios && ./setup.sh ios-simulator


Quick Start

  1. Create a folder [GOPATH]/src/qtExample

  2. Create a file [GOPATH]/src/qtExample/main.go

package main

import ( "os"

	"github.com/therecipe/qt/widgets"

)

func main() { widgets.NewQApplication(len(os.Args), os.Args)

	var btn = widgets.NewQPushButton2("Hello World", nil)
	btn.Resize2(180, 44)
	btn.ConnectClicked(func(flag bool) {
		widgets.QMessageBox_Information(nil, "OK", "You Clicked me!", widgets.QMessageBox__Ok, widgets.QMessageBox__Ok)
	})

	var window = widgets.NewQMainWindow(nil, 0)
	window.SetWindowTitle("Hello World Example")
	window.Layout().AddWidget(btn)
	window.Show()

	widgets.QApplication_Exec()

}


3. Open the command line in `[GOPATH]/src` and run
`qtdeploy build desktop qtExample`

4. You will find the executable file here
`[GOPATH]/src/qtExample/deploy/[GOOS]/qtExample(.exe)`

5. Take a look at the [other examples](https://github.com/therecipe/qt/tree/master/internal/examples)

6. Make yourself familiar with the [qt documentation](https://doc.qt.io/qt-5/classes.html)