readme: add gif
This commit is contained in:
parent
6b6807d9ec
commit
7014a38a9c
3 changed files with 43 additions and 13 deletions
|
@ -4,12 +4,10 @@
|
||||||
It begins with them, but ends with me. Their son, Vaxis
|
It begins with them, but ends with me. Their son, Vaxis
|
||||||
```
|
```
|
||||||
|
|
||||||
libvaxis is a zig port of the go TUI library
|
![vaxis demo gif](vaxis.gif)
|
||||||
[Vaxis](https://git.sr.ht/~rockorager/vaxis). The goal is to have the same
|
|
||||||
feature set, only written in zig.
|
|
||||||
|
|
||||||
Like it's sibling library, libvaxis _does not use terminfo_. Support for vt
|
Libvaxis _does not use terminfo_. Support for vt features is detected through
|
||||||
features is detected through terminal queries.
|
terminal queries.
|
||||||
|
|
||||||
Contributions are welcome.
|
Contributions are welcome.
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,8 @@ const Event = union(enum) {
|
||||||
winsize: vaxis.Winsize,
|
winsize: vaxis.Winsize,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
pub const panic = vaxis.panic_handler;
|
||||||
|
|
||||||
pub fn main() !void {
|
pub fn main() !void {
|
||||||
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
|
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
|
||||||
defer {
|
defer {
|
||||||
|
@ -31,13 +33,17 @@ pub fn main() !void {
|
||||||
try vx.enterAltScreen(tty.anyWriter());
|
try vx.enterAltScreen(tty.anyWriter());
|
||||||
try vx.queryTerminal(tty.anyWriter(), 1 * std.time.ns_per_s);
|
try vx.queryTerminal(tty.anyWriter(), 1 * std.time.ns_per_s);
|
||||||
|
|
||||||
const lower_limit = 30;
|
try vx.queryColor(tty.anyWriter(), .fg);
|
||||||
var color_idx: u8 = lower_limit;
|
try vx.queryColor(tty.anyWriter(), .bg);
|
||||||
|
var pct: u8 = 0;
|
||||||
var dir: enum {
|
var dir: enum {
|
||||||
up,
|
up,
|
||||||
down,
|
down,
|
||||||
} = .up;
|
} = .up;
|
||||||
|
|
||||||
|
const fg = [_]u8{ 192, 202, 245 };
|
||||||
|
const bg = [_]u8{ 26, 27, 38 };
|
||||||
|
|
||||||
// block until we get a resize
|
// block until we get a resize
|
||||||
while (true) {
|
while (true) {
|
||||||
const event = loop.nextEvent();
|
const event = loop.nextEvent();
|
||||||
|
@ -61,7 +67,9 @@ pub fn main() !void {
|
||||||
const win = vx.window();
|
const win = vx.window();
|
||||||
win.clear();
|
win.clear();
|
||||||
|
|
||||||
const style: vaxis.Style = .{ .fg = .{ .rgb = [_]u8{ color_idx, color_idx, color_idx } } };
|
const color = try blendColors(bg, fg, pct);
|
||||||
|
|
||||||
|
const style: vaxis.Style = .{ .fg = color };
|
||||||
|
|
||||||
const segment: vaxis.Segment = .{
|
const segment: vaxis.Segment = .{
|
||||||
.text = vaxis.logo,
|
.text = vaxis.logo,
|
||||||
|
@ -70,16 +78,40 @@ pub fn main() !void {
|
||||||
const center = vaxis.widgets.alignment.center(win, 28, 4);
|
const center = vaxis.widgets.alignment.center(win, 28, 4);
|
||||||
_ = try center.printSegment(segment, .{ .wrap = .grapheme });
|
_ = try center.printSegment(segment, .{ .wrap = .grapheme });
|
||||||
try vx.render(tty.anyWriter());
|
try vx.render(tty.anyWriter());
|
||||||
std.time.sleep(8 * std.time.ns_per_ms);
|
std.time.sleep(16 * std.time.ns_per_ms);
|
||||||
switch (dir) {
|
switch (dir) {
|
||||||
.up => {
|
.up => {
|
||||||
color_idx += 1;
|
pct += 1;
|
||||||
if (color_idx == 255) dir = .down;
|
if (pct == 100) dir = .down;
|
||||||
},
|
},
|
||||||
.down => {
|
.down => {
|
||||||
color_idx -= 1;
|
pct -= 1;
|
||||||
if (color_idx == lower_limit) dir = .up;
|
if (pct == 0) dir = .up;
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// blend two rgb colors. pct is an integer percentage for te portion of 'b' in
|
||||||
|
/// 'a'
|
||||||
|
fn blendColors(a: [3]u8, b: [3]u8, pct: u8) !vaxis.Color {
|
||||||
|
// const r_a = (a[0] * (100 -| pct)) / 100;
|
||||||
|
|
||||||
|
const r_a = (@as(u16, a[0]) * @as(u16, (100 -| pct))) / 100;
|
||||||
|
const r_b = (@as(u16, b[0]) * @as(u16, pct)) / 100;
|
||||||
|
|
||||||
|
const g_a = (@as(u16, a[1]) * @as(u16, (100 -| pct))) / 100;
|
||||||
|
const g_b = (@as(u16, b[1]) * @as(u16, pct)) / 100;
|
||||||
|
// const g_a = try std.math.mul(u8, a[1], (100 -| pct) / 100);
|
||||||
|
// const g_b = (b[1] * pct) / 100;
|
||||||
|
|
||||||
|
const b_a = (@as(u16, a[2]) * @as(u16, (100 -| pct))) / 100;
|
||||||
|
const b_b = (@as(u16, b[2]) * @as(u16, pct)) / 100;
|
||||||
|
// const b_a = try std.math.mul(u8, a[2], (100 -| pct) / 100);
|
||||||
|
// const b_b = (b[2] * pct) / 100;
|
||||||
|
return .{ .rgb = [_]u8{
|
||||||
|
@min(r_a + r_b, 255),
|
||||||
|
@min(g_a + g_b, 255),
|
||||||
|
@min(b_a + b_b, 255),
|
||||||
|
} };
|
||||||
|
}
|
||||||
|
|
BIN
vaxis.gif
Normal file
BIN
vaxis.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1,022 KiB |
Loading…
Reference in a new issue