Source: kglobalaccel.h


Annotated List
Files
Globals
Hierarchy
Index
/* This file is part of the KDE libraries
    Copyright (C) 2001,2002 Ellis Whitehead 

    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., 59 Temple Place - Suite 330,
    Boston, MA 02111-1307, USA.
*/

#ifndef _KGLOBALACCEL_H_
#define _KGLOBALACCEL_H_

#include 
#include 

class QPopupMenu;
class QWidget;
class KAccelAction;
class KAccelActions;
class KConfigBase;

class KGlobalAccelPrivate;

class KGlobalAccel : public QObject
{
	Q_OBJECT
 public:
	KGlobalAccel( QObject* pParent, const char* psName = 0 );
	virtual ~KGlobalAccel();

	bool isEnabled();
	void setEnabled( bool bEnabled );

	/**
	 * Create an accelerator action.
	 *
	 * Usage:
	 *
	 * 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()) );
	 *
* * @param sAction The internal name of the action. * @param sLabel An i18n'ized short description of the action displayed when * using @ref 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 ); /** * Use this to insert a label into the action list. This will be * displayed when the user configures shortcuts. */ KAccelAction* insert( const QString& sName, const QString& sLabel ); bool updateConnections(); /** * Set the shortcut to be associated with the action named by @p sAction. */ const KShortcut& shortcut( const QString& sAction ) const; /** * Set the shortcut to be associated with the action named by @p sAction. */ bool setShortcut( const QString& sAction, const KShortcut& ); /** * Set the slot to be called when the shortcut of the action named * by @p sAction is pressed. */ bool setSlot( const QString& sAction, const QObject* pObjSlot, const char* psMethodSlot ); /** * Enable or disable the action named by @p sAction. */ bool setEnabled( const QString& sAction, bool bEnabled ); const QString& configGroup() const; void setConfigGroup( const QString& ); /** * Read all shortcuts from @p pConfig, or (if @p pConfig * is zero) from the application's configuration file * @ref KGlobal::config(). */ bool readSettings( KConfigBase* pConfig = 0 ); /** * Write the current shortcuts to @p pConfig, * or (if @p pConfig is zero) to the application's * configuration file. */ bool writeSettings( KConfigBase* pConfig = 0 ) const; /** * @internal -- this a wrapper function to * KAccelActions::useFourModifierKeys(). */ static bool useFourModifierKeys(); private: KAccelActions& actions(); const KAccelActions& actions() const; friend class KGlobalAccelPrivate; friend class KAccelShortcutList; protected: virtual void virtual_hook( int id, void* data ); private: class KGlobalAccelPrivate* d; }; #endif // _KGLOBALACCEL_H_

Generated by: dfaure on faure on Tue Apr 16 08:49:00 2002, using kdoc 2.0a53.