Crates.io | termbg |
lib.rs | termbg |
version | 0.6.1 |
source | src |
created_at | 2020-11-09 10:20:28.730055 |
updated_at | 2024-11-15 06:03:07.050153 |
description | Terminal background color detection |
homepage | |
repository | https://github.com/dalance/termbg |
max_upload_size | |
id | 310245 |
size | 70,347 |
A Rust library for terminal background color detection. The detected color is provided by RGB or theme ( dark or light ).
If you check other terminals, please report through issue.
"Windows Terminal" may be supported in a future release: https://github.com/microsoft/terminal/issues/3718.
[dependencies]
termbg = "0.6.1"
fn main() {
let timeout = std::time::Duration::from_millis(100);
println!("Check terminal background color");
let term = termbg::terminal();
let rgb = termbg::rgb(timeout);
let theme = termbg::theme(timeout);
println!(" Term : {:?}", term);
match rgb {
Ok(rgb) => {
println!(" Color: R={:x}, G={:x}, B={:x}", rgb.r, rgb.g, rgb.b);
}
Err(e) => {
println!(" Color: detection failed {:?}", e);
}
}
match theme {
Ok(theme) => {
println!(" Theme: {:?}", theme);
}
Err(e) => {
println!(" Theme: detection failed {:?}", e);
}
}
}
This crate provides a simple program to check.
$ cargo run
Check terminal background color
Term : Tmux
Color: R=0, G=0, B=0
Theme: Dark
If the terminal is win32 console, WIN32API is used for detection.
If the terminal is xterm compatible, "Xterm Control Sequences" is used.
When these method was failed, COLORFGBG
environment variable is used.
The detected RGB is converted to YCbCr. If Y > 0.5, the theme is detected as "light", otherwise "dark".