/* $Id$ Gallium-IceWM themeable KWin client Copyright 2001 Karol Szwed http://gallium.n3.net/ This client loads most icewm 1.0.X pixmap themes, without taking into account specific font settings for clients, or coloured mouse cursors. Titlebar fonts can be changed via the kde control center. Bi-colour mouse cursors may be added in future if requested by users, as well as theme font support. Any styles using inbuilt icewm titlebar drawing without using pixmaps (e.g. Warp4, win95 etc.) are not fully supported, and may cause drawing errors, as these themes use in-built icewm drawing mechanisms. When a pixmap theme is not present (or a corrupt one is present) then very plain title decorations are painted instead, so that users don't see non-painted window areas where possible ;) At a later date, frame shaping may be added if really requested, and an update to support the latest icewm 1.1.X theme format may be made. */ #ifndef __KDEGALLIUM_ICEWM_H #define __KDEGALLIUM_ICEWM_H #include #include #include #include "../../client.h" class QLabel; class QSpacerItem; class QHBoxLayout; class QGridLayout; namespace KWinInternal { // Pixmap group enum { InActive=0, Active }; // Pixmap stretching mode enum { Vertical=0, Horizontal=1 }; // Handles the resetClients() signal from the Options class, // and manages the dynamic pixmaps, configuration and theme changing class ThemeHandler: public QObject { Q_OBJECT public: ThemeHandler(); ~ThemeHandler(); public slots: void slotReset(); private: bool initialized; QString themeName; void readConfig(); QColor decodeColor( QString& s ); bool isFrameValid(); void initTheme(); void freePixmaps(); void freePixmapGroup( QPixmap* p[] ); void setPixmap( QPixmap* p[], QString s1, QString s2, bool stretch=false, bool stretchHoriz=true ); QPixmap* stretchPixmap( QPixmap* src, bool stretchHoriz=true, int stretchSize=-1); QPixmap* duplicateValidPixmap( bool act, int size = -1 ); void convertButtons( QString& s ); QString reverseString( QString s ); }; class IceWMButton : public QButton { public: IceWMButton( Client *parent=0, const char *name=0, QPixmap* (*p)[2]=0L, bool isToggle=false ); void usePixmap( QPixmap* (*p)[2] ); QSize sizeHint() const; void turnOn( bool isOn ); int last_button; protected: void mousePressEvent( QMouseEvent* e ); void mouseReleaseEvent( QMouseEvent* e ); void drawButton( QPainter *p ); void drawButtonLabel( QPainter * ) {;} private: QPixmap* (*pix)[2]; // Points to active/inactive pixmap array Client* client; }; class IceWMClient : public KWinInternal::Client { Q_OBJECT public: IceWMClient( Workspace *ws, WId w, QWidget *parent=0, const char *name=0 ); ~IceWMClient(); protected: void resizeEvent( QResizeEvent* ); void paintEvent( QPaintEvent* ); void showEvent( QShowEvent* ); void mouseDoubleClickEvent( QMouseEvent * ); void captionChange( const QString& name ); void maximizeChange(bool m); void activeChange(bool); // void shadeChange(bool); /* KWin Client class doesn't provide this yet */ MousePosition mousePosition( const QPoint& ) const; void renderMenuIcons(); void iconChange(); void stickyChange(bool on); protected slots: void slotMaximize(); void menuButtonPressed(); private: // These are all the icewm button types :) enum Buttons{ BtnSysMenu=0, BtnClose, BtnMaximize, BtnMinimize, BtnHide, BtnRollup, BtnDepth, BtnCount }; QString shortenCaption( const QString* s ); void calcHiddenButtons(); int titleTextWidth( const QString& s ); void addClientButtons( const QString& s ); QSpacerItem* addPixmapSpacer( QPixmap* p[], QSizePolicy::SizeType = QSizePolicy::Maximum, int hsize = -1 ); IceWMButton* button[ IceWMClient::BtnCount ]; QPixmap* menuButtonWithIconPix[2]; QSpacerItem* titleSpacerJ; QSpacerItem* titleSpacerL; QSpacerItem* titleSpacerS; QSpacerItem* titleSpacerP; QSpacerItem* titlebar; QSpacerItem* titleSpacerM; QSpacerItem* titleSpacerB; QSpacerItem* titleSpacerR; QSpacerItem* titleSpacerQ; QHBoxLayout* hb; QGridLayout* grid; }; }; #endif // vim: ts=4