Go Gio 实战:煮蛋计时器的实现之带边距的按钮

开发 后端
margins 使用设备独立的单位:unit.Dp。如果你希望所有边的边距都相同,还有一个方便的 UniformInset( ),可以为你节省几次按键操作。

[[439057]]

01 本节目标

在按钮两边加上空白,即带边距的按钮,如下图。

Button with margin

02 关键代码

  • 为了突出结构,主要关注下面关键点:
  • 使用 layout.Inset 定义边距
  • 布局这些边距

在这些边距内创建按钮

代码如下:

layout.Flex{ 
    // ... 
}.Layout(gtx,  
    layout.Rigid( 
        func(gtx C) D { 
            // 1、使用 layout.Inset 定义边距 
            margin := layout.Inset{ 
                // ... 
            } 
 
            // 2、布局这些边距 
            margins.Layout( 
                 
                // 3、在这些边距内创建按钮 
                func(gtx C) D { 
                    btn := material.Button(th, &startButton, "Start"
                    return btn.Layout(gtx) 
                }, 
             
            ) 
 
            } 
        } 
    )     

  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.

03 代码详解

上面就像一个中间有一个按钮的甜甜圈。这个比喻形象吗?

Button inside inset

边距是使用 layout.Inset{} 构建的。它是一个结构体,定义了小部件周围的空间:

margins := layout.Inset{ 
    Top:    unit.Dp(25), 
    Bottom: unit.Dp(25), 
    Right:  unit.Dp(35), 
    Left:   unit.Dp(35), 

  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.

在这里,margins 使用设备独立的单位:unit.Dp。如果你希望所有边的边距都相同,还有一个方便的 UniformInset( ),可以为你节省几次按键操作。

04 完整代码

以下是 system.FrameEvent 部分的完整代码:

case system.FrameEvent: 
    gtx := layout.NewContext(&ops, e) 
    // Let's try out the flexbox layout concept 
    layout.Flex{ 
        // Vertical alignment, from top to bottom 
        Axis: layout.Vertical, 
        // Empty space is left at the start, i.e. at the top 
        Spacing: layout.SpaceStart, 
    }.Layout(gtx, 
        layout.Rigid( 
            func(gtx C) D { 
                // 1、使用 layout.Inset 定义边距 
                margins := layout.Inset{ 
                    Top:    unit.Dp(25), 
                    Bottom: unit.Dp(25), 
                    Right:  unit.Dp(35), 
                    Left:   unit.Dp(35), 
                } 
                // 2、布局这些边距 
                return margins.Layout(gtx, 
                    // 3、在这些边距内创建按钮 
                    func(gtx C) D { 
                        btn := material.Button(th, &startButton, "Start"
                        return btn.Layout(gtx) 
                    }, 
                ) 
            }, 
        ), 
    ) 
    e.Frame(gtx.Ops) 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.

 

责任编辑:武晓燕 来源: 幽鬼
相关推荐

2021-11-26 00:04:20

Go计时器重构

2019-12-24 16:52:22

Go语言腾讯TM函数

2013-05-23 16:01:47

Android开发移动开发Chronometer

2021-03-26 09:10:11

Go 参透计时器

2023-04-17 09:08:27

CSS计时器

2011-05-31 16:50:35

Android 线程

2012-05-08 13:58:37

SharePoint

2020-03-10 09:42:04

JavaScript前端线程

2023-01-11 09:02:50

2011-09-08 14:01:01

Android Wid实例

2013-03-25 10:03:35

网络优化网络抑制快速认知网络

2020-06-11 08:48:49

JavaScript开发技术

2022-06-28 15:29:56

Python编程语言计时器

2023-12-11 09:50:35

Linux定时器

2024-07-18 08:46:58

.NET轻量级计时器测量代码块

2010-01-05 15:00:30

.NET Framew

2010-01-25 11:29:33

Android计时器

2022-06-23 07:23:34

自定义组件计时器

2011-04-15 09:29:20

jQueryFlash

2022-06-30 16:10:26

Python计时器装饰器
点赞
收藏

51CTO技术栈公众号