window app 开发语言_GO语言 GUI编程 | 怎样实现 page 页面?

一句话概要:本文是GO语言开发,GUI编程相关知识--page页面

大家知道什么GUI样式是page页吧,也有的叫Tab页,其实都是一排按钮一样的界面,来控制一个较大的显示区(子窗口)。

1ad58b5031265755c995c91929445e30.png

page页面基本样式

这样的界面设计,可以方便地在多个子窗口之间切换。

图中Page1 和Page 2就是切换控制器的内部按钮。下面的显示区就是stack。stack可以包含多个子窗口,但一个时间只能显示一个子窗口内容,由stackswitcher来控制。

它们的对象层次体系如下:

97b7762e84e54bfecc03042e7314855c.png

gtkstackswitcher直接继承自gtkbox

a757733713202dc2938813a65890e3ea.png

gtkstack则继承自gtkcontainer

下面我们实现一个例子,来熟悉这种界面的基本用法:

先看结果图,这样脑海里就有一个图形,在看代码时比较方便理解:

7f82384d3d80a9bb9adc53bcf2af6cd8.png

第一页 显示一个文本框子窗口

edbf66dd4785da2233f6def00cd07b23.png

第二页 显示一个 radio button group

49c6efe4c7e66001ad5189d51a018abd.png

第三页 显示一个文本框子窗口

先看main()主函数:

func main() {  gtk.Init(nil) // 初始化gtk  win := setup_window(winTitle) // 创建主窗口  box := newStackFull() // 创建工作区窗口  win.Add(box) // 把工作区窗口加到主窗口  win.ShowAll() // 主窗口会递归显示各个子窗口  gtk.Main() // GTK主循环启动,一直到 MainQuit()}

主函数就是程序框架,主要包含初始化,创建主窗口,创建工作区,把工作区和主窗口通过ADD关联起来,主窗口显示,进入主消息循环,直到app收到退出信号。这个和win32编程的窗口消息循环是一致的。如果不太理解,建议看下window系统编程。

主窗口的创建就非常简单明了:

func setup_window(title string) *gtk.Window {win, err := gtk.WindowNew(gtk.WINDOW_TOPLEVEL) //创建顶级窗口win.SetTitle(title) //设置窗口标题win.Connect("destroy", func() { //设置销毁函数,即关闭窗口gtk.MainQuit()})win.SetDefaultSize(800, 600) //设置主窗口宽高像素win.SetPosition(gtk.WIN_POS_CENTER) //设置窗口启动初始显示位置:居中return win}

主窗口的创建也很简单,创建window对象,设置属性,标题,映射销毁回调函数,设置窗口默认大小,设置默认显示在屏幕中的位置。

来看看创建工作区窗口

func newStackFull() gtk.IWidget {  // 创建一个stack 和它的控制器 switcher  stack, err := gtk.StackNew()  sw, err := gtk.StackSwitcherNew()  sw.SetStack(stack) //控制器有个setstack函数来绑定二者关系  // 给stack创建3个pages  boxText1 := newBoxText("Hello there!")  boxRadio := newBoxRadio("choice 1", "choice 2", "choice 3", "choice 4")  boxText2 := newBoxText("third page")  stack.AddTitled(boxText1, "key1", "first page")  stack.AddTitled(boxRadio, "key2", "second page")  stack.AddTitled(boxText2, "key3", "third page")  // 可把icons 给 switcher page (这个page title就作为tooltip显示)  stack.ChildSetProperty(boxRadio, "icon-name", "list-add")//加号图标  // stack里的数据要显示到一个可视化组件里,这里创建一个box组件  box := setup_box(gtk.ORIENTATION_VERTICAL) //垂直方向放置内部组件  box.PackStart(sw, false, false, 0) //首先把控制器加到box,不展开,不填充全部空间,前面(因为是垂直故上面)不留空隙  box.PackStart(stack, true, true, 0)//再把stack加到box,展开,填充,前面不留空==这样的结果就是stack占满了剩下的所有空间  return box}

创建stack窗口和Windows编程几乎一样,就是window编程时,工作区是不需要自己创建的。而这里需要自己厂家一个box组件来作为工作区。而工作区窗口add到主窗口时显然按照“填充”剩余空间的方式显示的。

box中有一个开关组件,有一个stack组件。且box内部的组件按照垂直排列,开关先加入“不展开,不填充”,就会显示在最上面。stack后加入box,“展开且填充”即占满剩余空间。

代码中第二个page页面显示图标,其文本则作为帮助提示显示。这里还可以自定义图片。(以后完善项目再分享)

每个page也面对应文本框的,实际项目中也需要动态更新文本内容(以后分享如何改变内容)。

剩下的代码比较简单,直接上图,如下:

42aac5e6332fc7a0bfcbb87be7fb2a77.png

newBoxText

474a8c2775de2284f10632f17c2c1b9c.png

newBoxRadio

44d091f5abf5c134620d0d78ea933905.png

其他细节代码

总结:

要活用page页界面,先了解各个组件之间的协作关系。用法其实比较简单的。你可以扩展成更复杂的界面。

今天刚看了《Hands-On-GUI-Application-Development-in-Go》这本书,虽然它用的gtk2版本和我安装的不一致,但它从GUI编程的整体历史出发,详细介绍了几个库,还是受益匪浅。


我是程序员黑洞,正在学习GoLang,基础学完后,准备分享一个工具软件的设计开发整个过程,代码开源到github或者gitee。欢迎关注我,可以留言私信。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值