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-04-30 19:03:25 +02:00
androidextras cleanup and support for abstract classes 2016-04-28 19:43:44 +02:00
bluetooth new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
core new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
dbus new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
designer new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
gui new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
help new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
internal new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
location new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
macextras new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
multimedia new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
multimediawidgets new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
network new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
nfc new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
positioning new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
printsupport new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
qml new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
quick new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
script new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
scripttools new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
sensors new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
serialport new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
sql new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
svg new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
testlib new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
uitools new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
webchannel new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
webkit new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
websockets new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
widgets new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
xml cleanup and support for abstract classes 2016-04-28 19:43:44 +02:00
xmlpatterns new modules and fixed missing virtual functions 2016-04-30 19:03:25 +02:00
.gitignore partial support for QGraphicsItem 2016-04-23 04:19:03 +02:00
LICENSE complete rewrite 2015-10-24 17:18:24 +02:00
qt.go cleanup and support for abstract classes 2016-04-28 19:43:44 +02:00
README.md new modules and fixed missing virtual functions 2016-04-30 19:03:25 +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

source


Getting Started

Desktop (Windows / Mac OS X / Linux)

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

  2. Install Qt 5.5.1 in C:\Qt\Qt5.5.1\ or /usr/local/Qt5.5.1/

  3. Setup the environment

    • Windows

      • Add the directory that contains gcc.exe to your PATH

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

    • Mac OS X

      • Install Xcode >= 7.3
    • 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

    github.com/therecipe/qt/setup.bat (run as admin)

    or

    github.com/therecipe/qt/setup.sh


Mobile (Android)

  1. Make sure the binding is working by setting 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 5.1.1 (API 22)
      • SDK Platform
    • Extras (Windows only)
      • Google USB Driver
  4. Install the Android NDK in C:\android\android-ndk\ or /opt/android-ndk/

  5. Install Apache-Ant in C:\android\apache-ant\ or /opt/apache-ant/

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

  7. Install and test

    github.com/therecipe/qt/setup.bat android (run as admin)

    or

    github.com/therecipe/qt/setup.sh android


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)