1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
use termion::color;

/// # Pixel structure
/// contains color data and character data
#[derive(Clone)]
pub struct Pixel {
    pub colors: String,
    pub chr: char
}
impl std::fmt::Display for Pixel {
    fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result 
    {
        fmt.write_str(self.colors.as_str()).unwrap();
        fmt.write_str(self.chr.to_string().as_str()).unwrap();
        Ok(())
    }
}

/// Generate a pixel using a character, a foreground and background color
/// 
/// usage: 
/// ```
/// use console_engine::pixel;
/// use console_engine::termion::color;
/// // ...
/// engine.set_pxl(0,0,pixel::pxl_fbg('X', color::Blue, color::White));
/// ```
pub fn pxl_fbg<C1: color::Color, C2: color::Color>(value: char, fg: C1, bg: C2) -> Pixel {
    Pixel {
        colors: format!("{}{}", color::Fg(fg), color::Bg(bg)),
        chr: value
    }
}

/// Generate a pixel using a character and a foreground color.  
/// Background color is always black.
/// 
/// usage: 
/// ```
/// use console_engine::pixel;
/// use console_engine::termion::color;
/// // ...
/// engine.set_pxl(0,0,pixel::pxl_fg('X', color::Cyan));
/// ```
pub fn pxl_fg<C: color::Color>(value: char, fg: C) -> Pixel {
    Pixel {
        colors: format!("{}{}", color::Fg(fg), color::Bg(color::Black)),
        chr: value
    }
}
/// Generate a pixel using a character and a background color.  
/// Foreground color is always White.
/// 
/// usage: 
/// ```
/// use console_engine::pixel;
/// use console_engine::termion::color;
/// // ...
/// engine.set_pxl(0,0,pixel::pxl_bg('X', color::Magenta));
/// ```
pub fn pxl_bg<C: color::Color>(value: char, bg: C) -> Pixel {
    Pixel {
        colors: format!("{}{}", color::Fg(color::White), color::Bg(bg)),
        chr: value
    }
}

/// Generate a pixel using a character  
/// Foreground color is always White.  
/// Background color is always black.
/// 
/// usage: 
/// ```
/// use console_engine::pixel;
/// // ...
/// engine.set_pxl(0,0,pixel::pxl('X'));
/// ```
pub fn pxl(value: char) -> Pixel {
    Pixel {
        colors: format!("{}{}", color::Fg(color::White), color::Bg(color::Black)),
        chr: value
    }
}