You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
twin-style-crystal/client/myrootpixmap.cpp

259 lines
6.3 KiB

/*
*
* $Id: krootpixmap.cpp,v 1.20 2003/06/01 01:49:31 hadacek Exp $
*
* This file is part of the KDE project, module tdeui.
* Copyright (C) 1999,2000 Geert Jansen <jansen@kde.org>
*
* You can Freely distribute this program under the GNU Library
* General Public License. See the file "COPYING.LIB" for the exact
* licensing terms.
*/
/* Modified by Sascha Hlusiak */
/* Further modified 11/18/2014 by Timothy Pearson <kb9vqf@pearsoncomputing.net> */
#include <tqwidget.h>
#include <tqtimer.h>
#include <tqrect.h>
#include <tqimage.h>
#ifndef TQ_WS_TQWS //FIXME
#include <tdeapplication.h>
#include <kimageeffect.h>
#include <kpixmapio.h>
#include <netwm.h>
#include <twin.h>
#include <kdebug.h>
#include <netwm.h>
#include <dcopclient.h>
#include <dcopref.h>
#include <tqpainter.h>
#include <ksharedpixmap.h>
#include "myrootpixmap.h"
static TQString wallpaperForDesktop(int desktop)
{
return DCOPRef("kdesktop", "KBackgroundIface").call("currentWallpaper", desktop);
}
DesktopWallpaperWatcher::DesktopWallpaperWatcher() : TQWidget(), m_old_current_desktop(-1)
{
kapp->installX11EventFilter( this );
(void ) kapp->desktop(); //trigger desktop widget creation to select root window events
}
DesktopWallpaperWatcher::~DesktopWallpaperWatcher()
{
}
bool DesktopWallpaperWatcher::x11Event( XEvent * ev )
{
if ( ev->xany.window == tqt_xrootwin() ) {
NETRootInfo rinfo( tqt_xdisplay(), NET::CurrentDesktop );
rinfo.activate();
if ( rinfo.currentDesktop() != m_old_current_desktop ) {
emit currentDesktopChanged( rinfo.currentDesktop() );
}
m_old_current_desktop = rinfo.currentDesktop();
}
return false;
}
class KMyRootPixmapData
{
public:
#ifdef Q_WS_X11
DesktopWallpaperWatcher *twin;
#endif
};
KMyRootPixmap::KMyRootPixmap( TQWidget * widget, const char *name )
: TQObject(widget, name ? name : "KMyRootPixmap" )
{
init();
}
KMyRootPixmap::KMyRootPixmap( TQWidget *, TQObject *parent, const char *name )
: TQObject( parent, name ? name : "KMyRootPixmap" )
{
init();
}
void KMyRootPixmap::init()
{
d = new KMyRootPixmapData;
// m_Fade = 0;
12 years ago
m_pPixmap = new TDESharedPixmap;
// m_pTimer = new TQTimer( this );
m_bInit = false;
m_bActive = false;
m_Desk=-1;
// m_bCustomPaint = false;
// connect(kapp, TQT_SIGNAL(backgroundChanged(int)), TQT_SLOT(slotBackgroundChanged(int)));
connect(m_pPixmap, TQT_SIGNAL(done(bool)), TQT_SLOT(slotDone(bool)));
// connect(m_pTimer, TQT_SIGNAL(timeout()), TQT_SLOT(repaint()));
#ifdef Q_WS_X11
d->twin = new DesktopWallpaperWatcher();
connect(d->twin, TQT_SIGNAL(currentDesktopChanged(int)), TQT_SLOT(desktopChanged(int)));
#endif
// d->toplevel = m_pWidget->topLevelWidget();
// d->toplevel->installEventFilter(this);
}
KMyRootPixmap::~KMyRootPixmap()
{
delete m_pPixmap;
delete d;
}
void KMyRootPixmap::desktopChanged(int desktop)
{
if (wallpaperForDesktop(m_Desk) == wallpaperForDesktop(desktop) &&
!wallpaperForDesktop(m_Desk).isNull())
return;
// #ifdef Q_WS_X11
// if (KWin::windowInfo(m_pWidget->topLevelWidget()->winId()).desktop() == NET::OnAllDesktops &&
// pixmapName(m_Desk) != pixmapName(desktop))
// #endif
repaint(true);
}
int KMyRootPixmap::currentDesktop() const
{
NETRootInfo rinfo( tqt_xdisplay(), NET::CurrentDesktop );
rinfo.activate();
return rinfo.currentDesktop();
}
void KMyRootPixmap::start()
{
if (m_bActive)
return;
m_bActive = true;
enableExports();
return;
// if (m_bInit)
// repaint(true);
}
void KMyRootPixmap::stop()
{
m_bActive = false;
// m_pTimer->stop();
}
void KMyRootPixmap::repaint()
{
repaint(false);
}
void KMyRootPixmap::repaint(bool force)
{
// printf("KMyRootPixmap::repaint(%s)\n",force?"true":"false");
if ((!force) && (m_Desk==currentDesktop()))return;
m_Desk = currentDesktop();
if (!isAvailable())
{
emit backgroundUpdated(NULL);
}else{
12 years ago
// TDESharedPixmap will correctly generate a tile for us.
m_pPixmap->loadFromShared(pixmapName(m_Desk));
updateBackground( m_pPixmap );
}
}
bool KMyRootPixmap::isAvailable()
{
return m_pPixmap->isAvailable(pixmapName(m_Desk));
}
TQString KMyRootPixmap::pixmapName(int desk)
{
TQString pattern = TQString("DESKTOP%1");
int screen_number = DefaultScreen(tqt_xdisplay());
if (screen_number) {
pattern = TQString("SCREEN%1-DESKTOP").arg(screen_number) + "%1";
}
return pattern.arg( desk );
}
void KMyRootPixmap::enableExports()
{
// kdDebug(270) << k_lineinfo << "activating background exports.\n";
DCOPClient *client = kapp->dcopClient();
if (!client->isAttached())
client->attach();
TQByteArray data;
TQDataStream args( data, IO_WriteOnly );
args << 1;
TQCString appname( "kdesktop" );
int screen_number = DefaultScreen(tqt_xdisplay());
if ( screen_number )
appname.sprintf("kdesktop-screen-%d", screen_number );
client->send( appname, "KBackgroundIface", "setExport(int)", data );
}
void KMyRootPixmap::slotDone(bool success)
{
if (!success)
{
// kdWarning(270) << k_lineinfo << "loading of desktop background failed.\n";
return;
}
// We need to test active as the pixmap might become available
// after the widget has been destroyed.
if ( m_bActive )
updateBackground( m_pPixmap );
}
12 years ago
void KMyRootPixmap::updateBackground( TDESharedPixmap *spm )
{
// printf("KMyRootPixmap::updateBackground(%p)\n",spm);
TQPixmap *px=spm;
if (px->isNull() || px->width()==0 || px->height()==0)
{ // This is NOT an image, something went wrong, update to plain
emit backgroundUpdated(NULL);
return;
}
KPixmapIO io;
TQSize desktopsize(TQApplication::desktop()->width(),TQApplication::desktop()->height());
if (px->rect().size()==desktopsize)
{ // Image has already the right dimension, make a quick update
TQImage img = io.convertToImage(*spm);
emit backgroundUpdated(&img);
return;
}else{ // we need to create a tiled pixmap and then the image to update
TQPixmap pix(desktopsize,spm->TQPixmap::depth());
TQPainter pufferPainter(&pix);
pufferPainter.drawTiledPixmap(pix.rect(),*spm);
pufferPainter.end();
TQImage img=io.convertToImage(pix);
emit backgroundUpdated(&img);
}
}
#include "myrootpixmap.moc"
#endif