f9c7091e05
Strickly and wanted to implement focus configurability. Here is the (for now) "politically correct" version. svn path=/trunk/kdebase/kwin/; revision=37123
179 lines
5.3 KiB
C++
179 lines
5.3 KiB
C++
#ifndef OPTIONS_H
|
|
#define OPTIONS_H
|
|
|
|
#include <qobject.h>
|
|
#include <qfont.h>
|
|
#include <qpalette.h>
|
|
|
|
// increment this when you add a color type (mosfet)
|
|
#define KWINCOLORS 8
|
|
|
|
class Options : public QObject {
|
|
Q_OBJECT
|
|
public:
|
|
|
|
Options();
|
|
~Options();
|
|
|
|
|
|
/*!
|
|
Different focus policies:
|
|
<ul>
|
|
|
|
<li>ClickToFocus - Clicking into a window activates it. This is
|
|
also the default.
|
|
|
|
<li>FocusFollowsMouse - Moving the mouse pointer actively onto a
|
|
window activates it.
|
|
|
|
<li>FocusUnderMouse - The window that happens to be under the
|
|
mouse pointer becomes active.
|
|
|
|
<li>FocusStrictlyUnderMouse - Only the window under the mouse
|
|
pointer is active. If the mouse points nowhere, nothing has the
|
|
focus. In practice, this is the same as FocusUnderMouse, since
|
|
kdesktop can take the focus.
|
|
|
|
Note that FocusUnderMouse and FocusStrictlyUnderMouse are not
|
|
particulary useful. They are only provided for old-fashined
|
|
die-hard UNIX people ;-)
|
|
|
|
</ul>
|
|
*/
|
|
enum FocusPolicy { ClickToFocus, FocusFollowsMouse, FocusUnderMouse, FocusStrictlyUnderMouse };
|
|
FocusPolicy focusPolicy;
|
|
|
|
enum MoveResizeMode { Transparent, Opaque };
|
|
|
|
/**
|
|
* Basic color types that should be recognized by all decoration styles.
|
|
* Not all styles have to implement all the colors, but for the ones that
|
|
* are implemented you should retrieve them here.
|
|
*/
|
|
// increment KWINCOLORS if you add something (mosfet)
|
|
enum ColorType{TitleBar=0, TitleBlend, Font, ButtonFg, ButtonBg,
|
|
ButtonBlend, Frame, Handle};
|
|
|
|
MoveResizeMode resizeMode;
|
|
MoveResizeMode moveMode;
|
|
|
|
/**
|
|
* Placement policies. How workspace decides the way windows get positioned
|
|
* on the screen. The better the policy, the heavier the resource use.
|
|
* Normally you don't have to worry. What the WM adds to the startup time
|
|
* is nil compared to the creation of the window itself in the memory
|
|
*/
|
|
enum PlacementPolicy { Random, Smart, Cascade };
|
|
PlacementPolicy placement;
|
|
|
|
bool focusPolicyIsReasonable() {
|
|
return focusPolicy == ClickToFocus || focusPolicy == FocusFollowsMouse;
|
|
}
|
|
|
|
/**
|
|
* Return the color for the given decoration.
|
|
*/
|
|
const QColor& color(ColorType type, bool active=true);
|
|
/**
|
|
* Return a colorgroup using the given decoration color as the background
|
|
*/
|
|
const QColorGroup& colorGroup(ColorType type, bool active=true);
|
|
/**
|
|
* Return the active or inactive decoration font.
|
|
*/
|
|
const QFont& font(bool active=true);
|
|
/**
|
|
* Return whether we animate the shading of windows to titlebar or not
|
|
*/
|
|
const bool animateShade() { return animate_shade; };
|
|
/**
|
|
* Return the number of animation steps (would this be general?)
|
|
*/
|
|
const int animSteps() { return anim_steps; };
|
|
/**
|
|
* Return the size of the zone that triggers snapping on desktop borders
|
|
*/
|
|
const int borderSnapZone() { return border_snap_zone; };
|
|
/**
|
|
* Return the number of animation steps (would this be general?)
|
|
*/
|
|
const int windowSnapZone() { return window_snap_zone; };
|
|
|
|
|
|
|
|
// mouse bindings
|
|
|
|
enum WindowOperation{
|
|
MaximizeOp = 5000,
|
|
RestoreOp,
|
|
IconifyOp,
|
|
MoveOp,
|
|
ResizeOp,
|
|
CloseOp,
|
|
StickyOp,
|
|
ShadeOp,
|
|
OperationsOp,
|
|
NoOp
|
|
};
|
|
|
|
WindowOperation operationTitlebarDblClick() { return OpTitlebarDblClick; }
|
|
|
|
enum MouseCommand {
|
|
MouseRaise, MouseLower, MouseOperationsMenu, MouseToggleRaiseAndLower,
|
|
MouseActivateAndRaise, MouseActivateAndLower, MouseActivate,
|
|
MouseActivateRaiseAndPassClick, MouseActivateAndPassClick,
|
|
MouseMove, MouseResize, MouseNothing
|
|
};
|
|
|
|
MouseCommand commandActiveTitlebar1() { return CmdActiveTitlebar1; }
|
|
MouseCommand commandActiveTitlebar2() { return CmdActiveTitlebar2; }
|
|
MouseCommand commandActiveTitlebar3() { return CmdActiveTitlebar3; }
|
|
MouseCommand commandInactiveTitlebar1() { return CmdInactiveTitlebar1; }
|
|
MouseCommand commandInactiveTitlebar2() { return CmdInactiveTitlebar2; }
|
|
MouseCommand commandInactiveTitlebar3() { return CmdInactiveTitlebar3; }
|
|
MouseCommand commandWindow1() { return CmdWindow1; }
|
|
MouseCommand commandWindow2() { return CmdWindow2; }
|
|
MouseCommand commandWindow3() { return CmdWindow3; }
|
|
MouseCommand commandAll1() { return CmdAll1; }
|
|
MouseCommand commandAll2() { return CmdAll2; }
|
|
MouseCommand commandAll3() { return CmdAll3; }
|
|
|
|
|
|
static WindowOperation windowOperation(const QString &name );
|
|
static MouseCommand mouseCommand(const QString &name);
|
|
|
|
|
|
public slots:
|
|
void reload();
|
|
|
|
protected:
|
|
QFont activeFont, inactiveFont;
|
|
QColor colors[KWINCOLORS*2];
|
|
QColorGroup *cg[KWINCOLORS*2];
|
|
|
|
private:
|
|
bool animate_shade;
|
|
int anim_steps;
|
|
int border_snap_zone, window_snap_zone;
|
|
|
|
|
|
WindowOperation OpTitlebarDblClick;
|
|
|
|
// mouse bindings
|
|
MouseCommand CmdActiveTitlebar1;
|
|
MouseCommand CmdActiveTitlebar2;
|
|
MouseCommand CmdActiveTitlebar3;
|
|
MouseCommand CmdInactiveTitlebar1;
|
|
MouseCommand CmdInactiveTitlebar2;
|
|
MouseCommand CmdInactiveTitlebar3;
|
|
MouseCommand CmdWindow1;
|
|
MouseCommand CmdWindow2;
|
|
MouseCommand CmdWindow3;
|
|
MouseCommand CmdAll1;
|
|
MouseCommand CmdAll2;
|
|
MouseCommand CmdAll3;
|
|
};
|
|
|
|
extern Options* options;
|
|
|
|
#endif
|