mirror of
https://github.com/githubuser0xFFFF/Qt-Advanced-Docking-System.git
synced 2024-12-25 23:51:33 +08:00
Update PyQt bindings (#168)
* Fix include header in sidebar example * Update SIP files and Python examples Co-authored-by: K Lauer <klauer@users.noreply.github.com> Co-authored-by: K Lauer <klauer@users.noreply.github.com>
This commit is contained in:
parent
aa7976dac6
commit
4a8b5dd7ab
117
demo/demo.py
117
demo/demo.py
@ -7,7 +7,7 @@ from PyQt5 import uic
|
|||||||
from PyQt5.QtCore import (QCoreApplication, QDir, Qt, QSettings, QSignalBlocker,
|
from PyQt5.QtCore import (QCoreApplication, QDir, Qt, QSettings, QSignalBlocker,
|
||||||
QRect, QPoint, qDebug, qInstallMessageHandler,
|
QRect, QPoint, qDebug, qInstallMessageHandler,
|
||||||
QtDebugMsg, QtInfoMsg, QtWarningMsg,
|
QtDebugMsg, QtInfoMsg, QtWarningMsg,
|
||||||
QtCriticalMsg, QtFatalMsg)
|
QtCriticalMsg, QtFatalMsg, QSize)
|
||||||
from PyQt5.QtGui import (QGuiApplication, QIcon, QCloseEvent)
|
from PyQt5.QtGui import (QGuiApplication, QIcon, QCloseEvent)
|
||||||
from PyQt5.QtWidgets import (QCalendarWidget, QFileSystemModel, QFrame, QLabel,
|
from PyQt5.QtWidgets import (QCalendarWidget, QFileSystemModel, QFrame, QLabel,
|
||||||
QMenu, QTreeView, QAction, QWidgetAction,
|
QMenu, QTreeView, QAction, QWidgetAction,
|
||||||
@ -25,6 +25,7 @@ else:
|
|||||||
from PyQtAds import QtAds
|
from PyQtAds import QtAds
|
||||||
|
|
||||||
import rc # pyrcc5 demo.qrc -o rc.py
|
import rc # pyrcc5 demo.qrc -o rc.py
|
||||||
|
from status_dialog import CStatusDialog
|
||||||
|
|
||||||
UI_FILE = os.path.join(os.path.dirname(__file__), 'mainwindow.ui')
|
UI_FILE = os.path.join(os.path.dirname(__file__), 'mainwindow.ui')
|
||||||
MainWindowUI, MainWindowBase = uic.loadUiType(UI_FILE)
|
MainWindowUI, MainWindowBase = uic.loadUiType(UI_FILE)
|
||||||
@ -100,7 +101,12 @@ def create_calendar_dock_widget(view_menu: QMenu) -> QtAds.CDockWidget:
|
|||||||
|
|
||||||
dock_widget = QtAds.CDockWidget("Calendar {}".format(_State.calendar_count))
|
dock_widget = QtAds.CDockWidget("Calendar {}".format(_State.calendar_count))
|
||||||
_State.calendar_count += 1
|
_State.calendar_count += 1
|
||||||
|
# The following lines are for testing the setWidget() and takeWidget()
|
||||||
|
# functionality
|
||||||
dock_widget.setWidget(widget)
|
dock_widget.setWidget(widget)
|
||||||
|
dock_widget.setWidget(widget) # what happens if we set a widget if a widget is already set
|
||||||
|
dock_widget.takeWidget() # we remove the widget
|
||||||
|
dock_widget.setWidget(widget) # and set the widget again - there should be no error
|
||||||
dock_widget.setToggleViewActionMode(QtAds.CDockWidget.ActionModeShow)
|
dock_widget.setToggleViewActionMode(QtAds.CDockWidget.ActionModeShow)
|
||||||
dock_widget.setIcon(svg_icon(":/adsdemo/images/date_range.svg"))
|
dock_widget.setIcon(svg_icon(":/adsdemo/images/date_range.svg"))
|
||||||
view_menu.addAction(dock_widget.toggleViewAction())
|
view_menu.addAction(dock_widget.toggleViewAction())
|
||||||
@ -149,9 +155,15 @@ def create_editor_widget(view_menu: QMenu) -> QtAds.CDockWidget:
|
|||||||
|
|
||||||
return dock_widget
|
return dock_widget
|
||||||
|
|
||||||
|
class CMinSizeTableWidget(QTableWidget):
|
||||||
|
"""Custom QTableWidget with a minimum size hint to test CDockWidget
|
||||||
|
setMinimumSizeHintMode() function of CDockWidget"""
|
||||||
|
|
||||||
|
def minimumSizeHint(self) -> QSize:
|
||||||
|
return QSize(300, 100)
|
||||||
|
|
||||||
def create_table_widget(view_menu: QMenu) -> QtAds.CDockWidget:
|
def create_table_widget(view_menu: QMenu) -> QtAds.CDockWidget:
|
||||||
widget = QTableWidget()
|
widget = CMinSizeTableWidget()
|
||||||
dock_widget = QtAds.CDockWidget("Table {}".format(_State.table_count))
|
dock_widget = QtAds.CDockWidget("Table {}".format(_State.table_count))
|
||||||
_State.table_count += 1
|
_State.table_count += 1
|
||||||
COLCOUNT = 5
|
COLCOUNT = 5
|
||||||
@ -165,6 +177,15 @@ def create_table_widget(view_menu: QMenu) -> QtAds.CDockWidget:
|
|||||||
|
|
||||||
dock_widget.setWidget(widget)
|
dock_widget.setWidget(widget)
|
||||||
dock_widget.setIcon(svg_icon(":/adsdemo/images/grid_on.svg"))
|
dock_widget.setIcon(svg_icon(":/adsdemo/images/grid_on.svg"))
|
||||||
|
dock_widget.setMinimumSizeHintMode(QtAds.CDockWidget.MinimumSizeHintFromContent)
|
||||||
|
toolbar = dock_widget.createDefaultToolBar()
|
||||||
|
action = toolbar.addAction(svg_icon(":/adsdemo/images/fullscreen.svg"), "Toggle Fullscreen")
|
||||||
|
def on_toggle_fullscreen():
|
||||||
|
if dock_widget.isFullScreen():
|
||||||
|
dock_widget.showNormal()
|
||||||
|
else:
|
||||||
|
dock_widget.showFullScreen()
|
||||||
|
action.triggered.connect(on_toggle_fullscreen)
|
||||||
view_menu.addAction(dock_widget.toggleViewAction())
|
view_menu.addAction(dock_widget.toggleViewAction())
|
||||||
return dock_widget
|
return dock_widget
|
||||||
|
|
||||||
@ -179,7 +200,7 @@ if ACTIVEX_AVAILABLE:
|
|||||||
return dock_widget
|
return dock_widget
|
||||||
|
|
||||||
|
|
||||||
class CustomComponentsFactory(QtAds.CDockComponentsFactory):
|
class CCustomComponentsFactory(QtAds.CDockComponentsFactory):
|
||||||
|
|
||||||
def createDockAreaTitleBar(self, dock_area: QtAds.CDockAreaWidget) -> QtAds.CDockAreaTitleBar:
|
def createDockAreaTitleBar(self, dock_area: QtAds.CDockAreaWidget) -> QtAds.CDockAreaTitleBar:
|
||||||
title_bar = QtAds.CDockAreaTitleBar(dock_area)
|
title_bar = QtAds.CDockAreaTitleBar(dock_area)
|
||||||
@ -192,7 +213,6 @@ class CustomComponentsFactory(QtAds.CDockComponentsFactory):
|
|||||||
return title_bar
|
return title_bar
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class MainWindow(MainWindowUI, MainWindowBase):
|
class MainWindow(MainWindowUI, MainWindowBase):
|
||||||
save_perspective_action: QAction
|
save_perspective_action: QAction
|
||||||
perspective_list_action: QWidgetAction
|
perspective_list_action: QWidgetAction
|
||||||
@ -213,13 +233,39 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
# a QToolButton instead of a QPushButton
|
# a QToolButton instead of a QPushButton
|
||||||
# QtAds.CDockManager.setConfigFlags(QtAds.CDockManager.configFlags() | QtAds.CDockManager.TabCloseButtonIsToolButton)
|
# QtAds.CDockManager.setConfigFlags(QtAds.CDockManager.configFlags() | QtAds.CDockManager.TabCloseButtonIsToolButton)
|
||||||
|
|
||||||
|
# uncomment the following line if you want to use opaque undocking and
|
||||||
|
# opaque splitter resizing
|
||||||
|
#QtAds.CDockManager.setConfigFlags(QtAds.CDockManager.DefaultOpaqueConfig);
|
||||||
|
|
||||||
# uncomment the following line if you want a fixed tab width that does
|
# uncomment the following line if you want a fixed tab width that does
|
||||||
# not change if the visibility of the close button changes
|
# not change if the visibility of the close button changes
|
||||||
# QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.RetainTabSizeWhenCloseButtonHidden, True)
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.RetainTabSizeWhenCloseButtonHidden, True)
|
||||||
|
|
||||||
# uncomment the follwing line if you want to use non opaque undocking and splitter
|
# uncomment the following line if you don't want close button on DockArea's title bar
|
||||||
# movements
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.DockAreaHasCloseButton, false);
|
||||||
# QtAds.CDockManager.setConfigFlags(QtAds.CDockManager.DefaultNonOpaqueConfig)
|
|
||||||
|
# uncomment the following line if you don't want undock button on DockArea's title bar
|
||||||
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.DockAreaHasUndockButton, false);
|
||||||
|
|
||||||
|
# uncomment the following line if you don't want tabs menu button on DockArea's title bar
|
||||||
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.DockAreaHasTabsMenuButton, false);
|
||||||
|
|
||||||
|
# uncomment the following line if you don't want disabled buttons to appear on DockArea's title bar
|
||||||
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.DockAreaHideDisabledButtons, true);
|
||||||
|
|
||||||
|
# uncomment the following line if you want to show tabs menu button on DockArea's title bar only when there are more than one tab and at least of them has elided title
|
||||||
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.DockAreaDynamicTabsMenuButtonVisibility, true);
|
||||||
|
|
||||||
|
# uncomment the following line if you want floating container to always show application title instead of active dock widget's title
|
||||||
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.FloatingContainerHasWidgetTitle, false);
|
||||||
|
|
||||||
|
# uncomment the following line if you want floating container to show active dock widget's icon instead of always showing application icon
|
||||||
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.FloatingContainerHasWidgetIcon, true);
|
||||||
|
|
||||||
|
# uncomment the following line if you want a central widget in the main dock container (the dock manager) without a titlebar
|
||||||
|
# If you enable this code, you can test it in the demo with the Calendar 0
|
||||||
|
# dock widget.
|
||||||
|
#QtAds.CDockManager.setConfigFlag(QtAds.CDockManager.HideSingleCentralWidgetTitleBar, true);
|
||||||
|
|
||||||
# Now create the dock manager and its content
|
# Now create the dock manager and its content
|
||||||
self.dock_manager = QtAds.CDockManager(self)
|
self.dock_manager = QtAds.CDockManager(self)
|
||||||
@ -245,8 +291,6 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
view_menu = self.menuView
|
view_menu = self.menuView
|
||||||
dock_widget = create_calendar_dock_widget(view_menu)
|
dock_widget = create_calendar_dock_widget(view_menu)
|
||||||
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetClosable, False)
|
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetClosable, False)
|
||||||
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetMovable, False)
|
|
||||||
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetFloatable, False)
|
|
||||||
special_dock_area = self.dock_manager.addDockWidget(QtAds.LeftDockWidgetArea, dock_widget)
|
special_dock_area = self.dock_manager.addDockWidget(QtAds.LeftDockWidgetArea, dock_widget)
|
||||||
|
|
||||||
# For this Special Dock Area we want to avoid dropping on the center of it (i.e. we don't want this widget to be ever tabbified):
|
# For this Special Dock Area we want to avoid dropping on the center of it (i.e. we don't want this widget to be ever tabbified):
|
||||||
@ -271,18 +315,13 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
append_feature_string_to_window_title(file_system_widget)
|
append_feature_string_to_window_title(file_system_widget)
|
||||||
|
|
||||||
# Test custom factory - we inject a help button into the title bar
|
# Test custom factory - we inject a help button into the title bar
|
||||||
self.factory = CustomComponentsFactory()
|
QtAds.CDockComponentsFactory.setFactory(CCustomComponentsFactory())
|
||||||
QtAds.CDockComponentsFactory.setFactory(self.factory)
|
|
||||||
top_dock_area = self.dock_manager.addDockWidget(QtAds.TopDockWidgetArea, file_system_widget)
|
top_dock_area = self.dock_manager.addDockWidget(QtAds.TopDockWidgetArea, file_system_widget)
|
||||||
QtAds.CDockComponentsFactory.resetDefaultFactory()
|
QtAds.CDockComponentsFactory.resetDefaultFactory()
|
||||||
|
|
||||||
|
|
||||||
# We create a calendar widget and clear all flags to prevent the dock area
|
# We create a calendar widget and clear all flags to prevent the dock area
|
||||||
# from closing
|
# from closing
|
||||||
dock_widget = create_calendar_dock_widget(view_menu)
|
dock_widget = create_calendar_dock_widget(view_menu)
|
||||||
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetClosable, False)
|
|
||||||
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetMovable, False)
|
|
||||||
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetFloatable, False)
|
|
||||||
dock_widget.setTabToolTip("Tab ToolTip\nHodie est dies magna")
|
dock_widget.setTabToolTip("Tab ToolTip\nHodie est dies magna")
|
||||||
dock_area = self.dock_manager.addDockWidget(QtAds.CenterDockWidgetArea, dock_widget, top_dock_area)
|
dock_area = self.dock_manager.addDockWidget(QtAds.CenterDockWidgetArea, dock_widget, top_dock_area)
|
||||||
|
|
||||||
@ -292,6 +331,7 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
custom_button.setToolTip("Create Editor")
|
custom_button.setToolTip("Create Editor")
|
||||||
custom_button.setIcon(svg_icon(":/adsdemo/images/plus.svg"))
|
custom_button.setIcon(svg_icon(":/adsdemo/images/plus.svg"))
|
||||||
custom_button.setAutoRaise(True)
|
custom_button.setAutoRaise(True)
|
||||||
|
|
||||||
title_bar = dock_area.titleBar()
|
title_bar = dock_area.titleBar()
|
||||||
index = title_bar.indexOf(title_bar.tabBar())
|
index = title_bar.indexOf(title_bar.tabBar())
|
||||||
title_bar.insertWidget(index + 1, custom_button)
|
title_bar.insertWidget(index + 1, custom_button)
|
||||||
@ -321,8 +361,13 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
QtAds.CenterDockWidgetArea,
|
QtAds.CenterDockWidgetArea,
|
||||||
create_long_text_label_dock_widget(view_menu), bottom_dock_area)
|
create_long_text_label_dock_widget(view_menu), bottom_dock_area)
|
||||||
|
|
||||||
action = self.menuView.addAction("Set {} floating".format(dock_widget.windowTitle()))
|
|
||||||
|
action = self.menuTests.addAction("Set {} Floating".format(dock_widget.windowTitle()))
|
||||||
action.triggered.connect(dock_widget.setFloating)
|
action.triggered.connect(dock_widget.setFloating)
|
||||||
|
action = self.menuTests.addAction("Set {} As Current Tab".format(dock_widget.windowTitle()))
|
||||||
|
action.triggered.connect(dock_widget.setAsCurrentTab)
|
||||||
|
action = self.menuTests.addAction("Raise {}".format(dock_widget.windowTitle()))
|
||||||
|
action.triggered.connect(dock_widget.raise_)
|
||||||
|
|
||||||
if ACTIVEX_AVAILABLE:
|
if ACTIVEX_AVAILABLE:
|
||||||
flags = self.dock_manager.configFlags()
|
flags = self.dock_manager.configFlags()
|
||||||
@ -353,25 +398,40 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
self.toolBar.addAction(self.perspective_list_action)
|
self.toolBar.addAction(self.perspective_list_action)
|
||||||
self.toolBar.addAction(self.save_perspective_action)
|
self.toolBar.addAction(self.save_perspective_action)
|
||||||
|
|
||||||
a = self.toolBar.addAction("Create Editor")
|
a = self.toolBar.addAction("Create Floating Editor")
|
||||||
|
a.setProperty("Floating", True)
|
||||||
a.setToolTip("Creates floating dynamic dockable editor windows that are deleted on close")
|
a.setToolTip("Creates floating dynamic dockable editor windows that are deleted on close")
|
||||||
a.setIcon(svg_icon(":/adsdemo/images/note_add.svg"))
|
a.setIcon(svg_icon(":/adsdemo/images/note_add.svg"))
|
||||||
a.triggered.connect(self.create_editor)
|
a.triggered.connect(self.create_editor)
|
||||||
|
self.menuTests.addAction(a)
|
||||||
|
|
||||||
a = self.toolBar.addAction("Create Table")
|
a = self.toolBar.addAction("Create Docked Editor")
|
||||||
|
a.setProperty("Floating", False)
|
||||||
|
a.setToolTip("Creates a docked editor windows that are deleted on close")
|
||||||
|
a.setIcon(svg_icon(":/adsdemo/images/docked_editor.svg"))
|
||||||
|
a.triggered.connect(self.create_editor)
|
||||||
|
self.menuTests.addAction(a)
|
||||||
|
|
||||||
|
a = self.toolBar.addAction("Create Floating Table")
|
||||||
a.setToolTip("Creates floating dynamic dockable table with millions of entries")
|
a.setToolTip("Creates floating dynamic dockable table with millions of entries")
|
||||||
a.setIcon(svg_icon(":/adsdemo/images/grid_on.svg"))
|
a.setIcon(svg_icon(":/adsdemo/images/grid_on.svg"))
|
||||||
a.triggered.connect(self.create_table)
|
a.triggered.connect(self.create_table)
|
||||||
|
self.menuTests.addAction(a)
|
||||||
|
|
||||||
|
self.menuTests.addSeparator()
|
||||||
|
a = self.menuTests.addAction("Show Status Dialog")
|
||||||
|
a.triggered.connect(self.show_status_dialog)
|
||||||
|
self.menuTests.addSeparator()
|
||||||
|
|
||||||
def closeEvent(self, event: QCloseEvent):
|
def closeEvent(self, event: QCloseEvent):
|
||||||
self.save_state()
|
self.save_state()
|
||||||
super().closeEvent(event)
|
super().closeEvent(event)
|
||||||
|
|
||||||
def on_action_save_state_triggered(state: bool):
|
def on_actionSaveState_triggered(self, state: bool):
|
||||||
qDebug("MainWindow::on_action_save_state_triggered")
|
qDebug("MainWindow::on_action_save_state_triggered")
|
||||||
self.save_state()
|
self.save_state()
|
||||||
|
|
||||||
def on_action_restore_state_triggered(state: bool):
|
def on_actionRestoreState_triggered(self, state: bool):
|
||||||
qDebug("MainWindow::on_action_restore_state_triggered")
|
qDebug("MainWindow::on_action_restore_state_triggered")
|
||||||
self.restore_state()
|
self.restore_state()
|
||||||
|
|
||||||
@ -403,12 +463,19 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
qDebug("{} visibility_changed({})".format(dock_widget.objectName(), visible))
|
qDebug("{} visibility_changed({})".format(dock_widget.objectName(), visible))
|
||||||
|
|
||||||
def create_editor(self):
|
def create_editor(self):
|
||||||
|
sender = self.sender()
|
||||||
|
floating = sender.property("Floating")
|
||||||
|
print("Floating:", floating)
|
||||||
dock_widget = create_editor_widget(self.menuView)
|
dock_widget = create_editor_widget(self.menuView)
|
||||||
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetDeleteOnClose, True)
|
dock_widget.setFeature(QtAds.CDockWidget.DockWidgetDeleteOnClose, True)
|
||||||
floating_widget = self.dock_manager.addDockWidgetFloating(dock_widget)
|
|
||||||
floating_widget.move(QPoint(20, 20))
|
|
||||||
dock_widget.closeRequested.connect(self.on_editor_close_requested)
|
dock_widget.closeRequested.connect(self.on_editor_close_requested)
|
||||||
|
|
||||||
|
if floating:
|
||||||
|
floating_widget = self.dock_manager.addDockWidgetFloating(dock_widget)
|
||||||
|
floating_widget.move(QPoint(20, 20))
|
||||||
|
else:
|
||||||
|
self.dock_manager.addDockWidget(QtAds.TopDockWidgetArea, dock_widget)
|
||||||
|
|
||||||
def on_editor_close_requested(self):
|
def on_editor_close_requested(self):
|
||||||
dock_widget = self.sender()
|
dock_widget = self.sender()
|
||||||
result = QMessageBox.question(self, "Close Editor",
|
result = QMessageBox.question(self, "Close Editor",
|
||||||
@ -422,6 +489,10 @@ class MainWindow(MainWindowUI, MainWindowBase):
|
|||||||
floating_widget = self.dock_manager.addDockWidgetFloating(dock_widget)
|
floating_widget = self.dock_manager.addDockWidgetFloating(dock_widget)
|
||||||
floating_widget.move(QPoint(40, 40))
|
floating_widget.move(QPoint(40, 40))
|
||||||
|
|
||||||
|
def show_status_dialog(self):
|
||||||
|
dialog = CStatusDialog(self.dock_manager)
|
||||||
|
dialog.exec_()
|
||||||
|
|
||||||
def save_state(self):
|
def save_state(self):
|
||||||
'''
|
'''
|
||||||
Saves the dock manager state and the main window geometry
|
Saves the dock manager state and the main window geometry
|
||||||
|
38
demo/status_dialog.py
Normal file
38
demo/status_dialog.py
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import os
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from PyQt5 import uic
|
||||||
|
from PyQtAds import QtAds
|
||||||
|
|
||||||
|
UI_FILE = os.path.join(os.path.dirname(__file__), 'StatusDialog.ui')
|
||||||
|
StatusDialogUI, StatusDialogBase = uic.loadUiType(UI_FILE)
|
||||||
|
|
||||||
|
class CStatusDialog(StatusDialogUI, StatusDialogBase):
|
||||||
|
|
||||||
|
def __init__(self, dock_manager: QtAds.CDockManager, parent=None):
|
||||||
|
super().__init__(parent)
|
||||||
|
|
||||||
|
self.setupUi(self)
|
||||||
|
|
||||||
|
self.dock_manager = dock_manager
|
||||||
|
self.dock_widgets = self.dock_manager.dockWidgetsMap()
|
||||||
|
|
||||||
|
for key, widget in self.dock_widgets.items():
|
||||||
|
self.dockWidgetsComboBox.addItem(key, widget)
|
||||||
|
|
||||||
|
def on_dockWidgetsComboBox_currentIndexChanged(self, index: int):
|
||||||
|
if not isinstance(index, int):
|
||||||
|
return
|
||||||
|
if index < 0:
|
||||||
|
return
|
||||||
|
|
||||||
|
dock_widget = self.dockWidgetsComboBox.currentData()
|
||||||
|
self.isClosedCheckBox.setChecked(dock_widget.isClosed())
|
||||||
|
self.isFloatingCheckBox.setChecked(dock_widget.isFloating())
|
||||||
|
self.tabbedCheckBox.setChecked(dock_widget.isTabbed())
|
||||||
|
self.isCurrentTabCheckBox.setChecked(dock_widget.isCurrentTab())
|
||||||
|
self.closableCheckBox.setChecked(dock_widget.features() & QtAds.CDockWidget.DockWidgetClosable)
|
||||||
|
self.movableCheckBox.setChecked(dock_widget.features() & QtAds.CDockWidget.DockWidgetMovable)
|
||||||
|
self.floatableCheckBox.setChecked(dock_widget.features() & QtAds.CDockWidget.DockWidgetFloatable)
|
||||||
|
self.deleteOnCloseCheckBox.setChecked(dock_widget.features() & QtAds.CDockWidget.DockWidgetDeleteOnClose)
|
||||||
|
self.customCloseHandlingCheckBox.setChecked(dock_widget.features() & QtAds.CDockWidget.CustomCloseHandling)
|
@ -1,4 +1,4 @@
|
|||||||
#include "../../examples/simple/MainWindow.h"
|
#include "MainWindow.h"
|
||||||
|
|
||||||
#include "ui_MainWindow.h"
|
#include "ui_MainWindow.h"
|
||||||
|
|
||||||
|
60
examples/sidebar/sidebar.py
Normal file
60
examples/sidebar/sidebar.py
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
import os
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from PyQt5 import uic
|
||||||
|
from PyQt5.QtCore import Qt, QMargins
|
||||||
|
from PyQt5.QtWidgets import QApplication, QLabel, QVBoxLayout, QPlainTextEdit
|
||||||
|
|
||||||
|
from PyQtAds import QtAds
|
||||||
|
|
||||||
|
UI_FILE = os.path.join(os.path.dirname(__file__), 'MainWindow.ui')
|
||||||
|
MainWindowUI, MainWindowBase = uic.loadUiType(UI_FILE)
|
||||||
|
|
||||||
|
|
||||||
|
class MainWindow(MainWindowUI, MainWindowBase):
|
||||||
|
|
||||||
|
def __init__(self, parent=None):
|
||||||
|
super().__init__(parent)
|
||||||
|
|
||||||
|
self.setupUi(self)
|
||||||
|
|
||||||
|
# Create the dock manager. Because the parent parameter is a QMainWindow
|
||||||
|
# the dock manager registers itself as the central widget.
|
||||||
|
layout = QVBoxLayout(self.dockContainer);
|
||||||
|
layout.setContentsMargins(QMargins(0, 0, 0, 0))
|
||||||
|
self.dock_manager = QtAds.CDockManager(self.dockContainer)
|
||||||
|
layout.addWidget(self.dock_manager)
|
||||||
|
|
||||||
|
# Create example content label - this can be any application specific
|
||||||
|
# widget
|
||||||
|
l = QLabel()
|
||||||
|
l.setWordWrap(True)
|
||||||
|
l.setAlignment(Qt.AlignTop | Qt.AlignLeft);
|
||||||
|
l.setText("Lorem ipsum dolor sit amet, consectetuer adipiscing elit. ")
|
||||||
|
|
||||||
|
# Create a dock widget with the title Label 1 and set the created label
|
||||||
|
# as the dock widget content
|
||||||
|
dock_widget = QtAds.CDockWidget("Label 1")
|
||||||
|
dock_widget.setWidget(l)
|
||||||
|
|
||||||
|
# Add the toggleViewAction of the dock widget to the menu to give
|
||||||
|
# the user the possibility to show the dock widget if it has been closed
|
||||||
|
self.menuView.addAction(dock_widget.toggleViewAction())
|
||||||
|
|
||||||
|
# Add the dock widget to the top dock widget area
|
||||||
|
self.dock_manager.addDockWidget(QtAds.TopDockWidgetArea, dock_widget)
|
||||||
|
|
||||||
|
# Create an example editor
|
||||||
|
te = QPlainTextEdit()
|
||||||
|
te.setPlaceholderText("Please enter your text here into this QPlainTextEdit...")
|
||||||
|
dock_widget = QtAds.CDockWidget("Editor 1")
|
||||||
|
self.menuView.addAction(dock_widget.toggleViewAction())
|
||||||
|
self.dock_manager.addDockWidget(QtAds.BottomDockWidgetArea, dock_widget)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
app = QApplication(sys.argv)
|
||||||
|
|
||||||
|
w = MainWindow()
|
||||||
|
w.show()
|
||||||
|
app.exec_()
|
@ -1,5 +1,3 @@
|
|||||||
import datetime
|
|
||||||
import logging
|
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
35
setup.py
35
setup.py
@ -1,6 +1,7 @@
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import shlex
|
import shlex
|
||||||
|
import shutil
|
||||||
import subprocess
|
import subprocess
|
||||||
import glob
|
import glob
|
||||||
|
|
||||||
@ -141,7 +142,23 @@ class build_ext(sipdistutils.build_ext):
|
|||||||
|
|
||||||
def _find_sip(self):
|
def _find_sip(self):
|
||||||
"""override _find_sip to allow for manually speficied sip path."""
|
"""override _find_sip to allow for manually speficied sip path."""
|
||||||
return self.sip_bin or super()._find_sip()
|
|
||||||
|
# 1. Manually specified sip_bin
|
||||||
|
if self.sip_bin:
|
||||||
|
return self.sip_bin
|
||||||
|
|
||||||
|
# 2. Path determined from sipconfig.Configuration()
|
||||||
|
# This may not exist, depending on conda build configuration.
|
||||||
|
sip_bin = super()._find_sip()
|
||||||
|
if os.path.exists(sip_bin):
|
||||||
|
return sip_bin
|
||||||
|
|
||||||
|
# 3. Finally, fall back to sip binary found in path
|
||||||
|
sip_bin = shutil.which('sip')
|
||||||
|
if sip_bin:
|
||||||
|
return sip_bin
|
||||||
|
|
||||||
|
raise SystemExit('Could not find PyQt SIP binary.')
|
||||||
|
|
||||||
def _sip_compile(self, sip_bin, source, sbf):
|
def _sip_compile(self, sip_bin, source, sbf):
|
||||||
cmd = [sip_bin]
|
cmd = [sip_bin]
|
||||||
@ -194,6 +211,8 @@ class build_ext(sipdistutils.build_ext):
|
|||||||
return super().swig_sources(sources, extension)
|
return super().swig_sources(sources, extension)
|
||||||
|
|
||||||
def build_extension(self, ext):
|
def build_extension(self, ext):
|
||||||
|
# /usr/bin/rcc -name ads ../../Qt-Advanced-Docking-System/src/ads.qrc -o release/qrc_ads.cpp
|
||||||
|
|
||||||
cppsources = [source for source in ext.sources if source.endswith(".cpp")]
|
cppsources = [source for source in ext.sources if source.endswith(".cpp")]
|
||||||
|
|
||||||
dir_util.mkpath(self.build_temp, dry_run=self.dry_run)
|
dir_util.mkpath(self.build_temp, dry_run=self.dry_run)
|
||||||
@ -232,6 +251,17 @@ class build_ext(sipdistutils.build_ext):
|
|||||||
# the created .moc files
|
# the created .moc files
|
||||||
ext.include_dirs += [self._sip_output_dir()]
|
ext.include_dirs += [self._sip_output_dir()]
|
||||||
|
|
||||||
|
# Run rcc on all resource files
|
||||||
|
resources = [source for source in ext.sources if source.endswith(".qrc")]
|
||||||
|
for source in resources:
|
||||||
|
ext.sources.remove(source)
|
||||||
|
out_file = os.path.join(self.build_temp, "qrc_" + os.path.basename(source).replace(".qrc", ".cpp"))
|
||||||
|
if newer(header, out_file) or self.force:
|
||||||
|
spawn.spawn(["rcc", "-name", os.path.splitext(os.path.basename(source))[0], source, "-o", out_file], dry_run=self.dry_run)
|
||||||
|
|
||||||
|
if os.path.getsize(out_file) > 0:
|
||||||
|
ext.sources.append(out_file)
|
||||||
|
|
||||||
sipdistutils.build_ext.build_extension(self, ext)
|
sipdistutils.build_ext.build_extension(self, ext)
|
||||||
|
|
||||||
|
|
||||||
@ -262,9 +292,10 @@ class BuildPyCommand(build_py):
|
|||||||
setup_requires = ["PyQt5"] if REQUIRE_PYQT else []
|
setup_requires = ["PyQt5"] if REQUIRE_PYQT else []
|
||||||
cpp_sources = glob.glob(os.path.join('src', '*.cpp'))
|
cpp_sources = glob.glob(os.path.join('src', '*.cpp'))
|
||||||
sip_sources = [os.path.join('sip', MODULE_NAME + '.sip')]
|
sip_sources = [os.path.join('sip', MODULE_NAME + '.sip')]
|
||||||
|
resources = [os.path.join('src', MODULE_NAME + '.qrc')]
|
||||||
if sys.platform == 'linux':
|
if sys.platform == 'linux':
|
||||||
cpp_sources += glob.glob(os.path.join('src', 'linux', '*.cpp'))
|
cpp_sources += glob.glob(os.path.join('src', 'linux', '*.cpp'))
|
||||||
ext_modules = [Extension('PyQtAds.QtAds.ads', cpp_sources + sip_sources)]
|
ext_modules = [Extension('PyQtAds.QtAds.ads', cpp_sources + sip_sources + resources)]
|
||||||
|
|
||||||
install_requires = ["PyQt5"]
|
install_requires = ["PyQt5"]
|
||||||
if sys.platform == 'win32':
|
if sys.platform == 'win32':
|
||||||
|
@ -16,7 +16,7 @@ public:
|
|||||||
virtual CDockAreaTabBar* createDockAreaTabBar(CDockAreaWidget* DockArea /Transfer/ ) const;
|
virtual CDockAreaTabBar* createDockAreaTabBar(CDockAreaWidget* DockArea /Transfer/ ) const;
|
||||||
virtual CDockAreaTitleBar* createDockAreaTitleBar(CDockAreaWidget* DockArea /Transfer/ ) const;
|
virtual CDockAreaTitleBar* createDockAreaTitleBar(CDockAreaWidget* DockArea /Transfer/ ) const;
|
||||||
static const CDockComponentsFactory* factory();
|
static const CDockComponentsFactory* factory();
|
||||||
static void setFactory(CDockComponentsFactory* Factory);
|
static void setFactory(CDockComponentsFactory* Factory /KeepReference/);
|
||||||
static void resetDefaultFactory();
|
static void resetDefaultFactory();
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -165,12 +165,12 @@ public:
|
|||||||
DockAreaDynamicTabsMenuButtonVisibility,
|
DockAreaDynamicTabsMenuButtonVisibility,
|
||||||
FloatingContainerHasWidgetTitle,
|
FloatingContainerHasWidgetTitle,
|
||||||
FloatingContainerHasWidgetIcon,
|
FloatingContainerHasWidgetIcon,
|
||||||
|
HideSingleCentralWidgetTitleBar,
|
||||||
DefaultDockAreaButtons,
|
DefaultDockAreaButtons,
|
||||||
DefaultBaseConfig,
|
DefaultBaseConfig,
|
||||||
DefaultOpaqueConfig,
|
DefaultOpaqueConfig,
|
||||||
DefaultNonOpaqueConfig,
|
DefaultNonOpaqueConfig,
|
||||||
NonOpaqueWithWindowFrame,
|
NonOpaqueWithWindowFrame,
|
||||||
HideSingleCentralWidgetTitleBar,
|
|
||||||
};
|
};
|
||||||
typedef QFlags<ads::CDockManager::eConfigFlag> ConfigFlags;
|
typedef QFlags<ads::CDockManager::eConfigFlag> ConfigFlags;
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ public:
|
|||||||
bool isTitleElided() const;
|
bool isTitleElided() const;
|
||||||
bool isClosable() const;
|
bool isClosable() const;
|
||||||
virtual bool event(QEvent *e);
|
virtual bool event(QEvent *e);
|
||||||
|
void setElideMode(Qt::TextElideMode mode);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
virtual void setVisible(bool visible);
|
virtual void setVisible(bool visible);
|
||||||
|
@ -10,7 +10,7 @@ namespace ads
|
|||||||
|
|
||||||
enum eStateFileVersion
|
enum eStateFileVersion
|
||||||
{
|
{
|
||||||
InitialVerison,
|
InitialVersion,
|
||||||
Version1,
|
Version1,
|
||||||
CurrentVersion
|
CurrentVersion
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user