diff options
Diffstat (limited to 'kdecore/kglobalaccel.h')
-rw-r--r-- | kdecore/kglobalaccel.h | 239 |
1 files changed, 239 insertions, 0 deletions
diff --git a/kdecore/kglobalaccel.h b/kdecore/kglobalaccel.h new file mode 100644 index 000000000..e4b847cdc --- /dev/null +++ b/kdecore/kglobalaccel.h @@ -0,0 +1,239 @@ +/* This file is part of the KDE libraries + Copyright (C) 2001,2002 Ellis Whitehead <[email protected]> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + Boston, MA 02110-1301, USA. +*/ + +#ifndef _KGLOBALACCEL_H_ +#define _KGLOBALACCEL_H_ + +#include <qobject.h> +#include <kshortcut.h> + +class QPopupMenu; +class QWidget; +class KAccelAction; +class KAccelActions; +class KConfigBase; + +class KGlobalAccelPrivate; + +/** +* KGlobalAccel allows you to have global accelerators that are independent of +* the focused window. Unlike KAccel it does not matter which window is +* currently active. +* +* @see KAccel +* @see KAccelShortcutList +* @see KKeyChooser +* @see KKeyDialog +* @short Configurable global shortcut support +*/ +class KDECORE_EXPORT KGlobalAccel : public QObject +{ + Q_OBJECT + public: + /** + * Creates a new KGlobalAccel object with the given pParent and + * psName. + * @param pParent the parent of the QObject + * @param psName the name of the QObject + */ + KGlobalAccel( QObject* pParent, const char* psName = 0 ); + virtual ~KGlobalAccel(); + + /** + * Checks whether the accelerators are enabled. + * @return true if the KGlobalAccel is enabled + */ + bool isEnabled(); + + /** + * Enables or disables the KGlobalAccel + * @param bEnabled true if the KGlobalAccel should be enabled, false if it + * should be disabled. + */ + void setEnabled( bool bEnabled ); + + /** + * Create an accelerator action. + * + * Usage: + *\code + * insert( "Do Something", i18n("Do Something"), + * i18n("This action allows you to do something really great with this program to " + * "the currently open document."), + * ALT+CTRL+Key_Q, KKey::QtWIN+CTRL+Key_Q, this, SLOT(slotDoSomething()) ); + *\endcode + * + * @param sAction The internal name of the action. + * @param sLabel An i18n'ized short description of the action displayed when + * using KKeyChooser to reconfigure the shortcuts. + * @param sWhatsThis An extended description of the action. + * @param cutDef3 The default 3 modifier scheme shortcut. + * @param cutDef4 The default 4 modifier scheme shortcut. + * @param pObjSlot Pointer to the slot object. + * @param psMethodSlot Pointer to the slot method. + * @param bConfigurable Allow the user to change this shortcut if set to 'true'. + * @param bEnabled The action will be activated by the shortcut if set to 'true'. + */ + KAccelAction* insert( const QString& sAction, const QString& sLabel, const QString& sWhatsThis, + const KShortcut& cutDef3, const KShortcut& cutDef4, + const QObject* pObjSlot, const char* psMethodSlot, + bool bConfigurable = true, bool bEnabled = true ); + + /** + * Removes the accelerator action identified by the name. + * Remember to also call updateConnections(). + * @param sAction the name of the action to remove + * @since 3.1 + */ + bool remove( const QString& sAction ); + + /** + * Use this to insert a label into the action list. This will be + * displayed when the user configures shortcuts. + * @param sName of the of the action to insert + * @param sLabel a user-readable (i18n!) name for the action + * @return the KAccelAction of the action + */ + KAccelAction* insert( const QString& sName, const QString& sLabel ); + + /** + * Updates the connections of the accelerations after changing them. + * @return true if successful, false otherwise + */ + bool updateConnections(); + + /** + * Return the shortcut associated with the action named by @p sAction. + * @param sAction the name of the action + * @return the shortcut. If the action does not exist a null shortcut will be returned. + */ + const KShortcut& shortcut( const QString& sAction ) const; + /** + * Set the shortcut to be associated with the action named by @p sAction. + * @param sAction the name of the action + * @param shortcut the shortcut for the action + * @return true if successful, false otherwise + */ + bool setShortcut( const QString& sAction, const KShortcut &shortcut ); + /** + * Set the slot to be called when the shortcut of the action named + * by @p sAction is pressed. + * @param sAction the name of the action + * @param pObjSlot the receiver of the signal + * @param psMethodSlot the slot to receive the signal + * @return true if successful, false otherwise + */ + bool setSlot( const QString& sAction, const QObject* pObjSlot, const char* psMethodSlot ); + + /** + * Enables or disables action @p sAction. + * @since 3.4 + */ + bool setActionEnabled( const QString& sAction, bool bEnable ); + /** + * Return the label (i18n'ized short description) associated with the action named by @p sAction. + * @param sAction the name of the action + * @return the label + * @since 3.3 + */ + QString label( const QString& sAction ) const; + + /** + * Returns the configuration group that is used to save the accelerators. + * @return the configuration group + * @see KConfig + */ + const QString& configGroup() const; + + /** + * Sets the configuration group that is used to save the accelerators. + * @param cg the configuration group + * @see KConfig + */ + void setConfigGroup( const QString &cg ); + + /** + * Read all shortcuts from @p pConfig, or (if @p pConfig + * is zero) from the application's configuration file + * KGlobal::config(). + * @param pConfig the configuration file to read from, or 0 for the application + * configuration file + * @return true if successful, false otherwise + */ + bool readSettings( KConfigBase* pConfig = 0 ); + + /** + * Write the current shortcuts to @p pConfig, + * or (if @p pConfig is zero) to the application's + * configuration file. + * @param pConfig the configuration file to read from, or 0 for the application + * configuration file + * @return true if successful, false otherwise + * @since 3.1 + */ + bool writeSettings( KConfigBase* pConfig = 0 ) const; + // BCI: merge these two writeSettings methods in KDE 4.0 + /** + * Write the current shortcuts to @p pConfig, + * or (if @p pConfig is zero) to the application's + * configuration file. Alternatively, if bGlobal is true, then write + * to kdeglobals. + * @param pConfig the configuration file to read from, or 0 for the application + * configuration file + * @param bGlobal if true write the configuration to the kde global settings + * @return true if successful, false otherwise + */ + bool writeSettings( KConfigBase* pConfig, bool bGlobal ) const; + + /** + * @internal -- this a wrapper function to + * KAccelActions::useFourModifierKeys(). + */ + static bool useFourModifierKeys(); + + /** + * @internal + */ + static void blockShortcuts( bool block ); + /** + * @internal + */ + void disableBlocking( bool disable ); + + /** + * @internal + */ + // like setEnabled(), but doesn't ungrab (see in KGlobalAccelPrivate) + void suspend( bool s ); + +private: + + KAccelActions& actions(); + const KAccelActions& actions() const; + + friend class KGlobalAccelPrivate; + friend class KAccelShortcutList; +protected: + /** \internal */ + virtual void virtual_hook( int id, void* data ); +private: + class KGlobalAccelPrivate* d; +}; + +#endif // _KGLOBALACCEL_H_ |