2023-06-19 19:21:05 -04:00
|
|
|
use std::io::{ self, Write };
|
2023-04-13 15:04:05 -04:00
|
|
|
|
|
|
|
use termion::{
|
|
|
|
terminal_size,
|
|
|
|
|
|
|
|
clear,
|
2023-07-03 17:43:54 -04:00
|
|
|
color::{ Bg, Fg, Rgb },
|
2023-04-13 15:04:05 -04:00
|
|
|
cursor,
|
|
|
|
input::TermRead,
|
2023-06-19 19:21:05 -04:00
|
|
|
raw::IntoRawMode
|
2023-04-13 15:04:05 -04:00
|
|
|
};
|
|
|
|
|
2023-07-03 13:11:45 -04:00
|
|
|
use crate::color::{ RESET, RESET_BG, Colors };
|
2023-06-22 20:20:45 -04:00
|
|
|
|
|
|
|
pub static BLOCK: &str = "█";
|
|
|
|
pub static UHALF: &str = "▀";
|
2023-04-13 15:04:05 -04:00
|
|
|
|
2023-06-19 20:08:05 -04:00
|
|
|
pub fn full(colors: Colors) {
|
2023-04-13 15:04:05 -04:00
|
|
|
let mut stdout = io::stdout().into_raw_mode().unwrap();
|
|
|
|
let stdin = io::stdin();
|
|
|
|
|
|
|
|
let count = colors.len();
|
|
|
|
let (width, height) = terminal_size().unwrap();
|
|
|
|
let thresh = height as usize / count;
|
|
|
|
|
|
|
|
write!(stdout, "{}{}", cursor::Hide, clear::All).ok();
|
|
|
|
stdout.flush().ok();
|
|
|
|
|
|
|
|
let stripe = BLOCK.repeat(width as usize);
|
|
|
|
|
|
|
|
let mut index = 0;
|
|
|
|
for n in 0..(height as usize) {
|
|
|
|
if n != 0 && n % thresh == 0 {
|
|
|
|
index += 1;
|
|
|
|
if index >= count { break; }
|
|
|
|
}
|
|
|
|
write!(
|
|
|
|
stdout,
|
2023-06-19 19:21:05 -04:00
|
|
|
"{color}{stripe}{RESET}",
|
2023-04-13 15:04:05 -04:00
|
|
|
color = colors[index]
|
|
|
|
).ok();
|
|
|
|
}
|
|
|
|
stdout.flush().ok();
|
|
|
|
|
|
|
|
for _ in stdin.keys() { break; }
|
|
|
|
write!(stdout, "{}{}", cursor::Show, clear::All).ok();
|
|
|
|
stdout.flush().ok();
|
|
|
|
}
|
|
|
|
|
2023-06-19 20:08:05 -04:00
|
|
|
pub fn small(colors: Colors) {
|
|
|
|
let mut stdout = io::stdout();
|
|
|
|
|
|
|
|
let count = colors.len();
|
|
|
|
let width = count * 3;
|
|
|
|
|
|
|
|
let stripe = BLOCK.repeat(width);
|
|
|
|
|
|
|
|
for color in colors {
|
|
|
|
println!("{color}{stripe}");
|
|
|
|
}
|
|
|
|
print!("{RESET}");
|
|
|
|
stdout.flush().ok();
|
|
|
|
}
|
2023-04-13 15:04:05 -04:00
|
|
|
|
2023-07-07 12:36:31 -04:00
|
|
|
pub fn draw_lines(lines: Vec<String>, hold: bool) {
|
2023-07-03 13:11:45 -04:00
|
|
|
let mut stdout = io::stdout().into_raw_mode().unwrap();
|
|
|
|
|
|
|
|
let count = lines.len() as u16;
|
|
|
|
for _ in 0..count { write!(stdout, "\n").ok(); }
|
|
|
|
write!(stdout, "{}", cursor::Up(count)).ok();
|
|
|
|
|
|
|
|
if hold { write!(stdout, "{}{}", cursor::Hide, clear::All).ok(); }
|
|
|
|
|
|
|
|
let down = cursor::Down(1);
|
|
|
|
for line in lines {
|
|
|
|
let left = cursor::Left(line.len() as u16);
|
|
|
|
write!(stdout, "{line}{left}{down}").ok();
|
|
|
|
}
|
|
|
|
|
|
|
|
write!(stdout, "{RESET}{RESET_BG}").ok();
|
|
|
|
stdout.flush().ok();
|
|
|
|
if hold {
|
|
|
|
let stdin = io::stdin();
|
|
|
|
for _ in stdin.keys() { break; }
|
|
|
|
write!(stdout, "{}", clear::All).ok();
|
|
|
|
}
|
|
|
|
write!(stdout, "{}", cursor::Show).ok();
|
|
|
|
stdout.flush().ok();
|
|
|
|
}
|
|
|
|
|
2023-07-03 17:43:54 -04:00
|
|
|
pub fn fg_stripes(colors: Vec<Fg<Rgb>>, width: u16, height: u16) -> Vec<String> {
|
|
|
|
let width = width as usize;
|
|
|
|
let height = height as usize;
|
|
|
|
let count = colors.len();
|
|
|
|
|
|
|
|
let thresh = height / count;
|
|
|
|
|
|
|
|
let stripe = BLOCK.repeat(width);
|
|
|
|
let mut output = Vec::new();
|
|
|
|
|
|
|
|
let mut index = 0;
|
|
|
|
for n in 0..height {
|
|
|
|
if n != 0 && n % thresh == 0 {
|
|
|
|
index += 1;
|
|
|
|
if index >= count { break; }
|
|
|
|
}
|
|
|
|
let color = colors[index];
|
|
|
|
output.push(format!("{color}{stripe}"));
|
|
|
|
}
|
|
|
|
|
|
|
|
output
|
|
|
|
}
|
|
|
|
pub fn bg_stripes(colors: Vec<Bg<Rgb>>, width: u16, height: u16) -> Vec<String> {
|
|
|
|
let width = width as usize;
|
|
|
|
let height = height as usize;
|
|
|
|
let count = colors.len();
|
|
|
|
|
|
|
|
let thresh = height / count;
|
|
|
|
|
|
|
|
let stripe = " ".repeat(width);
|
|
|
|
let mut output = Vec::new();
|
|
|
|
|
|
|
|
let mut index = 0;
|
|
|
|
for n in 0..height {
|
|
|
|
if n != 0 && n % thresh == 0 {
|
|
|
|
index += 1;
|
|
|
|
if index >= count { break; }
|
|
|
|
}
|
|
|
|
let color = colors[index];
|
|
|
|
output.push(format!("{color}{stripe}"));
|
|
|
|
}
|
|
|
|
|
|
|
|
output
|
|
|
|
}
|
|
|
|
|
2023-07-07 12:36:31 -04:00
|
|
|
pub enum Flag {
|
|
|
|
Stripes(Colors),
|
|
|
|
Lines(Vec<String>)
|
|
|
|
}
|
|
|
|
impl Flag {
|
|
|
|
pub fn draw(self, hold: bool) {
|
|
|
|
let lines = match self {
|
|
|
|
Flag::Stripes(colors)
|
|
|
|
=> {
|
|
|
|
let (width, height);
|
|
|
|
if hold { (width, height) = terminal_size().unwrap(); }
|
|
|
|
else {
|
|
|
|
height = colors.len() as u16;
|
|
|
|
width = height * 3;
|
|
|
|
}
|
|
|
|
fg_stripes(colors, width, height)
|
|
|
|
},
|
|
|
|
Flag::Lines(lines)
|
|
|
|
=> lines
|
|
|
|
};
|
|
|
|
draw_lines(lines, hold);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|