fyne-gui-demo7有默认值得选择框

fyne-gui-demo7有默认值得选择框

示例图如下:
请添加图片描述

package main

import (
	"fmt"
	"fyne.io/fyne/v2"
	"fyne.io/fyne/v2/app"
	"fyne.io/fyne/v2/container"
	"fyne.io/fyne/v2/data/binding"
	"fyne.io/fyne/v2/widget"
)

// Layout 界面ui设计--互斥按钮
func Layout() fyne.CanvasObject {
	var start *widget.Button
	var stop *widget.Button
	var label *widget.Label
	var checkApple *widget.Check
	var checkBanana *widget.Check
	// 全局的垂直布局
	var fullBox *fyne.Container
	// 第一层的水平布局
	var Box1 *fyne.Container
	// 第二层的水平布局
	var Box2 *fyne.Container
	var Box3 *fyne.Container
	var checkAppleValue bool
	var checkBananaValue = true
	start = widget.NewButton("start", func() {
		label.SetText("state:start")
		start.Disable()
		stop.Enable()
	})
	stop = widget.NewButton("stop", func() {
		label.SetText("state:stop")
		start.Enable()
		stop.Disable()
	})
	label = widget.NewLabel("")
	// 按钮的初始状态
	stop.Disable()
	// 标签的初始状态
	label.SetText("state:stop")

	checkApple = widget.NewCheck("Apple", func(b bool) {
		checkAppleValue = b
		fmt.Println(checkAppleValue)

	})
	// 设置含有默认选项的选择框、此方法会失去自定义处理逻辑的实现、如上
	checkBanana = widget.NewCheckWithData("Banana", binding.BindBool(&checkBananaValue))
	Box1 = container.NewHBox(
		label,
	)
	Box2 = container.NewHBox(
		start,
		stop,
	)
	Box3 = container.NewHBox(
		checkApple,
		checkBanana,
	)
	// 垂直布局
	fullBox = container.NewVBox(
		Box1,
		Box2,
		Box3,
	)

	return fullBox
}

func main() {
	// 创建程序
	thisApp := app.New()
	// 创建窗口对象、传入窗口名
	w := thisApp.NewWindow("Title")
	// 设置窗口内容
	w.SetContent(Layout())
	// 窗口的显示和运行
	w.ShowAndRun()
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值