From 3c80f437ff36c1da9ef671b7d08702cc03d1877d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lubo=C5=A1=20Lu=C5=88=C3=A1k?= Date: Mon, 30 Apr 2007 12:26:31 +0000 Subject: [PATCH] Merging from old trunk: r646407 | montanaro | 2007-03-25 18:33:59 +0200 (Sun, 25 Mar 2007) | 5 lines Fix help and pindown rendering problem: it was due to Qt misrendering bitmaps when they have a mask. Changed code to remove use of kColorBitmaps(). Now kdefx should not be needed to draw the decoration. svn path=/trunk/KDE/kdebase/workspace/; revision=659570 --- clients/b2/b2client.cpp | 112 ++++++++++++++++++++++++++++------------ 1 file changed, 79 insertions(+), 33 deletions(-) diff --git a/clients/b2/b2client.cpp b/clients/b2/b2client.cpp index 9cc23b4652..04713d4c65 100644 --- a/clients/b2/b2client.cpp +++ b/clients/b2/b2client.cpp @@ -30,7 +30,7 @@ #include #include #include -#include +//#include #include #include #include @@ -40,6 +40,7 @@ #include #include +#include namespace B2 { @@ -221,22 +222,23 @@ static void create_pixmaps() } } + // This should stay here, before the mask creation, because of a bug with + // drawing a bitmap with drawPixmap() with the mask set (present at least + // in Qt 4.2.3). + redraw_pixmaps(); + // there seems to be no way to load X bitmaps from data properly, so // we need to create new ones for each mask :P QBitmap pinupMask = QBitmap::fromData(QSize(16, 16), pinup_mask_bits); - PIXMAP_A(P_PINUP)->setMask(pinupMask); - PIXMAP_I(P_PINUP)->setMask(pinupMask); QBitmap pindownMask = QBitmap::fromData(QSize(16, 16), pindown_mask_bits); - PIXMAP_AD(P_PINUP)->setMask(pindownMask); - PIXMAP_ID(P_PINUP)->setMask(pindownMask); - QBitmap menuMask = QBitmap::fromData(QSize(16, 16), menu_mask_bits); - for (i = 0; i < NumStates; i++) - pixmap[P_MENU * NumStates + i]->setMask(menuMask); - QBitmap helpMask = QBitmap::fromData(QSize(16, 16), help_mask_bits); - for (i = 0; i < NumStates; i++) + for (i = 0; i < NumStates; i++) { + bool isDown = (i == Down) || (i == IDown); + pixmap[P_MENU * NumStates + i]->setMask(menuMask); pixmap[P_HELP * NumStates + i]->setMask(helpMask); + pixmap[P_PINUP * NumStates + i]->setMask(isDown ? pindownMask: pinupMask); + } QBitmap normalizeMask(16, 16); normalizeMask.clear(); @@ -263,8 +265,6 @@ static void create_pixmaps() titleGradient[0] = 0; titleGradient[1] = 0; - - redraw_pixmaps(); } static void delete_pixmaps() @@ -574,10 +574,9 @@ void B2Client::calcHiddenButtons() button[BtnShade], button[BtnSticky], button[BtnHelp], button[BtnResize], button[BtnMax], button[BtnIconify], button[BtnClose], button[BtnMenu] }; - int minWidth = 120; + const int minWidth = 120; int currentWidth = width(); int count = 0; - int i; // Determine how many buttons we need to hide while (currentWidth < minWidth) { @@ -588,12 +587,12 @@ void B2Client::calcHiddenButtons() if (count > BtnCount) count = BtnCount; // Hide the required buttons - for (i = 0; i < count; i++) { + for (int i = 0; i < count; i++) { if (btnArray[i] && btnArray[i]->isVisible()) btnArray[i]->hide(); } // Show the rest of the buttons - for (i = count; i < BtnCount; i++) { + for (int i = count; i < BtnCount; i++) { if (btnArray[i] && (!btnArray[i]->isVisible())) btnArray[i]->show(); } @@ -773,7 +772,7 @@ KDecoration::Position B2Client::mousePosition(const QPoint& p) const const int lx = t.right(); const int bb = mustDrawHandle() ? 0 : 5; - if (p.x() > t.right()) { + if (p.x() > lx) { if (p.y() <= ly + range && p.x() >= width() - range) return PositionTopRight; else if (p.y() <= ly + thickness) @@ -906,8 +905,8 @@ void B2Client::menuButtonPressed() { static B2Client *lastClient = NULL; - bool dbl = (lastClient == this && - time.elapsed() <= QApplication::doubleClickInterval()); + const bool dbl = (lastClient == this && + time.elapsed() <= QApplication::doubleClickInterval()); lastClient = this; time.start(); if (!dbl) { @@ -961,7 +960,6 @@ void B2Client::unobscureTitlebar() static void redraw_pixmaps() { - int i; QPalette aGrp = options()->palette(KDecoration::ColorButtonBg, true); QPalette iGrp = options()->palette(KDecoration::ColorButtonBg, false); @@ -979,7 +977,7 @@ static void redraw_pixmaps() // shade QPixmap thinBox(buttonSize - 2, 6); - for (i = 0; i < NumStates; i++) { + for (int i = 0; i < NumStates; i++) { bool is_act = (i < 2); bool is_down = ((i & 1) == 1); QPixmap *pix = pixmap[P_SHADE * NumStates + i]; @@ -991,7 +989,7 @@ static void redraw_pixmaps() } // maximize - for (i = 0; i < NumStates; i++) { + for (int i = 0; i < NumStates; i++) { *pixmap[P_MAX * NumStates + i] = *pixmap[P_CLOSE * NumStates + i]; pixmap[P_MAX * NumStates + i]->detach(); } @@ -1000,7 +998,7 @@ static void redraw_pixmaps() QPixmap smallBox( 10, 10 ); QPixmap largeBox( 12, 12 ); - for (i = 0; i < NumStates; i++) { + for (int i = 0; i < NumStates; i++) { bool is_act = (i < 3); bool is_down = (i == Down || i == IDown); QPixmap *pix = pixmap[P_NORMALIZE * NumStates + i]; @@ -1017,7 +1015,7 @@ static void redraw_pixmaps() } // resize - for (i = 0; i < NumStates; i++) { + for (int i = 0; i < NumStates; i++) { bool is_act = (i < 3); bool is_down = (i == Down || i == IDown); *pixmap[P_RESIZE * NumStates + i] = *pixmap[P_CLOSE * NumStates + i]; @@ -1045,30 +1043,78 @@ static void redraw_pixmaps() break; } int off = (pixmap[pix * NumStates]->width() - 16) / 2; - for (i = 0; i < NumStates; i++) { - p.begin(pixmap[pix * NumStates + i]); - kColorBitmaps(&p, (i < 3) ? aGrp : iGrp, off, off, 16, 16, true, - light, NULL, NULL, dark, NULL, NULL); - p.end(); + QSize bSize(16, 16); + QBitmap lightBitmap = QBitmap::fromData(bSize, + light, QImage::Format_MonoLSB); + lightBitmap.setMask(lightBitmap); + QBitmap darkBitmap = QBitmap::fromData(bSize, + dark, QImage::Format_MonoLSB); + darkBitmap.setMask(darkBitmap); + + for (int i = 0; i < NumStates; i++) { + bool isAct = (i < 3); + QPixmap *pixm = pixmap[pix* NumStates + i]; + p.begin(pixm); + QColor color = isAct ? activeColor : inactiveColor; + p.setPen(color.light(150)); + p.drawPixmap(off, off, lightBitmap); + p.setPen(color.dark(150)); + p.drawPixmap(off, off, darkBitmap); + p.end(); } } // pin - for (i = 0; i < NumStates; i++) { + for (int i = 0; i < NumStates; i++) { const bool isDown = (i == Down || i == IDown); + bool isAct = (i < 3); + +#if 0 unsigned const char *white = isDown ? pindown_white_bits : pinup_white_bits; unsigned const char *gray = isDown ? pindown_gray_bits : pinup_gray_bits; unsigned const char *dgray = isDown ? pindown_dgray_bits : pinup_dgray_bits; - p.begin(pixmap[P_PINUP * NumStates + i]); + QPixmap *pix = pixmap[P_PINUP * NumStates + i]; + p.begin(pix); + kColorBitmaps(&p, (i < 3) ? aGrp : iGrp, 0, 0, 16, 16, true, white, gray, NULL, dgray, NULL, NULL); p.end(); + QBitmap pinupMask = QBitmap::fromData(QSize(16, 16), pinup_mask_bits); + QBitmap pindownMask = QBitmap::fromData(QSize(16, 16), pindown_mask_bits); + pixmap[P_PINUP * NumStates + i]->setMask(isDown ? pindownMask: pinupMask); +#else + + QSize pinSize(16, 16); + QBitmap white = QBitmap::fromData(pinSize, + isDown ? pindown_white_bits : pinup_white_bits, + QImage::Format_MonoLSB); + white.setMask(white); + QBitmap gray = QBitmap::fromData(pinSize, + isDown ? pindown_gray_bits : pinup_gray_bits, + QImage::Format_MonoLSB); + gray.setMask(gray); + QBitmap dgray = QBitmap::fromData(pinSize, + isDown ? pindown_dgray_bits : pinup_dgray_bits, + QImage::Format_MonoLSB); + dgray.setMask(dgray); + + QPixmap *pix = pixmap[P_PINUP * NumStates + i]; + QColor color = isAct ? activeColor : inactiveColor; + p.begin(pix); + p.setPen(color.light(150)); + p.drawPixmap(0, 0, white); + p.setPen(color); + p.drawPixmap(0, 0, gray); + p.setPen(color.dark(150)); + p.drawPixmap(0, 0, dgray); + p.end(); +#endif } // Apply the hilight effect to the 'Hover' icons KIconEffect ie; QPixmap hilighted; - for (i = 0; i < P_NUM_BUTTON_TYPES; i++) { + for (int i = 0; i < P_NUM_BUTTON_TYPES; i++) { int offset = i * NumStates; hilighted = ie.apply(*pixmap[offset + Norm], K3Icon::Small, K3Icon::ActiveState); @@ -1095,7 +1141,7 @@ static void redraw_pixmaps() titleColor[1] = options()->color(KDecoration::ColorTitleBar, true); } - for (i = 0; i < 2; i++) { + for (int i = 0; i < 2; i++) { if (titleColor[2 * i] != titleColor[2 * i + 1]) { if (!titleGradient[i]) { titleGradient[i] = new QPixmap;