2018-01-18 09:06:45 +11:00
|
|
|
//!
|
|
|
|
//! Color Examples
|
|
|
|
//!
|
|
|
|
|
|
|
|
extern crate crossterm;
|
|
|
|
|
2018-06-10 07:19:02 +10:00
|
|
|
use self::crossterm::style::{ Color };
|
2018-06-17 04:10:51 +10:00
|
|
|
use self::crossterm::terminal;
|
|
|
|
use self::crossterm::Context;
|
2018-01-18 09:06:45 +11:00
|
|
|
|
|
|
|
/// print some red font | demonstration.
|
|
|
|
pub fn paint_foreground()
|
2018-06-17 04:10:51 +10:00
|
|
|
{
|
|
|
|
let context = Context::new();
|
2018-06-23 05:04:30 +10:00
|
|
|
let terminal = terminal::terminal(context.clone());
|
2018-06-17 04:10:51 +10:00
|
|
|
|
2018-01-18 09:06:45 +11:00
|
|
|
// Pass an string to the `paint()` method with you want to paint.
|
|
|
|
// This will give you an object back wits can be styled and displayed.
|
2018-06-17 04:10:51 +10:00
|
|
|
let mut styledobject = terminal.paint("Red font");
|
2018-01-18 09:06:45 +11:00
|
|
|
// Call the method `with()` on the object given by `paint()` and pass in any Color from the Color enum.
|
|
|
|
styledobject = styledobject.with(Color::Red);
|
|
|
|
// Print the object to the console and see the result.
|
|
|
|
println!("{}", styledobject);
|
|
|
|
|
|
|
|
// Crossterm provides method chaining so that the above points can be inlined.
|
2018-06-17 04:10:51 +10:00
|
|
|
println!("{}", terminal.paint("Red font").with(Color::Red));
|
2018-01-18 09:06:45 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/// print some font on red background | demonstration.
|
|
|
|
pub fn paint_background()
|
2018-06-17 04:10:51 +10:00
|
|
|
{
|
|
|
|
let context = Context::new();
|
2018-06-23 05:04:30 +10:00
|
|
|
let terminal = terminal::terminal(context.clone());
|
2018-06-17 04:10:51 +10:00
|
|
|
|
2018-01-18 09:06:45 +11:00
|
|
|
// Pass an string to the `paint()` method with you want to paint.
|
|
|
|
// This will give you an object back wits can be styled and displayed.
|
2018-06-17 04:10:51 +10:00
|
|
|
let mut styledobject = terminal.paint("Red background color");
|
2018-01-18 09:06:45 +11:00
|
|
|
// Call the method `on()` on the object given by `paint()` and pass in an Color from the Color enum.
|
2018-01-26 04:26:08 +11:00
|
|
|
styledobject = styledobject.on(Color::Red);
|
2018-01-18 09:06:45 +11:00
|
|
|
// Print the object to the console and check see the result
|
|
|
|
println!("{}", styledobject);
|
|
|
|
|
|
|
|
// Crossterm provides method chaining so that the above points can be inlined.
|
2018-06-17 04:10:51 +10:00
|
|
|
println!("{}", terminal.paint("Red background color").on(Color::Red));
|
2018-01-18 09:06:45 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/// print font with fore- background color | demonstration.
|
|
|
|
pub fn paint_foreground_and_background()
|
2018-06-17 04:10:51 +10:00
|
|
|
{
|
|
|
|
let context = Context::new();
|
2018-06-23 05:04:30 +10:00
|
|
|
let terminal = terminal::terminal(context.clone());
|
2018-06-17 04:10:51 +10:00
|
|
|
|
2018-01-18 09:06:45 +11:00
|
|
|
// Pass an string to the `paint()` method with you want to paint.
|
|
|
|
// This will give you an object back wits can be styled and displayed.
|
2018-06-17 04:10:51 +10:00
|
|
|
let mut styledobject = terminal.paint("Red font on blue background color");
|
2018-01-18 09:06:45 +11:00
|
|
|
/* Foreground color:
|
|
|
|
Call the method `with()` on the object given by `paint()`
|
|
|
|
Pass in an Color from the Color enum.
|
|
|
|
*/
|
|
|
|
styledobject = styledobject.with(Color::Red);
|
|
|
|
/* Background color:
|
|
|
|
Call the method `on()` on the object given by `paint()`
|
|
|
|
Pass in an Color from the Color enum.
|
|
|
|
*/
|
|
|
|
styledobject = styledobject.on(Color::Blue);
|
|
|
|
// Print the object to the console and see the result.
|
|
|
|
println!("{}", styledobject);
|
|
|
|
|
|
|
|
// Crossterm provides method chaining so that the above points can be inlined.
|
2018-06-17 04:10:51 +10:00
|
|
|
println!("{}", terminal.paint("Red font on blue background color").with(Color::Red).on(Color::Blue));
|
2018-01-18 09:06:45 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Print all available foreground colors | demonstration.
|
|
|
|
pub fn print_all_foreground_colors()
|
|
|
|
{
|
2018-06-17 04:10:51 +10:00
|
|
|
let context = Context::new();
|
2018-06-23 05:04:30 +10:00
|
|
|
let terminal = terminal::terminal(context.clone());
|
2018-06-17 04:10:51 +10:00
|
|
|
|
|
|
|
println!("Black : \t {}", terminal.paint("■").with(Color::Black));
|
|
|
|
println!("Red : \t\t {}", terminal.paint("■").with(Color::Red));
|
|
|
|
println!("Dark Red: \t {}", terminal.paint("■").with(Color::DarkRed));
|
|
|
|
println!("Green : \t {}", terminal.paint("■").with(Color::Green));
|
|
|
|
println!("Dark Green : \t {}", terminal.paint("■").with(Color::DarkGreen));
|
|
|
|
println!("Yellow : \t {}", terminal.paint("■").with(Color::Yellow));
|
|
|
|
println!("Dark Yellow : \t {}", terminal.paint("■").with(Color::DarkYellow));
|
|
|
|
println!("Blue : \t\t {}", terminal.paint("■").with(Color::Blue));
|
|
|
|
println!("Dark Blue : \t {}", terminal.paint("■").with(Color::DarkBlue));
|
|
|
|
println!("Magenta : \t {}", terminal.paint("■").with(Color::Magenta));
|
|
|
|
println!("Dark Magenta : \t {}", terminal.paint("■").with(Color::DarkMagenta));
|
|
|
|
println!("Cyan : \t\t {}", terminal.paint("■").with(Color::Cyan));
|
|
|
|
println!("Dark Cyan : \t {}", terminal.paint("■").with(Color::DarkCyan));
|
|
|
|
println!("Grey : \t\t {}", terminal.paint("■").with(Color::Grey));
|
|
|
|
println!("White : \t {}", terminal.paint("■").with(Color::White));
|
2018-01-18 09:06:45 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Print all available foreground colors | demonstration.
|
|
|
|
pub fn print_all_background_colors()
|
|
|
|
{
|
2018-06-17 04:10:51 +10:00
|
|
|
let context = Context::new();
|
2018-06-23 05:04:30 +10:00
|
|
|
let terminal = terminal::terminal(context.clone());
|
2018-06-17 04:10:51 +10:00
|
|
|
|
|
|
|
println!("Black : \t {}", terminal.paint(" ").on(Color::Black));
|
|
|
|
println!("Red : \t\t {}", terminal.paint(" ").on(Color::Red));
|
|
|
|
println!("Dark Red: \t {}", terminal.paint(" ").on(Color::DarkRed));
|
|
|
|
println!("Green : \t {}", terminal.paint(" ").on(Color::Green));
|
|
|
|
println!("Dark Green : \t {}", terminal.paint(" ").on(Color::DarkGreen));
|
|
|
|
println!("Yellow : \t {}", terminal.paint(" ").on(Color::Yellow));
|
|
|
|
println!("Dark Yellow : \t {}", terminal.paint(" ").on(Color::DarkYellow));
|
|
|
|
println!("Blue : \t\t {}", terminal.paint(" ").on(Color::Blue));
|
|
|
|
println!("Dark Blue : \t {}", terminal.paint(" ").on(Color::DarkBlue));
|
|
|
|
println!("Magenta : \t {}", terminal.paint(" ").on(Color::Magenta));
|
|
|
|
println!("Dark Magenta : \t {}", terminal.paint(" ").on(Color::DarkMagenta));
|
|
|
|
println!("Cyan : \t\t {}", terminal.paint(" ").on(Color::Cyan));
|
|
|
|
println!("Dark Cyan : \t {}", terminal.paint(" ").on(Color::DarkCyan));
|
|
|
|
println!("Grey : \t\t {}", terminal.paint(" ").on(Color::Grey));
|
|
|
|
println!("White : \t {}", terminal.paint(" ").on(Color::White));
|
2018-01-28 06:01:55 +11:00
|
|
|
#[cfg(unix)]
|
2018-06-17 04:10:51 +10:00
|
|
|
println!("RGB (10,10,10): \t {}", terminal.paint(" ").on(Color::Rgb {r: 10, g: 10, b: 10}));
|
2018-01-28 06:01:55 +11:00
|
|
|
#[cfg(unix)]
|
2018-06-17 04:10:51 +10:00
|
|
|
println!("RGB (10,10,10): \t {}", terminal.paint(" ").on(Color::AnsiValue(50)));
|
2018-01-28 04:26:08 +11:00
|
|
|
}
|
|
|
|
|
2018-01-31 07:20:11 +11:00
|
|
|
/// Print font with all available attributes. Note that this can only be used at unix systems and that some are not supported widely | demonstration..
|
2018-01-28 04:26:08 +11:00
|
|
|
#[cfg(unix)]
|
|
|
|
pub fn print_font_with_attributes()
|
|
|
|
{
|
2018-06-17 04:10:51 +10:00
|
|
|
let context = Context::new();
|
2018-06-23 05:04:30 +10:00
|
|
|
let terminal = terminal::terminal(context.clone());
|
2018-06-17 04:10:51 +10:00
|
|
|
|
|
|
|
println!("{}", terminal.paint("Normal text"));
|
|
|
|
println!("{}", terminal.paint("Bold text").bold());
|
|
|
|
println!("{}", terminal.paint("Italic text").italic());
|
|
|
|
println!("{}", terminal.paint("Slow blinking text").slow_blink());
|
|
|
|
println!("{}", terminal.paint("Rapid blinking text").rapid_blink());
|
|
|
|
println!("{}", terminal.paint("Hidden text").hidden());
|
|
|
|
println!("{}", terminal.paint("Underlined text").underlined());
|
|
|
|
println!("{}", terminal.paint("Reversed color").reverse());
|
|
|
|
println!("{}", terminal.paint("Dim text color").dim());
|
|
|
|
println!("{}", terminal.paint("Crossed out font").crossed_out());
|
2018-01-28 04:26:08 +11:00
|
|
|
}
|
|
|
|
|
2018-01-31 07:20:11 +11:00
|
|
|
/// Print all supported rgb colors | demonstration.
|
2018-03-11 03:33:06 +11:00
|
|
|
#[cfg(unix)]
|
2018-01-28 04:26:08 +11:00
|
|
|
pub fn print_supported_colors()
|
2018-06-17 04:10:51 +10:00
|
|
|
{
|
|
|
|
let context = Context::new();
|
2018-06-23 05:04:30 +10:00
|
|
|
let terminal = terminal::terminal(context.clone());
|
2018-06-17 04:10:51 +10:00
|
|
|
|
2018-06-27 02:48:50 +10:00
|
|
|
let count = crossterm::style::color(context.clone()).get_available_color_count().unwrap();
|
2018-01-28 04:26:08 +11:00
|
|
|
|
|
|
|
for i in 0..count
|
|
|
|
{
|
2018-06-17 04:10:51 +10:00
|
|
|
println!("{}", terminal.paint(format!("Color: {}",i)).with(Color::AnsiValue(i as u8)));
|
2018-01-28 04:26:08 +11:00
|
|
|
}
|
2018-01-18 09:06:45 +11:00
|
|
|
}
|