From 3549c1a709ebc6847f528068eb85ecd63e8ea097 Mon Sep 17 00:00:00 2001 From: Jaby Date: Sat, 8 Mar 2025 17:11:00 +0100 Subject: [PATCH] Display full image in main window preview --- src/Tools/tim_tool/src/gui/main_tab.rs | 9 +++++---- src/Tools/tim_tool/src/main.rs | 5 +++-- src/Tools/tim_tool/ui/tab/main-tab.slint | 5 +++-- 3 files changed, 11 insertions(+), 8 deletions(-) diff --git a/src/Tools/tim_tool/src/gui/main_tab.rs b/src/Tools/tim_tool/src/gui/main_tab.rs index ddc68fa6..4bb58145 100644 --- a/src/Tools/tim_tool/src/gui/main_tab.rs +++ b/src/Tools/tim_tool/src/gui/main_tab.rs @@ -46,11 +46,12 @@ impl MainTab { MainTab{main_window, vram: Arc::new(Mutex::new(VRAM{count: 0, file_list: vram_file_list, image_list: vram_image_list}))} } - pub fn add_new_vram_file(&mut self, file_name: &String, image: slint::Image, encoding: Encoding, image_palette: Option) -> usize { + pub fn add_new_vram_file(&mut self, file_name: &String, full_image: slint::Image, image: slint::Image, encoding: Encoding, image_palette: Option) -> usize { let mut vram_data = self.vram.lock().expect("VRAM already locked"); - let mut add_new_image = |file_name: &String, image: slint::Image, encoding: Encoding, palette_count: i32, is_palette: bool| { + let mut add_new_image = |file_name: &String, full_image: slint::Image, image: slint::Image, encoding: Encoding, palette_count: i32, is_palette: bool| { let encoding_str = if is_palette {""} else {encoding.to_str()}; let vram_image = VRAMImage{ + full_img: full_image, img: image, x: 0, y: 0, @@ -63,12 +64,12 @@ impl MainTab { }; let mut images_added = 1; - add_new_image(file_name, image, encoding, if image_palette.is_some() {1} else {0}, false); + add_new_image(file_name, full_image, image, encoding, if image_palette.is_some() {1} else {0}, false); if let Some(image_palette) = image_palette { let file_name = " => ".to_owned() + file_name.as_str() + " (Palette)"; images_added += 1; - add_new_image(&file_name, image_palette, encoding, 0, true); + add_new_image(&file_name, image_palette.clone(), image_palette, encoding, 0, true); } images_added diff --git a/src/Tools/tim_tool/src/main.rs b/src/Tools/tim_tool/src/main.rs index ffae5ca9..e5e672a7 100644 --- a/src/Tools/tim_tool/src/main.rs +++ b/src/Tools/tim_tool/src/main.rs @@ -6,7 +6,7 @@ use gui::{GUIElements, VRAM_WIDTH, VRAM_HEIGHT, display_information}; use rfd::FileDialog; use std::{cell::RefCell, rc::Rc}; use slint::SharedString; -use tim_tool::logic::Logic; +use tim_tool::logic::{tim::types::Encoding, Logic}; use tool_helper::Error; slint::include_modules!(); @@ -88,8 +88,9 @@ fn setup_file_tab(gui_elements_ref: Rc>, logic_ref: Rc { cur_sel_x.text = root.vram_images[current-item].x; cur_sel_y.text = root.vram_images[current-item].y; - cur_sel_img.source = root.vram_images[current-item].img; + cur_sel_img.source = root.vram_images[current-item].full_img; encoding_text.encoding_str = root.vram_images[current-item].encoding_str; cur_sel_img.visible = true; }