Go GUI :lxn/walk 实现官方示例

本文是关于Go语言GUI库lxn/walk的学习记录,通过代码示例展示了如何创建一个GUI应用,并给出了运行效果的简要说明。
摘要由CSDN通过智能技术生成

Go GUI :lxn/walk 实现官方示例


前言

Go GUI :lxn/walk 学习记录一下,希望跟大家交流一下。


代码示例

package main

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

func main() {
   
	window, _ := walk.NewMainWindow()

	// 设置窗体生成在屏幕的正中间
	window.SetX((int(win.GetSystemMetrics(0)) - window.Width
以下是一个基于Go语言的walk实现的多页窗口示例: ```go package main import ( "github.com/lxn/walk" . "github.com/lxn/walk/declarative" ) func main() { mw := new(MyMainWindow) if err := (MainWindow{ AssignTo: &mw.MainWindow, Title: "Multi-Page Example", MinSize: Size{300, 200}, Layout: VBox{}, Children: []Widget{ HSpacer{}, RadioButtonGroup{ Buttons: []RadioButton{ {Text: "Page 1", Value: 0}, {Text: "Page 2", Value: 1}, {Text: "Page 3", Value: 2}, }, Orientation: Horizontal, OnValueChanged: func(value int) { mw.Stack.SetCurrentIndex(value) }, }, HSpacer{}, Stack{ AssignTo: &mw.Stack, Pages: []Page{ {Title: "Page 1", Layout: VBox{}, Children: []Widget{ Label{Text: "This is Page 1"}, }}, {Title: "Page 2", Layout: VBox{}, Children: []Widget{ Label{Text: "This is Page 2"}, PushButton{Text: "Button 2"}, }}, {Title: "Page 3", Layout: VBox{}, Children: []Widget{ Label{Text: "This is Page 3"}, LineEdit{AssignTo: &mw.LineEdit}, PushButton{Text: "Button 3", OnClicked: func() { walk.MsgBox(mw, "Button 3", mw.LineEdit.Text(), walk.MsgBoxIconInformation) }}, }}, }, }, HSpacer{}, }, }.Create()); err != nil { panic(err) } mw.Run() } type MyMainWindow struct { *walk.MainWindow Stack *walk.Stack LineEdit *walk.LineEdit } ``` 该示例包含一个主窗口,其中有一个单选按钮组用于切换三个不同的页面。每个页面都包含一个不同的小部件,比如标签、按钮和文本框。使用Stack小部件,可以轻松地在这些页面之间进行切换。 注意:为了使该示例正常工作,需要安装walk库。可以使用以下命令在终端中安装walk库: ``` go get github.com/lxn/walk ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值