package main
import (
"fmt"
termbox "github.com/nsf/termbox-go"
)
func main() {
//固定使用的方式
//初始化
err := termbox.Init()
if err != nil {
panic(err)
}
//结束的时候,记得关闭
defer termbox.Close()
//为了循化结束
Loop:
for {
//termbox.PollEvent() 这个监控事件输入,保存到ev
//ev.Type 事件类型
//ev.Key 一些特殊按键,比如 key+c F1 F2 Esc Enter等
//ev.Ch 正常的字符健. abcd 1234
//termbox.EventKey 判断是否键盘事件
//termbox.EventResize 判断是否调整窗口大小
//termbox.EventMouse 判断是否鼠标事件
//termbox.EventError 判断错误事件
//termbox.EventInterrupt 判断终止事件.
switch ev := termbox.PollEvent(); ev.Type {
case termbox.EventKey:
switch ev.Ch {
case 'p', 'P':
fmt.Println("p")
case 'c', 'C':
fmt.Println("c")
default:
break Loop
}
}
}
}
版权声明:
作者:不倒翁
包说明:
import "github.com/nsf/termbox-go"
termbox-go
是一个用于创建跨平台TUI(基于文本的用户界面)的库。
索引
- Variables
- func CellBuffer() []Cell
- func Clear(fg, bg Attribute) error
- func Close()
- func Flush() error
- func HideCursor()
- func Init() error
- func Interrupt()
- func SetCell(x, y int, ch rune, fg, bg Attribute)
- func SetCursor(x, y int)
- func Size() (int, int)
- func Sync() error
- type Attribute
- type Cell
- type Event
- func PollEvent() Event
- type InputMode
- type Key
- type Modifier
- type OutputMode
包文件
api.go
api_common.go
syscalls_linux.go
termbox.go
termbox_common.go
terminfo.go
terminfo_builtin.go
变量
var (
IsInit bool = false
)
查看termbox
是否已经被初始化。
func CellBuffer
func CellBuffer() []Cell
返回一个slice
到termbox
的后台缓存。你可以使用Size
方法来获取后台缓存的大小。如果调用当前方法后,没有使用Clear
或Flush
方法清理缓存,后台缓存的Slice
将会一直存在。
func Clear
func Clear(fg, bg Attribute) error
清理内部后台缓存。
func Close
func Close()
当termbox
已经被成功初始化且termbox
的方法不再被需要的时候,调用这个方法来终止termbox
库。
func Flush
func Flush() error
与终端同步内部后台缓存。
func HideCursor
func HideCursor()
设置SetCursor(-1,-1)
的快捷键。
func Init
func Init() error
初始化termbox
库。这个方法需要在其他方法之前被调用。在成功过初始化后,库必须使用Close
方法结束。
示例:
err := termbox.Init()
if err != nil {
panic(err)
}
defer termbox.Close()
func Interrupt
func Interrupt()
通过返回一个EventInterrupt
来终止一个正在进行中的到PollEvent
的调用。需要注意的是,这个方法在PollEvent
方法被成功中断前,将会被阻塞。
func SetCell
func SetCell(x, y int, ch rune, fg, bg Attribute)
在指定的位置改变内部后台缓存中单元格的参数。
func SetCursor
func SetCursor(x, y int)
设置光标的位置。参见HideCursor()
func Size
func Size() (int, int)
返回内部缓存的大小(几乎与终端窗口尺寸同样大小)。但是当终端的大小被改变后,它并不总是与终端窗口的大小一致,内部后台缓存仅仅在Clear
或Flush
方法调用后才会获得同步。
func Sync
func Sync() error
当有事务引起termbox
对于终端缓存和实际情况的解析不同步时,立即同步。
type Attribute
type Attribute uint16
const (
ColorDefault Attribute = iota
ColorBlack
ColorRed
ColorGreen
ColorYellow
ColorBlue
ColorMagenta
ColorCyan
ColorWhite
)
单元格颜色,你可以通过使用bitwise
或|
混合多个属性。
const (
AttrBold Attribute = 1 << (iota + 9)
AttrUnderline
AttrReverse
)
单元格属性,通过使用bitwise
或|
来混合多个属性。虽然颜色不能被混合,但是你可以混合多个属性和一个独立的颜色。
值得一提的是,一些平台不支持某些的属性。例如Windows Console不支持下划线属性。在一些终端上,应用AttrBold
到背景,可能会引起文字的闪烁。小心的使用他们,并且在不同的终端上测试你的代码。
type Cell
type Cell struct {
Ch rune
Fg Attribute
Bg Attribute
}
一个单元格,在屏幕上的独立概念实体。屏幕是基于单元格的一个2d数组。Ch
是一个unicode
字符,Fg
和Bg
是前景和背景属性。
type Event
type Event struct {
Type EventType // one of Event* constants
Mod Modifier // one of Mod* constants or 0
Key Key // one of Key* constants, invalid if 'Ch' is not 0
Ch rune // a unicode character
Width int // width of the screen
Height int // height of the screen
Err error // error in case if input failed
MouseX int // x coord of mouse
MouseY int // y coord of mouse
}
此类型描述一个termbox
事件。Mod
、Key
以及Ch
字段是对Type
是否是一个键值事件的验证。Width
和Height
字段是对于Type
是否是重置重置的验证。Err
字段是对于Type
是否是错误事件的验证。
func PollEvent
func PollEvent() Event
等待一个事件,并返回它。这事一个阻塞方法调用。
type EventType
type EventType uint8
const (
EventKey EventType = iota
EventResize
EventMouse
EventError
EventInterrupt
)
指示事件类型,祥见Event.Type
字段。
type InputMode
type InputMode int
const (
InputEsc InputMode = 1 << iota
InputAlt
InputMouse
InputCurrent InputMode = 0
)
输入模式,详见SetInputMode
方法。
func SetInputMode
func SetInputMode(mode InputMode) InputMode
设置termbox
输入模式。Termbox有两种输入模式:
-
Esc
输入模式。当ESC
在缓冲序列当中,并且它与任何已知的序列匹配。ESC
表示KeyEsc
(ESC键值)。此为默认的输入模式。 -
Alt
输入模式。当ESC
在缓冲序列当中,并且它与任何已知的序列匹配。ESC
为下一个键盘事件启用ModAlt
修改器。
这两个模式都可以与Mouse
模式混用。设置Mouse
模式将启用鼠标点击事件。
如果mode
是InputCurrent
,返回当前的输入模式。详见输入模式与Input*
常量。
type Key
type Key uint16
const (
KeyF1 Key = 0xFFFF - iota
KeyF2
KeyF3
KeyF4
KeyF5
KeyF6
KeyF7
KeyF8
KeyF9
KeyF10
KeyF11
KeyF12
KeyInsert
KeyDelete
KeyHome
KeyEnd
KeyPgup
KeyPgdn
KeyArrowUp
KeyArrowDown
KeyArrowLeft
KeyArrowRight
MouseLeft
MouseMiddle
MouseRight
)
键值常量,详见Event.Key
字段。
const (
KeyCtrlTilde Key = 0x00
KeyCtrl2 Key = 0x00
KeyCtrlSpace Key = 0x00
KeyCtrlA Key = 0x01
KeyCtrlB Key = 0x02
KeyCtrlC Key = 0x03
KeyCtrlD Key = 0x04
KeyCtrlE Key = 0x05
KeyCtrlF Key = 0x06
KeyCtrlG Key = 0x07
KeyBackspace Key = 0x08
KeyCtrlH Key = 0x08
KeyTab Key = 0x09
KeyCtrlI Key = 0x09
KeyCtrlJ Key = 0x0A
KeyCtrlK Key = 0x0B
KeyCtrlL Key = 0x0C
KeyEnter Key = 0x0D
KeyCtrlM Key = 0x0D
KeyCtrlN Key = 0x0E
KeyCtrlO Key = 0x0F
KeyCtrlP Key = 0x10
KeyCtrlQ Key = 0x11
KeyCtrlR Key = 0x12
KeyCtrlS Key = 0x13
KeyCtrlT Key = 0x14
KeyCtrlU Key = 0x15
KeyCtrlV Key = 0x16
KeyCtrlW Key = 0x17
KeyCtrlX Key = 0x18
KeyCtrlY Key = 0x19
KeyCtrlZ Key = 0x1A
KeyEsc Key = 0x1B
KeyCtrlLsqBracket Key = 0x1B
KeyCtrl3 Key = 0x1B
KeyCtrl4 Key = 0x1C
KeyCtrlBackslash Key = 0x1C
KeyCtrl5 Key = 0x1D
KeyCtrlRsqBracket Key = 0x1D
KeyCtrl6 Key = 0x1E
KeyCtrl7 Key = 0x1F
KeyCtrlSlash Key = 0x1F
KeyCtrlUnderscore Key = 0x1F
KeySpace Key = 0x20
KeyBackspace2 Key = 0x7F
KeyCtrl8 Key = 0x7F
)
type Modifier
type Modifier uint8
const (
ModAlt Modifier = 0x01
)
Alt
修改常量,祥见Event.Mod
字段与SetInputMode
方法。
type OutputMode
type OutputMode int
const (
OutputCurrent OutputMode = iota
OutputNormal
Output256
Output216
OutputGrayscale
)
输出模式。详见SetOutputMode
方法。
func SetOutputMode
func SetOutputMode(mode OutputMode) OutputMode
设置termbox
输出模式。Termbox有四种输出选项:
- OutputNormal => [1..8]
此模式提供8个不同的颜色:
黑,红,绿,黄,蓝,品红,蓝绿色,白
快捷方式:ColorBlack,ColorRec,……
属性:AttrBold,AttrUnderline,AttrReverse
示例:
SetCell(x, y, '@', ColorBlack | AttrBold, ColorRed);
- Output256 => [1..256]
此模式你可以使用256色的终端模式:
0x00 - 0x07: 与OutputNormal一致的8个颜色
0x08 - 0x0f: Color* 或 AttrBold
0x10 - 0xe7: 216种不同的颜色
0xe8 - 0xff: 24种灰度
示例:
SetCell(x, y, '@', 184, 240);
SetCell(x, y, '@', 0xb8, 0xf0);
- Output216 => [1..216]
此种模式仅仅支持256色模式的第三种情况。但是你不需要提供偏移。
- OutputGrayscale => [1..24]
这个模式仅仅支持256色模式的第四种情况。但是你不需要提供偏移。在所有模式中0
表示默认的颜色。
使用go run _demos/output.go
查看它在你终端的响应。
如果mode
是OutputCurrent
它返回当前的输出模式。
需要注意的是,这将会返回一个不同的OutputMode
超过一个请求,当请求模式也许在目标平台上不可用时。
版权声明:
作者:莫不逢
出处:http://www.cnblogs.com/sitemanager/
Github:https://github.com/congjf
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
网友评论