From 617ee30650c7a80f69b88c468e2db61f66e03e1b Mon Sep 17 00:00:00 2001 From: Michael Otto Date: Mon, 17 Nov 2025 12:23:04 +0100 Subject: [PATCH] =?UTF-8?q?Men=C3=BC=20und=20Symbolleiste=20=C3=BCberarbei?= =?UTF-8?q?tet.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ui/base_dockwidget.py | 11 +++++++++-- ui/navigation.py | 40 ++++++++++++++++++++++++++++------------ 2 files changed, 37 insertions(+), 14 deletions(-) diff --git a/ui/base_dockwidget.py b/ui/base_dockwidget.py index 904715b..4184b6d 100644 --- a/ui/base_dockwidget.py +++ b/ui/base_dockwidget.py @@ -3,6 +3,7 @@ from qgis.PyQt.QtWidgets import QDockWidget, QTabWidget class BaseDockWidget(QDockWidget): base_title = "LNO Sachsen" tabs = [] + action = None # Referenz auf die Toolbar-Action def __init__(self, parent=None, subtitle=""): super().__init__(parent) @@ -11,11 +12,17 @@ class BaseDockWidget(QDockWidget): title = self.base_title if not subtitle else f"{self.base_title} | {subtitle}" self.setWindowTitle(title) - # Dock fixieren (Nur schließen erlaubt) + # Dock fixieren (nur schließen erlaubt) self.setFeatures(QDockWidget.DockWidgetFeature.DockWidgetClosable) - + # Tabs hinzufügen tab_widget = QTabWidget() for tab_class in self.tabs: tab_widget.addTab(tab_class(), getattr(tab_class, "tab_title", tab_class.__name__)) self.setWidget(tab_widget) + + def closeEvent(self, event): + """Wird aufgerufen, wenn das Dock geschlossen wird.""" + if self.action: + self.action.setChecked(False) # Toolbar-Button zurücksetzen + super().closeEvent(event) diff --git a/ui/navigation.py b/ui/navigation.py index f59ca70..9e8ceef 100644 --- a/ui/navigation.py +++ b/ui/navigation.py @@ -1,10 +1,10 @@ -from qgis.PyQt.QtWidgets import QAction, QMenu, QToolBar +from qgis.PyQt.QtWidgets import QAction, QMenu, QToolBar, QActionGroup class Navigation: def __init__(self, iface): self.iface = iface self.actions = [] - + # Menü und Toolbar einmalig anlegen self.menu = QMenu("LNO Sachsen", iface.mainWindow()) iface.mainWindow().menuBar().addMenu(self.menu) @@ -12,23 +12,39 @@ class Navigation: self.toolbar = QToolBar("LNO Sachsen") iface.addToolBar(self.toolbar) - def add_action(self, text, callback, tooltip="", priority=100, icon=None): + # Gruppe für exklusive Auswahl (nur ein Plugin aktiv) + self.plugin_group = QActionGroup(iface.mainWindow()) + self.plugin_group.setExclusive(True) + + def add_action(self, text, callback, tooltip="", priority=100): action = QAction(text, self.iface.mainWindow()) - if icon: - action.setIcon(icon) - if tooltip: - action.setToolTip(tooltip) + action.setToolTip(tooltip) + action.setCheckable(True) # Button kann aktiv sein action.triggered.connect(callback) + # Action in Gruppe aufnehmen + self.plugin_group.addAction(action) + + # Action mit Priority speichern self.actions.append((priority, action)) return action def finalize_menu_and_toolbar(self): - # Menü und Toolbar leeren - self.menu.clear() - self.toolbar.clear() + # Sortieren nach Priority + self.actions.sort(key=lambda x: x[0]) - # Sortiert nach Priority einfügen - for _, action in sorted(self.actions, key=lambda x: x[0]): + # Menüeinträge + self.menu.clear() + for _, action in self.actions: self.menu.addAction(action) + + # Toolbar-Einträge + self.toolbar.clear() + for _, action in self.actions: self.toolbar.addAction(action) + + def set_active_plugin(self, active_action): + # Alle zurücksetzen, dann aktives Plugin markieren + for _, action in self.actions: + action.setChecked(False) + active_action.setChecked(True)