Go 語言跨平臺,Qt 也跨平臺,兩個跨平臺的框架/語言愉快地交織在了一起。我本應該獲得了這種如夢一般的幸福時光才對。可是,為什么,會變成現在這樣呢……(白學家梗)
Go 的 UI 庫
Go 語言本身是沒有 UI 庫的,不過有許多第三方的庫支持將 Go 語言綁定到其他 UI 庫,比如 Qt、GTK。本文就介紹使用這個 Qt 綁定的庫,therecipe/qt。
環境搭建(windows)
非 windows 或者需要參數說明的可以參考官方的wiki、windows 安裝
Qt 安裝
下載你需要的版本,下載地址。如果需要安裝 VS 編譯器什么的也可以參考下我之前的文章,Qt5.12.0 + VS2017 環境搭建。
therecipe/qt 安裝
終端執行下面的命令:
# Go的環境變量配置,配置過一次就不用在設置了
go env -w GO111MODULE=on
go env -w GOPROXY=https://goproxy.cn
# 下載therecipe/qt庫
go get -v -tags=no_env github.com/therecipe/qt/cmd/...
執行 qtsetup
下載好庫后會在%GOPATH%/bin
目錄下出現幾個幫助執行綁定工作的可執行文件
現在還需要根據你本地的 Qt 再配置下編譯環境,就是執行上面目錄中的 qtsetup,但是直接執行是會有問題的:
需要配置幾個環境變量,qtsetup
只需要執行一次。如果你有多個環境要切換,需要注意和編譯時的環境變量保持一致,可以用 bat 臨時設置下環境變量方便切換,下面就是 bat 的內容:
SET PATH=%PATH%;%GOPATH%\bin;
REM 配置Qt目錄和Qt版本
SET QT_DIR=C:\Qt\Qt5.12.5
SET QT_VERSION_MAJOR=5.12.5
REM 編譯32位程序,前提是你的Qt有Mingw32套件
SET GOARCH=386
REM 默認使用Mingw編譯,使用MSVC編譯的話開啟下面的選項,qtsetup可以運行,但是后面qtdeploy會報cgo相關錯誤
REM SET QT_MSVC=true
REM SET PATH=%PATH%;C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build;
REM call vcvarsall.bat amd64_x86
REM 語言綁定安裝,只需執行一次
qtsetup.exe
demo 運行
創建一個 Go 項目目錄
終端運行:
mkdir qtwidget && cd qtwidget
go mod init
main.go
在項目目錄新建一個 main.go 文件,復制下面的內容:
package main
import (
"os"
"github.com/therecipe/qt/widgets"
)
func main() {
// needs to be called once before you can start using the QWidgets
app := widgets.NewQApplication(len(os.Args), os.Args)
// create a window
// with a minimum size of 250*200
// and sets the title to "Hello Widgets Example"
window := widgets.NewQMainWindow(nil, 0)
window.SetMinimumSize2(250, 200)
window.SetWindowTitle("Hello Widgets Example")
// create a regular widget
// give it a QVBoxLayout
// and make it the central widget of the window
widget := widgets.NewQWidget(nil, 0)
widget.SetLayout(widgets.NewQVBoxLayout())
window.SetCentralWidget(widget)
// create a line edit
// with a custom placeholder text
// and add it to the central widgets layout
input := widgets.NewQLineEdit(nil)
input.SetPlaceholderText("Write something ...")
widget.Layout().AddWidget(input)
// create a button
// connect the clicked signal
// and add it to the central widgets layout
button := widgets.NewQPushButton2("and click me!", nil)
button.ConnectClicked(func(bool) {
widgets.QMessageBox_Information(nil, "OK", input.Text(), widgets.QMessageBox__Ok, widgets.QMessageBox__Ok)
})
widget.Layout().AddWidget(button)
// make the window visible
window.Show()
// start the main Qt event loop
// and block until app.Exit() is called
// or the window is closed by the user
app.Exec()
}
編譯
編譯就是執行 qtdeploy 命令,具體參數可以自己運行 qtdeploy -h 查看,這個終端文件也是在%GOPATH%/bin
的,如果你的編譯環境有多個也可以用 bat 配置下,與上面的類似,新建個 build.bat 拷貝下面的內容并運行:
SET PATH=%PATH%;%GOPATH%\bin;
REM 配置Qt目錄和Qt版本
SET QT_DIR=C:\Qt\Qt5.12.5
SET QT_VERSION_MAJOR=5.12.5
REM 編譯32位程序
SET GOARCH=386
REM 默認使用Mingw編譯,使用MSVC編譯的話開啟下面的選項,qtsetup可以運行,但是后面qtdeploy會報cgo相關錯誤
REM SET QT_MSVC=true
REM SET PATH=%PATH%;C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build;
REM call vcvarsall.bat amd64_x86
REM 語言綁定安裝,只需執行一次
REM qtsetup.exe
REM 編譯具體項目時運行
qtdeploy build desktop ./
生成的可執行文件在當前目錄/deploy/windows,本體 exe 和相關的 dll 都在這個目錄下
注:我使用 Mingw 編譯成功,但是 MSVC 編譯會有 cgo 的錯誤,太難用了...
main.go:6:2: G:\Go\src\go_learn\qtwidget\vendor\github.com\therecipe\qt\widgets\minimal_cgo_windows_windows_386.go: invalid #cgo verb: #cgo MSCFLAGS: -nologo -Zc:wchar_t -FS -Zc:strictStrings -O2 -MD -W3 -w44456 -w44457 -w44458 -D_ALLOW_KEYWORD_MACROS -DUNICODE -D_UNICODE -DWIN32 -D_ENABLE_EXTENDED_ALIGNED_STORAGE -DQT_NO_DEBUG -DQT_WIDGETS_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DNDEBUG
運行結果
demo 執行效果如下:
項目代碼
雖然沒幾行,不過如果懶得復制的話也可以直接下載,Github 鏈接,喜歡的話記得點個 Star~
使用感受
- 編譯的命令行配置中沒有多核編譯的選項,改個代碼編譯起碼要幾分鐘,很難受
- 這個庫沒有官方文檔,wiki直接指向 Qt 的文檔,所以調用都要在源碼搜,看看轉換函數咋寫的,把 Qt 函數名大寫、函數重載就名字后面加序號等,很蛋疼...
- 語法也不適應,Qt 的 connect 改成了類似方法回調的樣子:
btn.ConnectClicked(func(){})
- 支持不完善,使用 MSVC 編譯會有 cgo 的錯誤,還是直接通過 rpc 調用或者 http 調用來讓 Go 和 Qt 通信比較好