this commit is dedicated to rikkus :P

svn path=/trunk/kdebase/kwin/; revision=95367
icc-effect-5.14.5
Lennart Kudling 2001-05-05 23:16:27 +00:00
parent c0d943b01a
commit 4ca78790ee
1 changed files with 239 additions and 89 deletions

View File

@ -1,30 +1,27 @@
#include "mwmclient.h"
#include <qapplication.h>
#include <qcursor.h>
#include <qabstractlayout.h>
#include <qlayout.h>
#include <qtoolbutton.h>
#include <qlabel.h>
#include <qdrawutil.h>
#include <qdatetime.h>
#include <kpixmapeffect.h>
#include <qlayout.h>
#include <qbutton.h>
#include <qdrawutil.h>
#include "../../workspace.h"
#include "../../options.h"
#include "mwmclient.h"
#include <kdebug.h>
using namespace KWinInternal;
const int s_frameWidth = 5;
const int s_buttonSize = 18;
const int s_buttonSize = 19;
MwmButton::MwmButton( MwmClient* parent, const char* name, int btnType )
: QButton( parent, name , WStyle_Customize | WStyle_NoBorder | WRepaintNoErase
| WResizeNoErase ), m_parent(parent), m_btnType(btnType)
: QButton( parent, name , WStyle_Customize | WStyle_NoBorder
| WRepaintNoErase | WResizeNoErase ), m_parent(parent), m_btnType(btnType)
{
setBackgroundMode( QWidget::NoBackground );
setFixedSize( s_buttonSize, s_buttonSize );
resize( s_buttonSize, s_buttonSize );
}
@ -45,27 +42,30 @@ void MwmButton::drawButton( QPainter* p )
switch ( m_btnType )
{
case (BtnMenu):
qDrawShadePanel( p, 4, 6, 10, 4, options->colorGroup( Options::TitleBar, m_parent->isActive() ) );
qDrawShadePanel( p, 4, 7, 11, 4,
options->colorGroup( Options::TitleBar, m_parent->isActive() ) );
break;
case (BtnIconify):
qDrawShadePanel( p, 6, 7, 5, 5, options->colorGroup( Options::TitleBar, m_parent->isActive() ) );
qDrawShadePanel( p, 7, 7, 5, 5,
options->colorGroup( Options::TitleBar, m_parent->isActive() ) );
break;
case (BtnMax):
qDrawShadePanel( p, 4, 4, 10, 10, options->colorGroup( Options::TitleBar, m_parent->isActive() ) );
qDrawShadePanel( p, 4, 4, 11, 11,
options->colorGroup( Options::TitleBar, m_parent->isActive() ) );
break;
}
}
MwmClient::MwmClient( Workspace *ws, WId w, QWidget *parent,
const char *name )
: Client( ws, w, parent, name, WNorthWestGravity | WResizeNoErase | WRepaintNoErase )
MwmClient::MwmClient( Workspace* ws, WId w, QWidget* parent, const char* name )
: Client( ws, w, parent, name, WNorthWestGravity | WResizeNoErase
| WRepaintNoErase )
{
setBackgroundMode( QWidget::NoBackground );
QVBoxLayout *mainLayout = new QVBoxLayout( this );
QHBoxLayout *titleLayout = new QHBoxLayout();
QHBoxLayout *windowLayout = new QHBoxLayout();
QVBoxLayout* mainLayout = new QVBoxLayout( this );
QHBoxLayout* titleLayout = new QHBoxLayout();
QHBoxLayout* windowLayout = new QHBoxLayout();
mainLayout->addSpacing( s_frameWidth+1 );
mainLayout->addLayout( titleLayout );
@ -80,19 +80,25 @@ MwmClient::MwmClient( Workspace *ws, WId w, QWidget *parent,
button[BtnIconify] = new MwmButton( this, "iconify", BtnIconify );
button[BtnMax] = new MwmButton( this, "maximize", BtnMax );
connect( button[BtnMenu], SIGNAL( pressed() ), this, ( SLOT( menuButtonPressed() ) ) );
connect( button[BtnIconify], SIGNAL( clicked() ), this, ( SLOT( iconify() ) ) );
connect( button[BtnMax], SIGNAL( clicked() ), this, ( SLOT( slotMaximize() ) ) );
connect( options, SIGNAL( resetClients() ), this, ( SLOT( slotReset() ) ) );
connect( button[BtnMenu], SIGNAL( pressed() ),
this, ( SLOT( menuButtonPressed() ) ) );
connect( button[BtnIconify], SIGNAL( clicked() ),
this, ( SLOT( iconify() ) ) );
connect( button[BtnMax], SIGNAL( clicked() ),
this, ( SLOT( slotMaximize() ) ) );
connect( options, SIGNAL( resetClients() ),
this, ( SLOT( slotReset() ) ) );
titleLayout->addSpacing( s_frameWidth+1 );
titleLayout->addWidget( button[BtnMenu] );
titlebar = new QSpacerItem( 10, 16, QSizePolicy::Expanding,
QSizePolicy::Minimum );
QSizePolicy::Minimum );
titleLayout->addItem( titlebar );
titleLayout->addWidget( button[BtnIconify] );
titleLayout->addWidget( button[BtnMax] );
titleLayout->addSpacing( s_frameWidth+1 );
titleLayout->addSpacing( s_frameWidth + 1 );
}
void MwmClient::captionChange( const QString& )
@ -120,18 +126,25 @@ void MwmClient::slotReset()
void MwmClient::slotMaximize()
{
/* if ( button[BtnMax]->last_button == MidButton )
maximize( MaximizeVertical );
else if ( button[BtnMax]->last_button == RightButton )
maximize( MaximizeHorizontal );
else
*/ maximize();
maximize();
}
void MwmClient::menuButtonPressed()
{
workspace()->clientPopup(this)->
popup(button[BtnMenu]->mapToGlobal(button[BtnMenu]->rect().bottomLeft()));
static QTime* t = 0;
static MwmClient* tc = 0;
if ( !t )
t = new QTime;
if ( tc != this || t->elapsed() > QApplication::doubleClickInterval() )
workspace()->clientPopup( this )->popup(
button[BtnMenu]->mapToGlobal(
button[BtnMenu]->rect().bottomLeft() ) );
else
closeWindow();
t->start();
tc = this;
}
void MwmClient::resizeEvent( QResizeEvent* e)
@ -155,12 +168,15 @@ void MwmClient::resizeEvent( QResizeEvent* e)
if ( dx )
{
update( width() - dx + 1, 0, dx, height() );
update( QRect( QPoint(4,4), titlebar->geometry().bottomLeft() - QPoint(1,0) ) );
update( QRect( titlebar->geometry().topRight(), QPoint( width() - 4, titlebar->geometry().bottom() ) ) );
// Titlebar needs no paint event
QApplication::postEvent( this, new QPaintEvent( titlebar->geometry(), false ) );
}
update( width() - dx + 1, 0, dx, height() );
update( QRect( QPoint(4,4),
titlebar->geometry().bottomLeft() - QPoint(1,0) ) );
update( QRect( titlebar->geometry().topRight(),
QPoint( width() - 4, titlebar->geometry().bottom() ) ) );
// Titlebar needs no paint event
QApplication::postEvent( this,
new QPaintEvent( titlebar->geometry(), false ) );
}
}
}
@ -170,7 +186,7 @@ void MwmClient::paintEvent( QPaintEvent* )
QRect trect = titlebar->geometry();
QRect wrect = windowWrapper()->geometry();
QRect mrect = this->geometry();
QRect mrect = rect();
// draw black frame:
p.setPen( Qt::black );
@ -180,66 +196,194 @@ void MwmClient::paintEvent( QPaintEvent* )
p.setBrush( options->color( Options::TitleBar, isActive() ) );
// draw frame-background:
p.drawRect( 1, 1, mrect.width()-2, s_frameWidth );
p.drawRect( 1, mrect.height()-s_frameWidth-1, mrect.width()-2, s_frameWidth );
p.drawRect( 1, s_frameWidth+1, s_frameWidth, mrect.height()-2*s_frameWidth-2 );
p.drawRect( mrect.width()-s_frameWidth-1, s_frameWidth+1, s_frameWidth, mrect.height()-2*s_frameWidth-2 );
p.drawRect(
1,
1,
mrect.width() - 2,
s_frameWidth );
p.drawRect(
1,
mrect.height() - s_frameWidth - 1,
mrect.width() - 2,
s_frameWidth );
p.drawRect(
1,
s_frameWidth + 1,
s_frameWidth,
mrect.height() - 2*s_frameWidth - 2 );
p.drawRect(
mrect.width() - s_frameWidth - 1,
s_frameWidth + 1,
s_frameWidth,
mrect.height() - 2*s_frameWidth - 2 );
// draw left border:
qDrawShadePanel( &p, 1, wrect.y(), s_frameWidth, wrect.height()-s_buttonSize,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw left frame:
qDrawShadePanel( &p,
1,
wrect.y(),
s_frameWidth,
wrect.height() - s_buttonSize,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw right border:
qDrawShadePanel( &p, mrect.width()-s_frameWidth-1, wrect.y(), s_frameWidth, wrect.height()-s_buttonSize,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw right frame:
qDrawShadePanel( &p,
mrect.width() - s_frameWidth - 1,
wrect.y(),
s_frameWidth,
wrect.height() - s_buttonSize,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw top border:
qDrawShadePanel( &p, s_frameWidth+s_buttonSize+1, 1, wrect.width()-2*s_buttonSize, s_frameWidth,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw top frame:
qDrawShadePanel( &p,
s_frameWidth + s_buttonSize + 1,
1,
wrect.width() - 2*s_buttonSize,
s_frameWidth,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw bottom border:
qDrawShadePanel( &p, s_frameWidth+s_buttonSize+1, mrect.height()-s_frameWidth-1, wrect.width()-2*s_buttonSize, s_frameWidth,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw bottom frame:
qDrawShadePanel( &p,
s_frameWidth + s_buttonSize + 1,
mrect.height() - s_frameWidth - 1,
wrect.width() - 2*s_buttonSize,
s_frameWidth,
options->colorGroup( Options::TitleBar, isActive() ) );
// draw light corner parts:
p.setPen( options->colorGroup( Options::TitleBar, isActive() ).light() );
// tl corner:
p.drawLine( 1, 1, s_frameWidth+s_buttonSize-1, 1 );
p.drawLine( 1, 1, 1, s_frameWidth+s_buttonSize-1 );
p.drawLine(
1,
1,
s_frameWidth + s_buttonSize - 1,
1 );
p.drawLine(
1,
1,
1,
s_frameWidth + s_buttonSize - 1 );
// tr corner:
p.drawLine( mrect.width()-3, 1, mrect.width()-s_frameWidth-s_buttonSize-1, 1 );
p.drawLine( mrect.width()-s_frameWidth-s_buttonSize-1, 1, mrect.width()-s_frameWidth-s_buttonSize-1, s_frameWidth-1 );
p.drawLine( mrect.width()-s_frameWidth-1, s_frameWidth, mrect.width()-s_frameWidth-1, s_frameWidth+s_buttonSize-1 );
p.drawLine(
mrect.width() - 3,
1,
mrect.width() - s_frameWidth - s_buttonSize - 1,
1 );
p.drawLine(
mrect.width() - s_frameWidth - s_buttonSize - 1,
1,
mrect.width() - s_frameWidth - s_buttonSize - 1,
s_frameWidth - 1 );
p.drawLine(
mrect.width() - s_frameWidth - 1,
s_frameWidth,
mrect.width() - s_frameWidth - 1,
s_frameWidth + s_buttonSize - 1 );
// br corner:
p.drawLine( mrect.width()-3, mrect.height()-s_frameWidth-s_buttonSize-1, mrect.width()-s_frameWidth-1, mrect.height()-s_frameWidth-s_buttonSize-1 );
p.drawLine( mrect.width()-s_frameWidth-1, mrect.height()-s_frameWidth-s_buttonSize, mrect.width()-s_frameWidth-1, mrect.height()-s_frameWidth-1 );
p.drawLine( mrect.width()-s_frameWidth-2, mrect.height()-s_frameWidth-1, mrect.width()-s_frameWidth-s_buttonSize-1, mrect.height()-s_frameWidth-1 );
p.drawLine( mrect.width()-s_frameWidth-s_buttonSize-1, mrect.height()-s_frameWidth, mrect.width()-s_frameWidth-s_buttonSize-1, mrect.height()-2 );
p.drawLine(
mrect.width() - 3,
mrect.height() - s_frameWidth - s_buttonSize - 1,
mrect.width() - s_frameWidth - 1,
mrect.height() - s_frameWidth - s_buttonSize - 1 );
p.drawLine(
mrect.width() - s_frameWidth - 1,
mrect.height() - s_frameWidth - s_buttonSize,
mrect.width() - s_frameWidth - 1,
mrect.height() - s_frameWidth - 1 );
p.drawLine(
mrect.width() - s_frameWidth - 2,
mrect.height() - s_frameWidth - 1,
mrect.width() - s_frameWidth - s_buttonSize - 1,
mrect.height() - s_frameWidth - 1 );
p.drawLine(
mrect.width() - s_frameWidth - s_buttonSize - 1,
mrect.height() - s_frameWidth,
mrect.width() - s_frameWidth - s_buttonSize - 1,
mrect.height() - 2 );
// bl corner:
p.drawLine( s_frameWidth-1, mrect.height()-s_frameWidth-s_buttonSize-1, 1, mrect.height()-s_frameWidth-s_buttonSize-1 );
p.drawLine( 1, mrect.height()-s_frameWidth-s_buttonSize-2, 1, mrect.height()-3 );
p.drawLine( s_frameWidth+s_buttonSize-1, mrect.height()-s_frameWidth-1, s_frameWidth+1, mrect.height()-s_frameWidth-1 );
p.drawLine(
s_frameWidth-1,
mrect.height() - s_frameWidth - s_buttonSize - 1,
2,
mrect.height() - s_frameWidth - s_buttonSize - 1 );
p.drawLine(
1,
mrect.height() - s_frameWidth - s_buttonSize - 1,
1,
mrect.height() - 3 );
p.drawLine(
s_frameWidth + s_buttonSize - 1,
mrect.height() - s_frameWidth - 1,
s_frameWidth + 1,
mrect.height() - s_frameWidth - 1 );
p.setPen( Qt::NoPen );
// p.setPen( Qt::NoPen );
// draw dark corner parts:
p.setPen( options->colorGroup( Options::TitleBar, isActive() ).dark() );
// tl corner:
p.drawLine( 1, s_frameWidth+s_buttonSize, s_frameWidth, s_frameWidth+s_buttonSize );
p.drawLine( s_frameWidth, s_frameWidth+s_buttonSize-1, s_frameWidth, s_frameWidth );
p.drawLine( s_frameWidth+1, s_frameWidth, s_frameWidth+s_buttonSize, s_frameWidth );
p.drawLine( s_frameWidth+s_buttonSize, s_frameWidth, s_frameWidth+s_buttonSize, 1 );
p.drawLine(
1,
s_frameWidth + s_buttonSize,
s_frameWidth,
s_frameWidth + s_buttonSize );
p.drawLine(
s_frameWidth,
s_frameWidth + s_buttonSize - 1,
s_frameWidth,
s_frameWidth );
p.drawLine(
s_frameWidth + 1,
s_frameWidth,
s_frameWidth + s_buttonSize,
s_frameWidth );
p.drawLine(
s_frameWidth + s_buttonSize,
s_frameWidth,
s_frameWidth + s_buttonSize,
1 );
// tr corner:
p.drawLine( mrect.width()-s_frameWidth-s_buttonSize-1, s_frameWidth, mrect.width()-s_frameWidth-2, s_frameWidth );
p.drawLine( mrect.width()-s_frameWidth-1, s_frameWidth+s_buttonSize, mrect.width()-2, s_frameWidth+s_buttonSize );
p.drawLine( mrect.width()-2, s_frameWidth+s_buttonSize, mrect.width()-2, 1 );
p.drawLine(
mrect.width() - s_frameWidth - s_buttonSize - 1,
s_frameWidth,
mrect.width() - s_frameWidth - 2,
s_frameWidth );
p.drawLine(
mrect.width() - s_frameWidth - 1,
s_frameWidth + s_buttonSize,
mrect.width() - 2,
s_frameWidth + s_buttonSize );
p.drawLine(
mrect.width() - 2,
s_frameWidth + s_buttonSize,
mrect.width() - 2,
1 );
// br corner:
p.drawLine( mrect.width()-s_frameWidth-s_buttonSize-1, mrect.height()-2, mrect.width()-3, mrect.height()-2 );
p.drawLine( mrect.width()-2, mrect.height()-2, mrect.width()-2, mrect.height()-s_frameWidth-s_buttonSize-2 );
p.drawLine(
mrect.width() - s_frameWidth - s_buttonSize - 1,
mrect.height() - 2,
mrect.width() - 3,
mrect.height() - 2 );
p.drawLine(
mrect.width() - 2,
mrect.height() - 2,
mrect.width() - 2,
mrect.height() - s_frameWidth - s_buttonSize - 2 );
// bl corner:
p.drawLine( 1, mrect.height()-2, s_frameWidth+s_buttonSize, mrect.height()-2 );
p.drawLine( s_frameWidth+s_buttonSize, mrect.height()-3, s_frameWidth+s_buttonSize, mrect.height()-s_frameWidth-1 );
p.drawLine( s_frameWidth, mrect.height()-s_frameWidth-1, s_frameWidth, mrect.height()-s_frameWidth-s_buttonSize-1 );
p.drawLine(
1,
mrect.height() - 2,
s_frameWidth + s_buttonSize,
mrect.height() - 2 );
p.drawLine(
s_frameWidth + s_buttonSize,
mrect.height() - 3,
s_frameWidth + s_buttonSize,
mrect.height() - s_frameWidth - 1 );
p.drawLine(
s_frameWidth,
mrect.height() - s_frameWidth - 1,
s_frameWidth,
mrect.height() - s_frameWidth - s_buttonSize - 1 );
p.setPen( Qt::NoPen );
@ -249,17 +393,23 @@ void MwmClient::paintEvent( QPaintEvent* )
options->colorGroup( Options::TitleBar, isActive() ) );
// draw caption:
p.setFont( options->font(true) );
p.setFont( options->font( true ) );
p.setPen( options->color( Options::Font, isActive() ) );
p.drawText( trect.x()+3, trect.y()-1, trect.width()-6, trect.height(),
p.drawText(
trect.x() + 3,
trect.y() - 1,
trect.width() - 6,
trect.height(),
AlignHCenter | AlignVCenter, caption() );
}
void MwmClient::mouseDoubleClickEvent( QMouseEvent * e )
{
if ( titlebar->geometry().contains( e->pos() ) )
setShade( !isShade() );
workspace()->requestFocus( this );
{
workspace()->lowerClient( this );
workspace()->requestFocus( workspace()->topClientOnDesktop() );
}
}
void MwmClient::init()
@ -269,9 +419,9 @@ void MwmClient::init()
extern "C"
{
Client *allocate(Workspace *ws, WId w)
Client* allocate( Workspace* ws, WId w )
{
return(new MwmClient(ws, w));
return( new MwmClient( ws, w ) );
}
void init()
{