enable panel shadows
This commit is contained in:
parent
4c79f8fcff
commit
81f4ab704b
@ -14,7 +14,12 @@ find_path(KDE_MODULES_DIR NAMES KDE4Macros.cmake PATH_SUFFIXES share/cmake/modul
|
|||||||
|
|
||||||
|
|
||||||
add_definitions (${QT_DEFINITIONS} ${KDE4_DEFINITIONS})
|
add_definitions (${QT_DEFINITIONS} ${KDE4_DEFINITIONS})
|
||||||
|
add_definitions(-DHAVE_X11=${X11_FOUND})
|
||||||
|
|
||||||
|
if(X11_FOUND)
|
||||||
|
# FIXME: remove when upstream CMakeLists is fixed
|
||||||
|
find_package(XCB REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
find_package(Qt5Transitional REQUIRED Core)
|
find_package(Qt5Transitional REQUIRED Core)
|
||||||
find_package(Qt5Qml REQUIRED)
|
find_package(Qt5Qml REQUIRED)
|
||||||
@ -60,6 +65,7 @@ add_executable(plasma-shell
|
|||||||
configview.cpp
|
configview.cpp
|
||||||
containmentconfigview.cpp
|
containmentconfigview.cpp
|
||||||
currentcontainmentactionsmodel.cpp
|
currentcontainmentactionsmodel.cpp
|
||||||
|
panelshadows.cpp
|
||||||
desktopcorona.cpp
|
desktopcorona.cpp
|
||||||
panelview.cpp
|
panelview.cpp
|
||||||
shellpluginloader.cpp
|
shellpluginloader.cpp
|
||||||
@ -90,6 +96,10 @@ target_link_libraries(plasma-shell
|
|||||||
kdeqt5staging
|
kdeqt5staging
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if(X11_FOUND)
|
||||||
|
target_link_libraries(plasma-shell ${X11_LIBRARIES} ${XCB_XCB_LIBRARIES} )
|
||||||
|
target_link_libraries(plasma-shell Qt5::X11Extras)
|
||||||
|
endif(X11_FOUND)
|
||||||
|
|
||||||
install(TARGETS plasma-shell ${INSTALL_TARGETS_DEFAULT_ARGS})
|
install(TARGETS plasma-shell ${INSTALL_TARGETS_DEFAULT_ARGS})
|
||||||
|
|
||||||
|
478
src/shell/panelshadows.cpp
Normal file
478
src/shell/panelshadows.cpp
Normal file
@ -0,0 +1,478 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2011 by Aaron Seigo <aseigo@kde.org>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Library General Public License version 2,
|
||||||
|
* or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Library General Public
|
||||||
|
* License along with this program; if not, write to the
|
||||||
|
* Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "panelshadows_p.h"
|
||||||
|
|
||||||
|
#include <QWindow>
|
||||||
|
#include <QPainter>
|
||||||
|
|
||||||
|
#ifdef HAVE_X11
|
||||||
|
#include <QX11Info>
|
||||||
|
#include <X11/Xatom.h>
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
#include <X11/Xlib-xcb.h>
|
||||||
|
#include <fixx11h.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <qdebug.h>
|
||||||
|
#include <kglobal.h>
|
||||||
|
|
||||||
|
class PanelShadows::Private
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Private(PanelShadows *shadows)
|
||||||
|
: q(shadows)
|
||||||
|
#if HAVE_X11
|
||||||
|
,_connection( 0x0 ),
|
||||||
|
_gc( 0x0 )
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
~Private()
|
||||||
|
{
|
||||||
|
// Do not call clearPixmaps() from here: it creates new QPixmap(),
|
||||||
|
// which causes a crash when application is stopping.
|
||||||
|
freeX11Pixmaps();
|
||||||
|
}
|
||||||
|
|
||||||
|
void freeX11Pixmaps();
|
||||||
|
void clearPixmaps();
|
||||||
|
void setupPixmaps();
|
||||||
|
Qt::HANDLE createPixmap(const QPixmap& source);
|
||||||
|
void initPixmap(const QString &element);
|
||||||
|
QPixmap initEmptyPixmap(const QSize &size);
|
||||||
|
void updateShadow(const QWindow *window, Plasma::FrameSvg::EnabledBorders);
|
||||||
|
void clearShadow(const QWindow *window);
|
||||||
|
void updateShadows();
|
||||||
|
void windowDestroyed(QObject *deletedObject);
|
||||||
|
void setupData(Plasma::FrameSvg::EnabledBorders enabledBorders);
|
||||||
|
|
||||||
|
PanelShadows *q;
|
||||||
|
QList<QPixmap> m_shadowPixmaps;
|
||||||
|
|
||||||
|
QPixmap m_emptyCornerPix;
|
||||||
|
QPixmap m_emptyCornerLeftPix;
|
||||||
|
QPixmap m_emptyCornerTopPix;
|
||||||
|
QPixmap m_emptyCornerRightPix;
|
||||||
|
QPixmap m_emptyCornerBottomPix;
|
||||||
|
QPixmap m_emptyVerticalPix;
|
||||||
|
QPixmap m_emptyHorizontalPix;
|
||||||
|
|
||||||
|
//! xcb connection
|
||||||
|
xcb_connection_t* _connection;
|
||||||
|
|
||||||
|
//! graphical context
|
||||||
|
xcb_gcontext_t _gc;
|
||||||
|
|
||||||
|
QHash<Plasma::FrameSvg::EnabledBorders, QVector<unsigned long> > data;
|
||||||
|
QHash<const QWindow *, Plasma::FrameSvg::EnabledBorders> m_windows;
|
||||||
|
};
|
||||||
|
|
||||||
|
class DialogShadowsSingleton
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
DialogShadowsSingleton()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
PanelShadows self;
|
||||||
|
};
|
||||||
|
|
||||||
|
K_GLOBAL_STATIC(DialogShadowsSingleton, privateDialogShadowsSelf)
|
||||||
|
|
||||||
|
PanelShadows::PanelShadows(QObject *parent, const QString &prefix)
|
||||||
|
: Plasma::Svg(parent),
|
||||||
|
d(new Private(this))
|
||||||
|
{
|
||||||
|
setImagePath(prefix);
|
||||||
|
connect(this, SIGNAL(repaintNeeded()), this, SLOT(updateShadows()));
|
||||||
|
}
|
||||||
|
|
||||||
|
PanelShadows::~PanelShadows()
|
||||||
|
{
|
||||||
|
delete d;
|
||||||
|
}
|
||||||
|
|
||||||
|
PanelShadows *PanelShadows::self()
|
||||||
|
{
|
||||||
|
return &privateDialogShadowsSelf->self;
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::addWindow(const QWindow *window, Plasma::FrameSvg::EnabledBorders enabledBorders)
|
||||||
|
{
|
||||||
|
if (!window) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
d->m_windows[window] = enabledBorders;
|
||||||
|
d->updateShadow(window, enabledBorders);
|
||||||
|
connect(window, SIGNAL(destroyed(QObject*)),
|
||||||
|
this, SLOT(windowDestroyed(QObject*)), Qt::UniqueConnection);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::removeWindow(const QWindow *window)
|
||||||
|
{
|
||||||
|
if (!d->m_windows.contains(window)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
d->m_windows.remove(window);
|
||||||
|
disconnect(window, 0, this, 0);
|
||||||
|
d->clearShadow(window);
|
||||||
|
|
||||||
|
if (d->m_windows.isEmpty()) {
|
||||||
|
d->clearPixmaps();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::windowDestroyed(QObject *deletedObject)
|
||||||
|
{
|
||||||
|
m_windows.remove(static_cast<QWindow *>(deletedObject));
|
||||||
|
|
||||||
|
if (m_windows.isEmpty()) {
|
||||||
|
clearPixmaps();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::updateShadows()
|
||||||
|
{
|
||||||
|
setupPixmaps();
|
||||||
|
QHash<const QWindow *, Plasma::FrameSvg::EnabledBorders>::const_iterator i;
|
||||||
|
for (i = m_windows.constBegin(); i != m_windows.constEnd(); ++i) {
|
||||||
|
updateShadow(i.key(), i.value());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Qt::HANDLE PanelShadows::Private::createPixmap(const QPixmap& source)
|
||||||
|
{
|
||||||
|
|
||||||
|
// do nothing for invalid pixmaps
|
||||||
|
if( source.isNull() ) return 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
in some cases, pixmap handle is invalid. This is the case notably
|
||||||
|
when Qt uses to RasterEngine. In this case, we create an X11 Pixmap
|
||||||
|
explicitly and draw the source pixmap on it.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if HAVE_X11
|
||||||
|
|
||||||
|
// check connection
|
||||||
|
if( !_connection ) _connection = QX11Info::connection();
|
||||||
|
|
||||||
|
const int width( source.width() );
|
||||||
|
const int height( source.height() );
|
||||||
|
|
||||||
|
// create X11 pixmap
|
||||||
|
Pixmap pixmap = XCreatePixmap( QX11Info::display(), QX11Info::appRootWindow(), width, height, 32 );
|
||||||
|
|
||||||
|
// check gc
|
||||||
|
if( !_gc )
|
||||||
|
{
|
||||||
|
_gc = xcb_generate_id( _connection );
|
||||||
|
xcb_create_gc( _connection, _gc, pixmap, 0, 0x0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
// // create explicitly shared QPixmap from it
|
||||||
|
// QPixmap dest( QPixmap::fromX11Pixmap( pixmap, QPixmap::ExplicitlyShared ) );
|
||||||
|
//
|
||||||
|
// // create surface for pixmap
|
||||||
|
// {
|
||||||
|
// QPainter painter( &dest );
|
||||||
|
// painter.setCompositionMode( QPainter::CompositionMode_Source );
|
||||||
|
// painter.drawPixmap( 0, 0, source );
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// return pixmap;
|
||||||
|
QImage image( source.toImage() );
|
||||||
|
xcb_put_image(
|
||||||
|
_connection, XCB_IMAGE_FORMAT_Z_PIXMAP, pixmap, _gc,
|
||||||
|
image.width(), image.height(), 0, 0,
|
||||||
|
0, 32,
|
||||||
|
image.byteCount(), image.constBits());
|
||||||
|
|
||||||
|
return (Qt::HANDLE)pixmap;
|
||||||
|
|
||||||
|
#else
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::initPixmap(const QString &element)
|
||||||
|
{
|
||||||
|
m_shadowPixmaps << q->pixmap(element);
|
||||||
|
}
|
||||||
|
|
||||||
|
QPixmap PanelShadows::Private::initEmptyPixmap(const QSize &size)
|
||||||
|
{
|
||||||
|
#ifdef HAVE_X11
|
||||||
|
QPixmap tempEmptyPix(size);
|
||||||
|
if (!size.isEmpty()) {
|
||||||
|
tempEmptyPix.fill(Qt::transparent);
|
||||||
|
}
|
||||||
|
return tempEmptyPix;
|
||||||
|
#else
|
||||||
|
return QPixmap();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::setupPixmaps()
|
||||||
|
{
|
||||||
|
clearPixmaps();
|
||||||
|
initPixmap("shadow-top");
|
||||||
|
initPixmap("shadow-topright");
|
||||||
|
initPixmap("shadow-right");
|
||||||
|
initPixmap("shadow-bottomright");
|
||||||
|
initPixmap("shadow-bottom");
|
||||||
|
initPixmap("shadow-bottomleft");
|
||||||
|
initPixmap("shadow-left");
|
||||||
|
initPixmap("shadow-topleft");
|
||||||
|
|
||||||
|
m_emptyCornerPix = initEmptyPixmap(QSize(1,1));
|
||||||
|
m_emptyCornerLeftPix = initEmptyPixmap(QSize(q->elementSize("shadow-topleft").width(), 1));
|
||||||
|
m_emptyCornerTopPix = initEmptyPixmap(QSize(1, q->elementSize("shadow-topleft").height()));
|
||||||
|
m_emptyCornerRightPix = initEmptyPixmap(QSize(q->elementSize("shadow-bottomright").width(), 1));
|
||||||
|
m_emptyCornerBottomPix = initEmptyPixmap(QSize(1, q->elementSize("shadow-bottomright").height()));
|
||||||
|
m_emptyVerticalPix = initEmptyPixmap(QSize(1, q->elementSize("shadow-left").height()));
|
||||||
|
m_emptyHorizontalPix = initEmptyPixmap(QSize(q->elementSize("shadow-top").width(), 1));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void PanelShadows::Private::setupData(Plasma::FrameSvg::EnabledBorders enabledBorders)
|
||||||
|
{
|
||||||
|
#ifdef HAVE_X11
|
||||||
|
//shadow-top
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::TopBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[0]));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyHorizontalPix));
|
||||||
|
}
|
||||||
|
|
||||||
|
//shadow-topright
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::TopBorder &&
|
||||||
|
enabledBorders & Plasma::FrameSvg::RightBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[1]));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::TopBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerTopPix));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::RightBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerRightPix));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerPix));
|
||||||
|
}
|
||||||
|
|
||||||
|
//shadow-right
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::RightBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[2]));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyVerticalPix));
|
||||||
|
}
|
||||||
|
|
||||||
|
//shadow-bottomright
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::BottomBorder &&
|
||||||
|
enabledBorders & Plasma::FrameSvg::RightBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[3]));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::BottomBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerBottomPix));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::RightBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerRightPix));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerPix));
|
||||||
|
}
|
||||||
|
|
||||||
|
//shadow-bottom
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::BottomBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[4]));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyHorizontalPix));
|
||||||
|
}
|
||||||
|
|
||||||
|
//shadow-bottomleft
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::BottomBorder &&
|
||||||
|
enabledBorders & Plasma::FrameSvg::LeftBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[5]));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::BottomBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerBottomPix));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::LeftBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerLeftPix));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerPix));
|
||||||
|
}
|
||||||
|
|
||||||
|
//shadow-left
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::LeftBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[6]));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyVerticalPix));
|
||||||
|
}
|
||||||
|
|
||||||
|
//shadow-topleft
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::TopBorder &&
|
||||||
|
enabledBorders & Plasma::FrameSvg::LeftBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_shadowPixmaps[7]));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::TopBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerTopPix));
|
||||||
|
} else if (enabledBorders & Plasma::FrameSvg::LeftBorder) {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerLeftPix));
|
||||||
|
} else {
|
||||||
|
data[enabledBorders] << reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerPix));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int left, top, right, bottom = 0;
|
||||||
|
|
||||||
|
QSize marginHint;
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::TopBorder) {
|
||||||
|
marginHint = q->elementSize("shadow-hint-top-margin");
|
||||||
|
if (marginHint.isValid()) {
|
||||||
|
top = marginHint.height();
|
||||||
|
} else {
|
||||||
|
top = m_shadowPixmaps[0].height(); // top
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
top = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::RightBorder) {
|
||||||
|
marginHint = q->elementSize("shadow-hint-right-margin");
|
||||||
|
if (marginHint.isValid()) {
|
||||||
|
right = marginHint.width();
|
||||||
|
} else {
|
||||||
|
right = m_shadowPixmaps[2].width(); // right
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
right = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::BottomBorder) {
|
||||||
|
marginHint = q->elementSize("shadow-hint-bottom-margin");
|
||||||
|
if (marginHint.isValid()) {
|
||||||
|
bottom = marginHint.height();
|
||||||
|
} else {
|
||||||
|
bottom = m_shadowPixmaps[4].height(); // bottom
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
bottom = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (enabledBorders & Plasma::FrameSvg::LeftBorder) {
|
||||||
|
marginHint = q->elementSize("shadow-hint-left-margin");
|
||||||
|
if (marginHint.isValid()) {
|
||||||
|
left = marginHint.width();
|
||||||
|
} else {
|
||||||
|
left = m_shadowPixmaps[6].width(); // left
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
left = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
data[enabledBorders] << top << right << bottom << left;
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::freeX11Pixmaps()
|
||||||
|
{
|
||||||
|
#ifdef HAVE_X11
|
||||||
|
foreach (const QPixmap &pixmap, m_shadowPixmaps) {
|
||||||
|
if (!QX11Info::display()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!pixmap.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(pixmap)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!m_emptyCornerPix.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerPix)));
|
||||||
|
}
|
||||||
|
if (!m_emptyCornerBottomPix.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerBottomPix)));
|
||||||
|
}
|
||||||
|
if (!m_emptyCornerLeftPix.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerLeftPix)));
|
||||||
|
}
|
||||||
|
if (!m_emptyCornerRightPix.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerRightPix)));
|
||||||
|
}
|
||||||
|
if (!m_emptyCornerTopPix.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(m_emptyCornerTopPix)));
|
||||||
|
}
|
||||||
|
if (!m_emptyVerticalPix.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(m_emptyVerticalPix)));
|
||||||
|
}
|
||||||
|
if (!m_emptyHorizontalPix.isNull()) {
|
||||||
|
XFreePixmap(QX11Info::display(), reinterpret_cast<unsigned long>(createPixmap(m_emptyHorizontalPix)));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::clearPixmaps()
|
||||||
|
{
|
||||||
|
#ifdef HAVE_X11
|
||||||
|
freeX11Pixmaps();
|
||||||
|
|
||||||
|
m_emptyCornerPix = QPixmap();
|
||||||
|
m_emptyCornerBottomPix = QPixmap();
|
||||||
|
m_emptyCornerLeftPix = QPixmap();
|
||||||
|
m_emptyCornerRightPix = QPixmap();
|
||||||
|
m_emptyCornerTopPix = QPixmap();
|
||||||
|
m_emptyVerticalPix = QPixmap();
|
||||||
|
m_emptyHorizontalPix = QPixmap();
|
||||||
|
#endif
|
||||||
|
m_shadowPixmaps.clear();
|
||||||
|
data.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::updateShadow(const QWindow *window, Plasma::FrameSvg::EnabledBorders enabledBorders)
|
||||||
|
{
|
||||||
|
#ifdef HAVE_X11
|
||||||
|
if (m_shadowPixmaps.isEmpty()) {
|
||||||
|
setupPixmaps();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!data.contains(enabledBorders)) {
|
||||||
|
setupData(enabledBorders);
|
||||||
|
}
|
||||||
|
|
||||||
|
Display *dpy = QX11Info::display();
|
||||||
|
Atom atom = XInternAtom(dpy, "_KDE_NET_WM_SHADOW", False);
|
||||||
|
|
||||||
|
qDebug() << "going to set the shadow of" << window->winId() << "to" << data;
|
||||||
|
XChangeProperty(dpy, window->winId(), atom, XA_CARDINAL, 32, PropModeReplace,
|
||||||
|
reinterpret_cast<const unsigned char *>(data[enabledBorders].constData()), data[enabledBorders].size());
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void PanelShadows::Private::clearShadow(const QWindow *window)
|
||||||
|
{
|
||||||
|
#ifdef HAVE_X11
|
||||||
|
Display *dpy = QX11Info::display();
|
||||||
|
Atom atom = XInternAtom(dpy, "_KDE_NET_WM_SHADOW", False);
|
||||||
|
XDeleteProperty(dpy, window->winId(), atom);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
bool PanelShadows::enabled() const
|
||||||
|
{
|
||||||
|
return hasElement("shadow-left");
|
||||||
|
}
|
||||||
|
|
||||||
|
#include "moc_panelshadows_p.cpp"
|
||||||
|
|
52
src/shell/panelshadows_p.h
Normal file
52
src/shell/panelshadows_p.h
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2011 by Aaron Seigo <aseigo@kde.org>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Library General Public License version 2,
|
||||||
|
* or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Library General Public
|
||||||
|
* License along with this program; if not, write to the
|
||||||
|
* Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PLASMA_PANELSHADOWS_H
|
||||||
|
#define PLASMA_PANELSHADOWS_H
|
||||||
|
|
||||||
|
#include <QSet>
|
||||||
|
|
||||||
|
#include "plasma/framesvg.h"
|
||||||
|
#include "plasma/svg.h"
|
||||||
|
|
||||||
|
|
||||||
|
class PanelShadows : public Plasma::Svg
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
explicit PanelShadows(QObject *parent = 0, const QString &prefix = "widgets/panel-background");
|
||||||
|
~PanelShadows();
|
||||||
|
|
||||||
|
static PanelShadows *self();
|
||||||
|
|
||||||
|
void addWindow(const QWindow *window, Plasma::FrameSvg::EnabledBorders enabledBorders = Plasma::FrameSvg::AllBorders);
|
||||||
|
void removeWindow(const QWindow *window);
|
||||||
|
|
||||||
|
bool enabled() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
class Private;
|
||||||
|
Private * const d;
|
||||||
|
|
||||||
|
Q_PRIVATE_SLOT(d, void updateShadows())
|
||||||
|
Q_PRIVATE_SLOT(d, void windowDestroyed(QObject *deletedObject))
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
#include "panelview.h"
|
#include "panelview.h"
|
||||||
#include "desktopcorona.h"
|
#include "desktopcorona.h"
|
||||||
|
#include "panelshadows_p.h"
|
||||||
|
|
||||||
#include <QAction>
|
#include <QAction>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
@ -69,6 +70,7 @@ PanelView::PanelView(DesktopCorona *corona, QWindow *parent)
|
|||||||
engine()->rootContext()->setContextProperty("panel", this);
|
engine()->rootContext()->setContextProperty("panel", this);
|
||||||
setSource(QUrl::fromLocalFile(m_corona->package().filePath("views", "Panel.qml")));
|
setSource(QUrl::fromLocalFile(m_corona->package().filePath("views", "Panel.qml")));
|
||||||
positionPanel();
|
positionPanel();
|
||||||
|
PanelShadows::self()->addWindow(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
PanelView::~PanelView()
|
PanelView::~PanelView()
|
||||||
@ -88,6 +90,7 @@ PanelView::~PanelView()
|
|||||||
m_corona->requestApplicationConfigSync();
|
m_corona->requestApplicationConfigSync();
|
||||||
m_corona->requestApplicationConfigSync();
|
m_corona->requestApplicationConfigSync();
|
||||||
}
|
}
|
||||||
|
PanelShadows::self()->removeWindow(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
KConfigGroup PanelView::config() const
|
KConfigGroup PanelView::config() const
|
||||||
@ -401,4 +404,10 @@ void PanelView::resizeEvent(QResizeEvent *ev)
|
|||||||
View::resizeEvent(ev);
|
View::resizeEvent(ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PanelView::showEvent(QShowEvent *event)
|
||||||
|
{
|
||||||
|
PanelShadows::self()->addWindow(this);
|
||||||
|
View::showEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
#include "moc_panelview.cpp"
|
#include "moc_panelview.cpp"
|
||||||
|
@ -63,6 +63,7 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
void resizeEvent(QResizeEvent *ev);
|
void resizeEvent(QResizeEvent *ev);
|
||||||
|
void showEvent(QShowEvent *event);
|
||||||
|
|
||||||
Q_SIGNALS:
|
Q_SIGNALS:
|
||||||
void alignmentChanged();
|
void alignmentChanged();
|
||||||
|
Loading…
Reference in New Issue
Block a user