1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-03 03:50:58 +00:00

feat(core/rust): add better support for odd-width icons

[no changelog]
This commit is contained in:
grdddj 2023-06-02 11:42:34 +02:00 committed by Jiří Musil
parent 531511407b
commit f27405109e
3 changed files with 38 additions and 11 deletions

View File

@ -156,6 +156,11 @@ pub fn image(image: &Image, center: Point) {
#[derive(PartialEq, Eq, Clone, Copy)] #[derive(PartialEq, Eq, Clone, Copy)]
pub struct Toif<'i> { pub struct Toif<'i> {
data: &'i [u8], data: &'i [u8],
/// Due to toif limitations, image width must be divisible by 2.
/// In cases the actual image is odd-width, it will have empty
/// rightmost column and this flag will make account for it
/// when determining the width and when drawing it.
pub empty_right_column: bool,
} }
impl<'i> Toif<'i> { impl<'i> Toif<'i> {
@ -168,7 +173,15 @@ impl<'i> Toif<'i> {
if zdatalen + TOIF_HEADER_LENGTH != data.len() { if zdatalen + TOIF_HEADER_LENGTH != data.len() {
return None; return None;
} }
Some(Self { data }) Some(Self {
data,
empty_right_column: false,
})
}
pub const fn with_empty_right_column(mut self) -> Self {
self.empty_right_column = true;
self
} }
pub const fn format(&self) -> ToifFormat { pub const fn format(&self) -> ToifFormat {
@ -189,7 +202,12 @@ impl<'i> Toif<'i> {
} }
pub const fn width(&self) -> i16 { pub const fn width(&self) -> i16 {
u16::from_le_bytes([self.data[4], self.data[5]]) as i16 let data_width = u16::from_le_bytes([self.data[4], self.data[5]]) as i16;
if self.empty_right_column {
data_width - 1
} else {
data_width
}
} }
pub const fn height(&self) -> i16 { pub const fn height(&self) -> i16 {
@ -245,6 +263,11 @@ impl Icon {
} }
} }
pub const fn with_empty_right_column(mut self) -> Self {
self.toif.empty_right_column = true;
self
}
/// Create a named icon. /// Create a named icon.
/// The name is only stored in debug builds. /// The name is only stored in debug builds.
pub const fn debug_named(data: &'static [u8], name: &'static str) -> Self { pub const fn debug_named(data: &'static [u8], name: &'static str) -> Self {

View File

@ -97,14 +97,7 @@ where
fn paint_warning_icons_in_top_corners(&self) { fn paint_warning_icons_in_top_corners(&self) {
let warning_icon = theme::ICON_WARNING; let warning_icon = theme::ICON_WARNING;
warning_icon.draw(AREA.top_left(), geometry::TOP_LEFT, theme::FG, theme::BG); warning_icon.draw(AREA.top_left(), geometry::TOP_LEFT, theme::FG, theme::BG);
// Needs x+1 Offset to compensate for empty right column (icon needs to be warning_icon.draw(AREA.top_right(), geometry::TOP_RIGHT, theme::FG, theme::BG);
// even-wide)
warning_icon.draw(
AREA.top_right() + Offset::x(1),
geometry::TOP_RIGHT,
theme::FG,
theme::BG,
);
} }
fn event_usb(&mut self, ctx: &mut EventCtx, event: Event) { fn event_usb(&mut self, ctx: &mut EventCtx, event: Event) {

View File

@ -160,9 +160,20 @@ pub fn long_line_content_with_ellipsis(
} }
#[macro_export] #[macro_export]
/// Create the `Icon` constant with given name and path.
/// Possibly users can supply `true` as a third argument and this
/// will signify that the icon has empty right column.
macro_rules! include_icon { macro_rules! include_icon {
($name:ident, $path:expr, empty_right_col = $empty:expr) => {
pub const $name: Icon = if $empty {
Icon::debug_named(include_res!($path), stringify!($name)).with_empty_right_column()
} else {
Icon::debug_named(include_res!($path), stringify!($name))
};
};
// No empty right column by default.
($name:ident, $path:expr) => { ($name:ident, $path:expr) => {
pub const $name: Icon = Icon::debug_named(include_res!($path), stringify!($name)); include_icon!($name, $path, empty_right_col = false);
}; };
} }