/***************************************************************** kwin - the KDE window manager Copyright (C) 1999, 2000 Matthias Ettrich ******************************************************************/ #ifndef OPTIONS_H #define OPTIONS_H #include #include #include // increment this when you add a color type (mosfet) #define KWINCOLORS 6 class Options : public QObject { Q_OBJECT public: Options(); ~Options(); /*! Different focus policies:
  • ClickToFocus - Clicking into a window activates it. This is also the default.
  • FocusFollowsMouse - Moving the mouse pointer actively onto a normal window activates it. For convenience, the desktop and windows on the dock are excluded. They require clicking.
  • FocusUnderMouse - The window that happens to be under the mouse pointer becomes active. The invariant is: no window can have focus that is not under the mouse. This also means that Alt-Tab won't work properly and popup dialogs are usually unsable with the keyboard. Note that the desktop and windows on the dock are excluded for convenience. They get focus only when clicking on it.
  • FocusStrictlyUnderMouse - this is even worse than FocusUnderMouse. Only the window under the mouse pointer is active. If the mouse points nowhere, nothing has the focus. If the mouse points onto the desktop, the desktop has focus. The same holds for windows on the dock. Note that FocusUnderMouse and FocusStrictlyUnderMouse are not particulary useful. They are only provided for old-fashined die-hard UNIX people ;-)
*/ enum FocusPolicy { ClickToFocus, FocusFollowsMouse, FocusUnderMouse, FocusStrictlyUnderMouse }; FocusPolicy focusPolicy; /** Whether clicking on a window raises it in FocusFollowsMouse mode or not. */ bool clickRaise; /** whether autoraise is enabled FocusFollowsMouse mode or not. */ bool autoRaise; /** autoraise interval */ int autoRaiseInterval; /** Different Alt-Tab-Styles:
  • KDE - the recommended KDE style. Alt-Tab opens a nice icon box that makes it easy to select the window you want to tab to. The order automatically adjusts to the most recently used windows. Note that KDE style does not work with the FocusUnderMouse and FocusStrictlyUnderMouse focus policies. Choose ClickToFocus or FocusFollowsMouse instead.
  • CDE - the old-fashion CDE style. Alt-Tab cycles between the windows in static order. The current window gets raised, the previous window gets lowered.
*/ enum AltTabStyle { KDE, CDE }; AltTabStyle altTabStyle; /** MoveResizeMode, either Tranparent or Opaque. */ enum MoveResizeMode { Transparent, Opaque }; 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; } /** * 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, ButtonBg, Frame, Handle}; /** * 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); /** * whether we animate the shading of windows to titlebar or not */ bool animateShade; /** * the number of animation steps (would this be general?) */ int animSteps; /** * the size of the zone that triggers snapping on desktop borders */ int borderSnapZone; /** * the number of animation steps (would this be general?) */ int windowSnapZone; // mouse bindings enum WindowOperation{ MaximizeOp = 5000, RestoreOp, IconifyOp, MoveOp, ResizeOp, CloseOp, StickyOp, ShadeOp, StaysOnTopOp, 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(); signals: void resetClients(); protected: QFont activeFont, inactiveFont; QColor colors[KWINCOLORS*2]; QColorGroup *cg[KWINCOLORS*2]; private: 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