使用 Go GUI 库 fyne 编写一个计算器程序

栏目: IT技术 · 发布时间: 4年前

内容简介:在之前文章中,我们介绍了一个 Go 的高颜值 GUI 库我们使用其它数字和符号控件都用

简介

在之前文章中,我们介绍了一个 Go 的高颜值 GUI 库 fyne 。本文接着,介绍如何使用 fyne 编写一个简单的计算器程序。程序效果如下:

使用 Go GUI 库 fyne 编写一个计算器程序

控件布局

我们使用 widget.Entry 来显示输入的数字、运算符和运算结果。先创建一个 widget.Entry 对象,设置可显示多行:

display := widget.NewEntry()
display.MultiLine = true

其它数字和符号控件都用 widget.Button 来表示。按钮也分为两种,一种是没有特殊效果的,点击后直接在显示框中添加对应的字符即可。一种是有特殊效果的,例如清空显示框( AC )、进行计算( = )。中间三行按钮都是前一种,我们使用 GridLayout 来布局,每行显示 4 个:

digits := []string{
  "7", "8", "9", "×",
  "4", "5", "6", "-",
  "1", "2", "3", "+",
}
var digitBtns []fyne.CanvasObject
for _, val := range digits {
  digitBtns = append(digitBtns, widget.NewButton(val, input(display, val)))
}
digitContainer := fyne.NewContainerWithLayout(
  layout.NewGridLayout(4),
  digitBtns...)

input 回调后面介绍。

第一行有 3 个具有特殊效果的按钮:

  • AC :清空显示框;
  • +/- :切换正负号;
  • % 将数字变为百分数,即除以 100。

外加一个除法按钮。这一行同样使用 GridLayout 布局:

clearBtn := widget.NewButton("AC", clear(display))
signBtn := widget.NewButton("+/-", sign(display))
percentBtn := widget.NewButton("%", percent(display, "%"))
divideBtn := widget.NewButton("÷", input(display, "÷"))
clearContainer := fyne.NewContainerWithLayout(
  layout.NewGridLayout(4),
  clearBtn,
  signBtn,
  percentBtn,
  divideBtn,
)

几个回调处理后面统一介绍。

最后一行由于 0 这个按钮宽度是其它按钮的 2 倍。我们先使用 GridLayout 布局,将这一行平均分成两 Grid (即每行 2 个控件)。按钮 0 独占一个 Grid ,由于 GridLayout 布局中每个 Grid 大小相同,故按钮 0 有整个行一半的宽度。后一个 Grid ,按钮 .= 平分,同样使用一个 GridLayout 达到这个效果:

zeroBtn := widget.NewButton("0", input(display, "0"))
dotBtn := widget.NewButton(".", input(display, "."))
equalBtn := widget.NewButton("=", equals(display))
zeroContainer := fyne.NewContainerWithLayout(
  layout.NewGridLayout(2),
  zeroBtn,
  fyne.NewContainerWithLayout(
    layout.NewGridLayout(2),
    dotBtn,
    equalBtn,
  ),
)

最后我们将所有部分用垂直的 BoxLayout 组合到一起:

container := fyne.NewContainerWithLayout(
  layout.NewVBoxLayout(),
  display,
  clearContainer,
  digitContainer,
  zeroContainer,
  copyright,
)

在实际开发中,一般会组合使用多种布局实现界面效果。

按钮响应

清空按钮响应比较简单,直接将显示框的 Text 设置为空即可:

func clear(display *widget.Entry) func() {
  return func() {
    display.Text = ""
    display.Refresh()
  }
}

注意,要调用 Entry.Refresh() 方法刷新界面。由于按钮响应都是对应显示框进行操作,所以都需要传入该对象。

我们设计在显示框中显示两行,第一行是上次计算的表达式,第二行是本次的。切换正负号在本次只输入一个数字时将该数字的正负号进行切换:

func sign(display *widget.Entry) func() {
  return func() {
    lines := strings.Split(display.Text, "\n")
    if len(lines) == 0 {
      return
    }

    line := lines[len(lines)-1]
    value, err := strconv.ParseInt(line, 10, 64)
    if err != nil {
      return
    }
    lines[len(lines)-1] = strconv.FormatInt(-value, 10)
    display.Text = strings.Join(lines, "\n")
  }
}

输入回调我们只做了简单的处理——将对应字符串拼接到显示框中:

func input(display *widget.Entry, value string) func() {
  return func() {
    display.Text += value
    display.Refresh()
  }
}

计算表达式的函数也很简单,我这里使用了 govaluate 库(可以看我之前的文章):

func equals(display *widget.Entry) func() {
  return func() {
    lines := strings.Split(display.Text, "\n")
    if len(lines) == 0 {
      return
    }

    line := lines[len(lines)-1]
    line = strings.Trim(line, "+÷×")
    exprLine := strings.Replace(line, "÷", "/", -1)
    exprLine = strings.Replace(exprLine, "×", "*", -1)
    expr, _ := govaluate.NewEvaluableExpression(exprLine)
    result, _ := expr.Evaluate(nil)
    line += "=\n"
    line += fmt.Sprint(result)
    display.Text = line
    display.Refresh()
  }
}

注意,这里做了一点容错,把前后多余的运算符去掉了。另外,我们前面为了显示,使用了 ÷ 表示除法符号, × 表示乘法符号。要使用 govaluate ,必须将它们分别替换为 /*

至此计算器就编写完成了,下面我们介绍如何打包。

打包

准备好一张图片资源作为图标,放到项目目录下:

使用 Go GUI 库 fyne 编写一个计算器程序

打包:

$ fyne package -os windows -icon icon.jpg

在同目录下生成了一个 .exe 文件和一个 .syso 文件。现在可直接点击 calculator.exe 运行程序,没有其他依赖。

总结

本文介绍如何使用 fyne 编写一个简单的计算器程序,主要介绍如何组合使用多种布局。当然计算器功能和错误处理还不完善,而且实现偏过程式编程,感兴趣的可自行完善。完整代码在 fyne/calculator 中。

大家如果发现好玩、好用的 Go 语言库,欢迎到 Go 每日一库 GitHub 上提交 issue:smile:

参考

  1. fyne GitHub:https://github.com/fyne-io/fyne

  2. fyne 官网:https://fyne.io/

  3. fyne 官方入门教程:https://developer.fyne.io/tour/introduction/hello.html

  4. Go 每日一库 GitHub:https://github.com/darjun/go-daily-lib

推荐阅读

喜欢本文的朋友,欢迎关注“ Go语言中文网

使用 Go GUI 库 fyne 编写一个计算器程序

Go 语言中 文网启用 信学习交流群,欢迎加微信 274768166 ,投稿亦欢迎


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

以奋斗者为本

以奋斗者为本

黄卫伟 / 中信出版社 / 2014-11-1 / 68.00元

《以奋斗者为本:华为公司人力资源管理纲要》传承于《华为公司基本法》,华为管理层25年人力资源管理思想精髓,5年整理,华为公司内训教材,首次大公开!作为华为公司内部培训教材,原汁原味,是继《华为基本法》之后华为的标志性著作,对国内外企业管理者&研究者具有高度的研究及借鉴价值。《以奋斗者为本:华为公司人力资源管理纲要》由华为公司首席管理科学家主编,华为高管及顾问参与编著,华为管理层25年实践,权威出品......一起来看看 《以奋斗者为本》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具