抱歉,您的浏览器无法访问本站
本页面需要浏览器支持(启用)JavaScript
了解详情 >

Termbox 提供一个最小化的 API,允许程序员编写基于文本的用户界面。在 Linux 操作系统有基于终端的实现,基本思想是对所有主要终端和其他类似终端的 API 上的最大的通用功能子集进行抽象,以最小的方式进行。小的 API 意味着它很容易实现、测试、维护、学习。

重要函数

下面我们简单介绍下比较重要的函数:

函数介绍
termbox.Size()获取 Console 的尺寸
termbox.SetCell(x, y, ch, fg, bg)用于设置字符单元属性,其中 x 表示所在行,y 表示所在列,ch 是要设置的字符,fg 和 bg 分布表示前景色和背景色
termbox.Flush()同步后台缓存。Flush 方法一般用于将后台的处理输出到界面中。如重新绘制一个界面
termbox.Init()在使用 Termbox 进行程序开发时候,我们需要先使用 termbox.Init 方法来初始化
termbox.Close()当不再使用 Termbox 任何功能时候,使用 termbox.Close 来关闭对 termbox 引入
termbox.PollEvent()用于等待键盘事件的触发并返回事件,无事件发生时则会无限等待

绘制代码

package main

import "github.com/nsf/termbox-go"
import "math/rand"
import "time"

func draw() {
    w, h := termbox.Size()
    termbox.Clear(termbox.ColorDefault, termbox.ColorDefault)
    for y := 0; y < h; y++ {
        for x := 0; x < w; x++ {
            termbox.SetCell(x, y, ' ', termbox.ColorDefault,
                termbox.Attribute(rand.Int()%8)+1)
        }
    }
    termbox.Flush()
}

func main() {
    err := termbox.Init()
    if err != nil {
        panic(err)
    }
    defer termbox.Close()

    event_queue := make(chan termbox.Event)
    go func() {
        for {
            event_queue <- termbox.PollEvent()
        }
    }()

    draw()
    for {
        select {
        case ev := <-event_queue:
            if ev.Type == termbox.EventKey && ev.Key == termbox.KeyEsc {
                return
            }
        default:
            draw()
            time.Sleep(10 * time.Millisecond)
        }
    }
}

注意:创建源文件 random_output.go,输入以上代码。

执行代码

go run random_output.go

注意:执行以上代码,就可以在终端中看到五彩缤纷的数据流啦,如果想退出程序需按下ESC键。

运行效果

效果如下:

评论