File indexing completed on 2024-09-15 12:04:29
0001 /* 0002 This file is part of the KDE libraries 0003 SPDX-FileCopyrightText: 2000 Reginald Stadlbauer <reggie@kde.org> 0004 SPDX-FileCopyrightText: 1997, 1998 Stephan Kulow <coolo@kde.org> 0005 SPDX-FileCopyrightText: 1997, 1998 Sven Radej <radej@kde.org> 0006 SPDX-FileCopyrightText: 1997, 1998 Mark Donohoe <donohoe@kde.org> 0007 SPDX-FileCopyrightText: 1997, 1998 Matthias Ettrich <ettrich@kde.org> 0008 SPDX-FileCopyrightText: 1999, 2000 Kurt Granroth <granroth@kde.org> 0009 SPDX-FileCopyrightText: 2005-2006 Hamish Rodda <rodda@kde.org> 0010 0011 SPDX-License-Identifier: LGPL-2.0-only 0012 */ 0013 0014 #ifndef KTOOLBAR_H 0015 #define KTOOLBAR_H 0016 0017 #include <kxmlgui_export.h> 0018 0019 #include <QToolBar> 0020 #include <memory> 0021 0022 class QDomElement; 0023 0024 class KConfigGroup; 0025 class KConfig; 0026 class KMainWindow; 0027 class KXMLGUIClient; 0028 0029 /** 0030 * @class KToolBar ktoolbar.h KToolBar 0031 * 0032 * @short Floatable toolbar with auto resize. 0033 * 0034 * A KDE-style toolbar. 0035 * 0036 * KToolBar can be used as a standalone widget, but KMainWindow 0037 * provides easy factories and management of one or more toolbars. 0038 * 0039 * KToolBar uses a global config group to load toolbar settings on 0040 * construction. It will reread this config group on a 0041 * KApplication::appearanceChanged() signal. 0042 * 0043 * KToolBar respects Kiosk settings (see the KAuthorized namespace in the 0044 * KConfig framework). In particular, system administrators can prevent users 0045 * from moving toolbars with the "movable_toolbars" action, and from showing or 0046 * hiding toolbars with the "options_show_toolbar" action. For example, to 0047 * disable both, add the following the application or global configuration: 0048 * @verbatim 0049 [KDE Action Restrictions][$i] 0050 movable_toolbars=false 0051 options_show_toolbar=false 0052 @endverbatim 0053 * 0054 * If you can't depend on KXmlGui but still want to integrate better with KDE, 0055 * you can use QToolBar and: 0056 * - Set ToolButtonStyle to Qt::ToolButtonFollowStyle, this will make QToolBar 0057 * use the settings for "Main Toolbar" 0058 * - Additionally set QToolBar::setProperty("otherToolbar", true) to use settings 0059 * for "Other toolbars"; settings from "Other toolbars" will only work on widget 0060 * styles derived from KStyle 0061 * 0062 * @author Reginald Stadlbauer <reggie@kde.org> 0063 * @author Stephan Kulow <coolo@kde.org> 0064 * @author Sven Radej <radej@kde.org> 0065 * @author Hamish Rodda <rodda@kde.org> 0066 */ 0067 class KXMLGUI_EXPORT KToolBar : public QToolBar 0068 { 0069 Q_OBJECT 0070 0071 public: 0072 /** 0073 * Constructor. 0074 * 0075 * This constructor takes care of adding the toolbar to the mainwindow, 0076 * if @p parent is a QMainWindow. 0077 * 0078 * Normally KDE applications do not call this directly, they either 0079 * call KMainWindow::toolBar(), or they use XML-GUI and specify 0080 * toolbars using XML. 0081 * 0082 * @param parent The standard toolbar parent (usually a KMainWindow) 0083 * @param isMainToolBar True for the "main toolbar", false for other toolbars. Different settings apply. 0084 * @param readConfig whether to apply the configuration (global and application-specific) 0085 */ 0086 explicit KToolBar(QWidget *parent, bool isMainToolBar = false, bool readConfig = true); 0087 // KDE5: remove. The one below is preferred so that all debug output from init() shows the right objectName already, 0088 // and so that isMainToolBar() and iconSizeDefault() return correct values during loading too. 0089 0090 /** 0091 * Constructor. 0092 * 0093 * This constructor takes care of adding the toolbar to the mainwindow, 0094 * if @p parent is a QMainWindow. 0095 * 0096 * Normally KDE applications do not call this directly, they either 0097 * call KMainWindow::toolBar(), or they use XML-GUI and specify 0098 * toolbars using XML. 0099 * 0100 * @param objectName The QObject name of this toolbar, required so that QMainWindow can save and load the toolbar position, 0101 * and so that KToolBar can find out if it's the main toolbar. 0102 * @param parent The standard toolbar parent (usually a KMainWindow) 0103 * @param readConfig whether to apply the configuration (global and application-specific) 0104 */ 0105 explicit KToolBar(const QString &objectName, QWidget *parent, bool readConfig = true); 0106 0107 /** 0108 * Alternate constructor with additional arguments, e.g. to choose in which area 0109 * the toolbar should be auto-added. This is rarely used in KDE. When using XMLGUI 0110 * you can specify this as an xml attribute instead. 0111 * 0112 * @param objectName The QObject name of this toolbar, required so that QMainWindow can save and load the toolbar position 0113 * @param parentWindow The window that should be the parent of this toolbar 0114 * @param area The position of the toolbar. Usually Qt::TopToolBarArea. 0115 * @param newLine If true, start a new line in the dock for this toolbar. 0116 * @param isMainToolBar True for the "main toolbar", false for other toolbars. Different settings apply. 0117 * @param readConfig whether to apply the configuration (global and application-specific) 0118 */ 0119 KToolBar(const QString &objectName, 0120 QMainWindow *parentWindow, 0121 Qt::ToolBarArea area, 0122 bool newLine = false, 0123 bool isMainToolBar = false, 0124 bool readConfig = true); // KDE5: remove, I don't think anyone is using this. 0125 0126 /** 0127 * Destroys the toolbar. 0128 */ 0129 ~KToolBar() override; 0130 0131 /** 0132 * Returns the main window that this toolbar is docked with. 0133 */ 0134 KMainWindow *mainWindow() const; 0135 0136 /** 0137 * Convenience function to set icon size 0138 */ 0139 void setIconDimensions(int size); 0140 0141 /** 0142 * Returns the default size for this type of toolbar. 0143 * 0144 * @return the default size for this type of toolbar. 0145 */ 0146 int iconSizeDefault() const; // KDE5: hide from public API. Doesn't make sense to export this, and it isn't used. 0147 0148 #if KXMLGUI_ENABLE_DEPRECATED_SINCE(5, 0) 0149 /** 0150 * This allows you to enable or disable the context menu. 0151 * 0152 * @param enable If false, then the context menu will be disabled 0153 * @deprecated Since 5.0, use setContextMenuPolicy() 0154 */ 0155 KXMLGUI_DEPRECATED_VERSION(5, 0, "Use QWidget::setContextMenuPolicy(Qt::ContextMenuPolicy)") 0156 void setContextMenuEnabled(bool enable = true); 0157 #endif 0158 0159 #if KXMLGUI_ENABLE_DEPRECATED_SINCE(5, 0) 0160 /** 0161 * Returns the context menu enabled flag 0162 * @return true if the context menu is disabled 0163 * @deprecated Since 5.0, use contextMenuPolicy() 0164 */ 0165 KXMLGUI_DEPRECATED_VERSION(5, 0, "Use QWidget::contextMenuPolicy()") 0166 bool contextMenuEnabled() const; 0167 #endif 0168 0169 /** 0170 * Save the toolbar settings to group @p cg. 0171 */ 0172 void saveSettings(KConfigGroup &cg); 0173 0174 /** 0175 * Read the toolbar settings from group @p cg 0176 * and apply them. 0177 */ 0178 void applySettings(const KConfigGroup &cg); 0179 0180 #if KXMLGUI_ENABLE_DEPRECATED_SINCE(5, 0) 0181 /** 0182 * Sets the XML gui client. 0183 * @deprecated Since 5.0, use addXMLGUIClient() 0184 */ 0185 KXMLGUI_DEPRECATED_VERSION(5, 0, "Use KToolBar::addXMLGUIClient(KXMLGUIClient *)") 0186 void setXMLGUIClient(KXMLGUIClient *client); 0187 #endif 0188 0189 /** 0190 * Adds an XML gui client that uses this toolbar 0191 * @since 4.8.1 0192 */ 0193 void addXMLGUIClient(KXMLGUIClient *client); 0194 0195 /** 0196 * Removes an XML gui client that uses this toolbar 0197 * @since 4.8.5 0198 */ 0199 void removeXMLGUIClient(KXMLGUIClient *client); 0200 0201 /** 0202 * Load state from an XML @param element, called by KXMLGUIBuilder. 0203 */ 0204 void loadState(const QDomElement &element); 0205 0206 /** 0207 * Save state into an XML @param element, called by KXMLGUIBuilder. 0208 */ 0209 void saveState(QDomElement &element) const; 0210 0211 /** 0212 * Reimplemented to support context menu activation on disabled tool buttons. 0213 */ 0214 bool eventFilter(QObject *watched, QEvent *event) override; 0215 0216 /** 0217 * Returns whether the toolbars are currently editable (drag & drop of actions). 0218 */ 0219 static bool toolBarsEditable(); 0220 0221 /** 0222 * Enable or disable toolbar editing via drag & drop of actions. This is 0223 * called by KEditToolBar and should generally be set to disabled whenever 0224 * KEditToolBar is not active. 0225 */ 0226 static void setToolBarsEditable(bool editable); 0227 0228 /** 0229 * Returns whether the toolbars are locked (i.e., moving of the toobars disallowed). 0230 */ 0231 static bool toolBarsLocked(); 0232 0233 /** 0234 * Allows you to lock and unlock all toolbars (i.e., disallow/allow moving of the toobars). 0235 */ 0236 static void setToolBarsLocked(bool locked); 0237 0238 /** 0239 * Emits a D-Bus signal to tell all toolbars in all applications, that the user settings have 0240 * changed. 0241 * @since 5.0 0242 */ 0243 static void emitToolbarStyleChanged(); 0244 0245 protected Q_SLOTS: 0246 virtual void slotMovableChanged(bool movable); 0247 0248 protected: 0249 void contextMenuEvent(QContextMenuEvent *) override; 0250 void actionEvent(QActionEvent *) override; 0251 0252 // Draggable toolbar configuration 0253 void dragEnterEvent(QDragEnterEvent *) override; 0254 void dragMoveEvent(QDragMoveEvent *) override; 0255 void dragLeaveEvent(QDragLeaveEvent *) override; 0256 void dropEvent(QDropEvent *) override; 0257 void mousePressEvent(QMouseEvent *) override; 0258 void mouseMoveEvent(QMouseEvent *) override; 0259 void mouseReleaseEvent(QMouseEvent *) override; 0260 0261 private: 0262 friend class KToolBarPrivate; 0263 std::unique_ptr<class KToolBarPrivate> const d; 0264 0265 Q_PRIVATE_SLOT(d, void slotAppearanceChanged()) 0266 Q_PRIVATE_SLOT(d, void slotContextRight()) 0267 Q_PRIVATE_SLOT(d, void slotContextTextRight()) 0268 }; 0269 0270 #endif