GoSimplePrint 是一款用go写的开源简单进度条打印包。我可以利用它,在自己项目中需要加入进度条功能。
1、安装
1
|
go get -u github.com/redmask-hb/GoSimplePrint/goPrint
|
2、初始化
bar:=goPrint.NewBar(20)
这里的20,是我们满进度条的数值。如果我们要让进度条走满的时候值是100,那么应该NewBar(100)
3、配置参数
(1)设置
bar.SetGraph(graph string) //设置进度条图块,默认"█"
bar.SetNotice(notice string) //设置进度条前的提示内容,可选
bar.SetProgressGraphTotal(totalGraph int) //设置进度条完成所填图块的总数,默认:50 ,通过配置不同的图块和数量可以改变进度条的总长度。
bar.SetEnds(start,end string) //设置进度条端块,默认为 srart:"[",end:"]"
bar.SetBackGraph(graph string) //设置背面被进度条替换的图形,默认" "
(2)隐藏
bar.HideProgressBar() //隐藏进度条
bar.HidePercent() //隐藏百分比
bar.HideRatio() //隐藏比值
(3)颜色设置
bar.SetColor(color BarColor) //配置所有的颜色选项
bar.SetBackColor(color int) //设置进度条背景色
bar.SetRatioColor(color int) //设置比值颜色
bar.SetPercentColor(color int) //设置百分比颜色
bar.SetNoticeColor(color int) //设置提示颜色
bar.SetGraphColor(clor int) //设置移动图块颜色
( 由于windows的cmd颜色打印,需要调用系统API,目前版本在windows操作系统下颜色是被忽略的 )
背景颜色为40-47,字体颜色为30-37,可以参考下表:
0 黑色 1 红色 2 绿色 3 黄色 4 蓝色 5 紫红色 6 青蓝色 7 白色
你也可以直接使用包中定义的颜色参数
1
2
3
4
|
bar.SetNoticeColor(goPrint.FontColor.Yellow)
bar.SetBackColor(goPrint.BackColor.Red)
bar.SetGraphColor(goPrint.FontColor.Blue)
bar.SetRatioColor(goPrint.FontColor.Red)
|
4、打印
bar.PrintBar(curValue) //curValue 是进度的当前值,在for循环中,动态将当前值传入到bar对象
5、结束
bar.PrintEnd(tip) //tip为可选参数
当进度条完成后,可以使用PrintEnd() 给出一个结束提示,可以传入一个要打印的内容,也可以不传。不传即为在进度条最后加一个"\n"。
参考实例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
func main() {
bar:=goPrint.NewBar(20)
bar.SetNotice("进度条:")
bar.SetGraph(">")
bar.SetNoticeColor(goPrint.FontColor.Red)
f or i:=1;i<=20;i++ {
bar.PrintBar(i)
time.Sleep(time.Second)
}
bar.PrintEnd("Finish!")
}
|
打印效果
到此这篇关于使用golang实现在屏幕上打印进度条的操作的文章就介绍到这了,更多相关golang在屏幕上打印进度条内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://studygolang.com/articles/33660