From 993c1c5309c259ad046984c17db2c39ed055bd0b Mon Sep 17 00:00:00 2001 From: Falko Habel Date: Mon, 11 Mar 2024 09:50:18 +0100 Subject: [PATCH] key Bindings are added --- main.py | 33 +++++++++++---- scripts/Converter.py | 1 - scripts/Labeling.py | 53 +++++++++++++++++++----- scripts/folder_mangement/CreateFolder.py | 1 - scripts/folder_mangement/OpenFolder.py | 10 +++++ scripts/folder_mangement/SwitchFolder.py | 10 ++++- 6 files changed, 88 insertions(+), 20 deletions(-) diff --git a/main.py b/main.py index 8c8ea83..477656c 100644 --- a/main.py +++ b/main.py @@ -4,14 +4,14 @@ from PIL import Image import scripts.get_sys_info as system_code from scripts.ClosePopup import ClosePopup -from scripts.settings import Settings +from scripts.Settings import Settings from scripts.Converter import Converter from scripts.Labeling import Labeling from scripts.folder_mangement.OpenFolder import OpenFolder from scripts.folder_mangement.CreateFolder import CreateFolder from scripts.folder_mangement.SwitchFolder import SwitchFolder -from scripts.SaveData import SaveData + SELECTION_TEXT = "Select your Directory and your Export Directory" @@ -42,7 +42,6 @@ class App(Ctk.CTk): self.current_labeling_frame = None self.last_opened_labeling_frame = None self.window_informaton_save = () - # Top Menu # Widgets self.settings_btn = Ctk.CTkButton(self, text="Settings", width=100, command=self.open_settings, font=self.my_font) @@ -53,7 +52,8 @@ class App(Ctk.CTk): # Alignment self.place_top_menu() self.show_main_menu() - + self.bind("", self.go_back) + # Open Main UI initially def show_main_menu(self): self.window_information.configure(text="Choose if you want to convert or label DATA") @@ -83,13 +83,19 @@ class App(Ctk.CTk): def open_current_labeling_ui(self): self.active_frame.place_forget() + if self.active_frame != self.buttons_frame: + self.active_frame.disable_keybinding() if self.current_labeling_frame == None: self.window_information.configure(text=SELECTION_TEXT) self.Switch_folder = SwitchFolder(master=self, callback=self.open_labeling) self.current_labeling_frame = self.Switch_folder + self.current_labeling_frame.place(relx=0.5, rely=0.52,relwidth=0.95, relheight=0.85, anchor="center") - else: + + else: self.current_labeling_frame.place(relx=0.5, rely=0.52,relwidth=0.95, relheight=0.85, anchor="center") + + self.current_labeling_frame.enable_keybinding() self.active_frame = self.current_labeling_frame self.last_frame = self.buttons_frame @@ -98,6 +104,7 @@ class App(Ctk.CTk): self.last_opened_labeling_frame = self.current_labeling_frame self.last_frame = self.current_labeling_frame self.current_labeling_frame.place_forget() + self.current_labeling_frame.disable_keybinding() self.labeling = Labeling(master=self, img_paths=img_paths, output_path=output, callback=self.open_folder_uis, window_information=self.change_window_information) self.current_labeling_frame = self.labeling self.active_frame = self.current_labeling_frame @@ -107,6 +114,7 @@ class App(Ctk.CTk): self.last_opened_labeling_frame = self.current_labeling_frame self.last_frame = self.current_labeling_frame self.current_labeling_frame.place_forget() + self.current_labeling_frame.disable_keybinding() self.labeling.update_active_output_path(output) self.current_labeling_frame = self.labeling self.active_frame = self.current_labeling_frame @@ -116,6 +124,7 @@ class App(Ctk.CTk): self.last_opened_labeling_frame = self.current_labeling_frame self.last_frame = self.current_labeling_frame self.current_labeling_frame.place_forget() + self.current_labeling_frame.disable_keybinding() if variant == 0: self.window_information.configure(text="Create new folder in active directory") self.create_folder = CreateFolder(master=self,output_path=output, callback=self.reopen_labeling) @@ -149,6 +158,8 @@ class App(Ctk.CTk): elif self.active_frame == self.open_folder: self.last_frame = self.open_folder self.active_frame.place_forget() + if self.active_frame != self.buttons_frame: + self.active_frame.disable_keybinding() self.window_information.configure(text="Settings") self.last_opened_labeling_frame = self.current_labeling_frame self.active_frame = self.settings_frame @@ -161,13 +172,14 @@ class App(Ctk.CTk): self.active_frame = self.converter_frame self.place_ui() - def go_back(self): + def go_back(self, event = None): if self.active_frame == self.buttons_frame: return elif self.active_frame == self.settings_frame: system_code.save_setting_change() if self.last_frame != self.buttons_frame: self.active_frame.place_forget() + self.active_frame.disable_keybinding() self.active_frame = self.last_frame self.last_frame = None self.place_ui() @@ -179,17 +191,20 @@ class App(Ctk.CTk): self.switch_to_labeling() elif self.active_frame == self.Switch_folder: self.active_frame.place_forget() + self.active_frame.disable_keybinding() self.active_frame = self.buttons_frame self.last_frame = None self.last_opened_labeling_frame = self.Switch_folder self.place_ui() elif self.active_frame == self.converter_frame: self.active_frame.place_forget() + self.active_frame.disable_keybinding() self.active_frame = self.buttons_frame self.last_frame = None self.place_ui() elif self.active_frame == self.labeling: self.active_frame.place_forget() + self.active_frame.disable_keybinding() self.active_frame = self.buttons_frame self.last_frame = None self.last_opened_labeling_frame = self.labeling @@ -207,12 +222,14 @@ class App(Ctk.CTk): self.hide_and_prepare_last_labeling() self.change_window_information(None) self.active_frame.place_forget() + self.active_frame.disable_keybinding() self.active_frame = self.labeling self.place_ui() def hide_and_prepare_last_labeling(self): if self.current_labeling_frame: self.current_labeling_frame.place_forget() + self.current_labeling_frame.disable_keybinding() self.last_opened_labeling_frame = self.current_labeling_frame self.current_labeling_frame = self.labeling @@ -223,7 +240,9 @@ class App(Ctk.CTk): def place_ui(self): self.active_frame.place(relx=0.5, rely=0.52,relwidth=0.95, relheight=0.85, anchor="center") - + if self.active_frame != self.buttons_frame: + self.active_frame.enable_keybinding() + def close_attempt(self): if self.settings_frame.winfo_ismapped() or self.converter_frame.winfo_ismapped(): self.popup = ClosePopup(master=self, callback=self.close_program) diff --git a/scripts/Converter.py b/scripts/Converter.py index ee0f938..10ee773 100644 --- a/scripts/Converter.py +++ b/scripts/Converter.py @@ -267,7 +267,6 @@ class Converter(Ctk.CTkFrame): return percent def align(self): - self.enable_keybinding() # output placing self.input_entry.place( relx=0.10, diff --git a/scripts/Labeling.py b/scripts/Labeling.py index 5a2ff51..36d20fe 100644 --- a/scripts/Labeling.py +++ b/scripts/Labeling.py @@ -1,7 +1,6 @@ import customtkinter as Ctk import os from PIL import Image, ImageTk, ImageDraw -import io from scripts.SaveData import SaveData import scripts.get_sys_info as system_code @@ -36,6 +35,7 @@ class Labeling(Ctk.CTkFrame): # bounding boxes self.labeling_boxes = [] + self.data_mode_index = system_code.data_modes.index(system_code.data_mode) self.labeling_box_index = 0 self.original_factor = None self.img_factor_x = None @@ -45,9 +45,35 @@ class Labeling(Ctk.CTkFrame): self.mpenn_data = self.data_saver.search_in_folder(self.active_output_path) self.save_index = self.data_saver.find_highest_image_number(self.mpenn_data[0]) - self.bind("", self.save_and_load) - self.start() + + def enable_keybinding(self): + """ + r: Remove the picture + j: jump in Time + l: Labeling / Resize Switch + o: Open Folder + c: Create Folder + s: Switch Folder + Return: Save Image + """ + print("gettriggered") + self.master.bind("", self.delete_current_rectangle, add="+") + self.master.bind("", self.skip_time, add="+") + self.master.bind("", self.set_data_mode_binding, add="+") + self.master.bind("", self.open_new_folder, add="+") + self.master.bind("", self.create_new_folder, add="+") + self.master.bind("", self.source_folder_dialog, add="+") + self.master.bind("", self.save_and_load, add="+") + + def disable_keybinding(self): + self.master.unbind("") + self.master.unbind("") + self.master.unbind("") + self.master.unbind("") + self.master.unbind("") + self.master.unbind("") + self.master.unbind("") def update_active_output_path(self, output_path): self.active_output_path = output_path @@ -132,7 +158,7 @@ class Labeling(Ctk.CTkFrame): def set_data_mode(self, value): system_code.data_mode = value - if system_code.data_mode == "Resize": + if system_code.data_mode == system_code.data_modes[0]: self.reset_rectangle() else: if self.tk_cropped_image is not None: @@ -140,6 +166,13 @@ class Labeling(Ctk.CTkFrame): else: self.show_img(self.img_paths[self.index]) + def set_data_mode_binding(self, value = None): + self.data_mode_index = 1 - self.data_mode_index + system_code.data_mode = system_code.data_modes[self.data_mode_index] + self.choose_mode.set(system_code.data_mode) + print("also triggered") + + def adjust_image_sizes_for_buttons(self): """Adjust the image sizes based on the current height of the buttons and update them accordingly.""" @@ -190,7 +223,7 @@ class Labeling(Ctk.CTkFrame): def save_and_load(self): save_path = f"{self.active_output_path}/{self.save_index:03d}{system_code.img_format}" - if system_code.data_mode == "Labeling": + if system_code.data_mode == system_code.data_modes[1]: if len(self.labeling_boxes) == 0: self.labeled = False else: @@ -316,7 +349,7 @@ class Labeling(Ctk.CTkFrame): self.start_x = event.x self.start_y = event.y # If there's an existing rectangle, remove it - if self.rect and (system_code.data_mode == "Resize"): + if self.rect and (system_code.data_mode == system_code.data_modes[0]): self.delete_current_rectangle(self.rect) # Create an initial 1x1 rectangle that will be adjusted in `on_drag` self.rect = self.big_canvas.create_rectangle(self.start_x, self.start_y, self.start_x+1, self.start_y+1, @@ -342,12 +375,12 @@ class Labeling(Ctk.CTkFrame): self.delete_current_rectangle(self.rect) # Start a new rectangle self.rect = self.big_canvas.create_rectangle(self.start_x, self.start_y, self.start_x+1, self.start_y+1, - outline=system_code.color if system_code.data_mode == "Labeling" else "#5f00c7", - width=system_code.thickness // self.img_factor_x if system_code.data_mode == "Labeling" else 1) + outline=system_code.color if system_code.data_mode == system_code.data_modes[1] else "#5f00c7", + width=system_code.thickness // self.img_factor_x if system_code.data_mode == system_code.data_modes[1] else 1) self.end_x, self.end_y = event.x, event.y - if system_code.data_mode == "Resize": + if system_code.data_mode == system_code.data_modes[0]: # Maintain 1:1 aspect ratio for resize mode delta_x = self.end_x - self.start_x delta_y = self.end_y - self.start_y @@ -376,7 +409,7 @@ class Labeling(Ctk.CTkFrame): self.big_canvas.coords(self.rect, self.start_x, self.start_y, self.end_x, self.end_y) self.display_cropped_part() # New line to display the cropped area self.dragging = False # Reset dragging flag - if system_code.data_mode == "Labeling" and self.rect is not None: + if system_code.data_mode == system_code.data_modes[1] and self.rect is not None: coordinates = [self.start_x, self.start_y, self.end_x, self.end_y] coordinates = self.subtract_image_from_canvas(coordinates) coordinates = self.multiply_array(coordinates, self.img_factor_x, self.img_factor_y) diff --git a/scripts/folder_mangement/CreateFolder.py b/scripts/folder_mangement/CreateFolder.py index 84138bf..9c8a8b7 100644 --- a/scripts/folder_mangement/CreateFolder.py +++ b/scripts/folder_mangement/CreateFolder.py @@ -29,7 +29,6 @@ class CreateFolder(Ctk.CTkFrame): self.create_new_data_folder() def create_folder(self): - self.enable_keybinding() self.create_folder_label = Ctk.CTkLabel(self, text="Type name for new Object:", width=100, font=self.my_font) self.create_folder_entry = Ctk.CTkEntry(self, placeholder_text="New Data Object", width=100, font=self.my_font) self.create_folder_name_btn = Ctk.CTkButton(self, text="Create", width=100, command=self.create_new_data_folder, font=self.my_font) diff --git a/scripts/folder_mangement/OpenFolder.py b/scripts/folder_mangement/OpenFolder.py index d4b902a..54eb05c 100644 --- a/scripts/folder_mangement/OpenFolder.py +++ b/scripts/folder_mangement/OpenFolder.py @@ -26,6 +26,16 @@ class OpenFolder(Ctk.CTkScrollableFrame): else: self.make_buttons() self.bind("", self.on_configure, '+') + + def enable_keybinding(self): + # this function has to be in all Functions but is only needed in + # some Classes + pass + + def disable_keybinding(self): + # this function has to be in all Functions but is only needed in + # some Classes + pass def on_configure(self, event=None): self.rearrange_buttons() diff --git a/scripts/folder_mangement/SwitchFolder.py b/scripts/folder_mangement/SwitchFolder.py index a38662f..70bef85 100644 --- a/scripts/folder_mangement/SwitchFolder.py +++ b/scripts/folder_mangement/SwitchFolder.py @@ -20,6 +20,14 @@ class SwitchFolder(Ctk.CTkFrame): self.img_paths = None self.create_selection() + + def enable_keybinding(self): + self.master.bind("", self.open_labeling, add="+") + + + def disable_keybinding(self): + self.master.unbind("") + # the selection part def create_selection(self): # input @@ -33,7 +41,7 @@ class SwitchFolder(Ctk.CTkFrame): self.error_label = Ctk.CTkLabel(self, text=self.error_txt, width=100, font=self.my_font) self.place_label_selection() - def open_labeling(self): + def open_labeling(self, value = None): source_path = self.input_entry.get() self.output_path = self.output_entry.get() if not os.path.exists(source_path):