From df4ca1cb2afef4b82a80270bd62e72b0f7d021fa Mon Sep 17 00:00:00 2001 From: Christian Heller <c.heller@plomlompom.de> Date: Mon, 9 Sep 2024 13:53:00 +0200 Subject: [PATCH] Fixe sidebar toggling not properly re-sizing slot sizes. --- browser.py | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/browser.py b/browser.py index a6f864b..8835353 100755 --- a/browser.py +++ b/browser.py @@ -193,6 +193,7 @@ class MainWindow(Gtk.Window): self.img_dir_absolute = abspath(IMG_DIR) self.block_once_hit_file_selection = False self.block_file_selection_updates = False + self.force_width = None viewer = Gtk.Box(orientation=OR_V) viewer.append(init_navbar()) @@ -284,10 +285,11 @@ class MainWindow(Gtk.Window): """Load/unload gallery's file images based on viewport visibility.""" self.gallery.set_min_children_per_line(self.per_row) self.gallery.set_max_children_per_line(self.per_row) - viewport = self.gallery.get_parent().get_parent() - vp_height = viewport.get_height() - vp_width = viewport.get_width() - vp_scroll = viewport.get_vadjustment() + vp = self.gallery.get_parent().get_parent() + vp_height = vp.get_height() + # because sometimes vp.width updates too late for our measurements + vp_width = self.force_width if self.force_width else vp.get_width() + vp_scroll = vp.get_vadjustment() vp_top = vp_scroll.get_value() vp_bottom = vp_top + vp_height margin = 6 @@ -301,8 +303,8 @@ class MainWindow(Gtk.Window): continue slot_top = (i // self.per_row) * (slot_size + margin) slot_bottom = slot_top + slot_size - in_viewport = (slot_bottom >= vp_top and slot_top <= vp_bottom) - if in_viewport: + in_vp = (slot_bottom >= vp_top and slot_top <= vp_bottom) + if in_vp: if not isinstance(slot.content, Gtk.Image): slot.remove(slot.content) slot.content = Gtk.Image.new_from_file(slot.item.full_path) @@ -312,6 +314,7 @@ class MainWindow(Gtk.Window): slot.content = Gtk.Label(label='?') slot.append(slot.content) slot.content.set_size_request(slot_size, slot_size) + # because for some reason vp.scroll_to doesn't do what we want if refocus: for c in self.gallery.get_selected_children(): for i in range(self.gallery_store_filtered.get_n_items()): @@ -443,7 +446,10 @@ class MainWindow(Gtk.Window): def toggle_side_box(self): """Toggle window sidebox visible/invisible.""" self.side_box.props.visible = not self.side_box.get_visible() - self.update_gallery_view() + side_box_width = self.side_box.measure(OR_H, -1).natural + # because relevant viewport measurement happens too late for our needs + self.force_width = self.get_width() - side_box_width + self.update_gallery_view(refocus=True) def reset_include_dirs(self, button): """By button's .active, in-/exclude directories from gallery view.""" -- 2.30.2