mirror of
https://bitbucket.org/smil3y/kdelibs.git
synced 2025-02-24 02:42:48 +00:00
plasma: move wallpaper rendering to main thread
Signed-off-by: Ivailo Monev <xakepa10@gmail.com>
This commit is contained in:
parent
6e683d468b
commit
75af9fbb87
6 changed files with 134 additions and 383 deletions
|
@ -126,7 +126,6 @@ set(plasma_LIB_SRCS
|
||||||
private/style.cpp
|
private/style.cpp
|
||||||
private/themedwidgetinterface.cpp
|
private/themedwidgetinterface.cpp
|
||||||
private/tooltip.cpp
|
private/tooltip.cpp
|
||||||
private/wallpaperrenderthread.cpp
|
|
||||||
private/windowpreview.cpp
|
private/windowpreview.cpp
|
||||||
private/kineticscroll.cpp
|
private/kineticscroll.cpp
|
||||||
private/declarative/declarativenetworkaccessmanagerfactory.cpp
|
private/declarative/declarativenetworkaccessmanagerfactory.cpp
|
||||||
|
|
|
@ -27,7 +27,6 @@
|
||||||
|
|
||||||
#include "plasma/scripting/wallpaperscript.h"
|
#include "plasma/scripting/wallpaperscript.h"
|
||||||
#include "plasma/private/dataengineconsumer_p.h"
|
#include "plasma/private/dataengineconsumer_p.h"
|
||||||
#include "plasma/private/wallpaperrenderthread_p.h"
|
|
||||||
|
|
||||||
namespace Plasma
|
namespace Plasma
|
||||||
{
|
{
|
||||||
|
@ -44,7 +43,6 @@ public:
|
||||||
|
|
||||||
bool findInCache(const QString &key, unsigned int lastModified = 0);
|
bool findInCache(const QString &key, unsigned int lastModified = 0);
|
||||||
|
|
||||||
void newRenderCompleted(const WallpaperRenderRequest &render, const QImage &image);
|
|
||||||
void setupScriptSupport();
|
void setupScriptSupport();
|
||||||
void renderWallpaper(const QString &sourceImagePath, const QImage &image, const QSize &size,
|
void renderWallpaper(const QString &sourceImagePath, const QImage &image, const QSize &size,
|
||||||
Wallpaper::ResizeMethod resizeMethod, const QColor &color);
|
Wallpaper::ResizeMethod resizeMethod, const QColor &color);
|
||||||
|
|
|
@ -1,269 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2007 Paolo Capriotti <p.capriotti@gmail.com>
|
|
||||||
* Copyright (c) 2009 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 as
|
|
||||||
* published by the Free Software Foundation; either 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 "plasma/private/wallpaperrenderthread_p.h"
|
|
||||||
|
|
||||||
#include <QCoreApplication>
|
|
||||||
#include <QPainter>
|
|
||||||
#include <QFile>
|
|
||||||
#include <QSvgRenderer>
|
|
||||||
|
|
||||||
#include "config-plasma.h"
|
|
||||||
#ifndef PLASMA_NO_SOLID
|
|
||||||
#include <solid/device.h>
|
|
||||||
#include <solid/deviceinterface.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <kdebug.h>
|
|
||||||
|
|
||||||
namespace Plasma
|
|
||||||
{
|
|
||||||
|
|
||||||
int WallpaperRenderRequest::s_token = 0;
|
|
||||||
int WallpaperRenderThread::s_rendererCount = 0;
|
|
||||||
QQueue<WallpaperRenderRequest> WallpaperRenderThread::s_renderQueue;
|
|
||||||
|
|
||||||
WallpaperRenderThread::WallpaperRenderThread(const WallpaperRenderRequest &request, QObject *parent)
|
|
||||||
: QThread(parent),
|
|
||||||
m_request(request),
|
|
||||||
m_abort(false)
|
|
||||||
{
|
|
||||||
qRegisterMetaType<WallpaperRenderRequest>("WallpaperRenderRequest");
|
|
||||||
if (!request.requester) {
|
|
||||||
deleteLater();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
++s_rendererCount;
|
|
||||||
connect(this, SIGNAL(done(WallpaperRenderRequest,QImage)),
|
|
||||||
request.requester.data(), SLOT(newRenderCompleted(WallpaperRenderRequest,QImage)));
|
|
||||||
}
|
|
||||||
|
|
||||||
WallpaperRenderThread::~WallpaperRenderThread()
|
|
||||||
{
|
|
||||||
kDebug() << "rendering done";
|
|
||||||
m_abort = true;
|
|
||||||
wait();
|
|
||||||
--s_rendererCount;
|
|
||||||
checkQueue();
|
|
||||||
}
|
|
||||||
|
|
||||||
void WallpaperRenderThread::render(const WallpaperRenderRequest &request)
|
|
||||||
{
|
|
||||||
QObject *requester = request.requester.data();
|
|
||||||
if (!requester) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// remove all dead requests and requests previously made for the same parent
|
|
||||||
QMutableListIterator<WallpaperRenderRequest> it(s_renderQueue);
|
|
||||||
while (it.hasNext()) {
|
|
||||||
const WallpaperRenderRequest &request = it.next();
|
|
||||||
|
|
||||||
if (!request.requester || request.requester.data() == requester) {
|
|
||||||
it.remove();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
s_renderQueue.append(request);
|
|
||||||
checkQueue();
|
|
||||||
}
|
|
||||||
|
|
||||||
void WallpaperRenderThread::checkQueue()
|
|
||||||
{
|
|
||||||
if (s_renderQueue.isEmpty()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (QCoreApplication::closingDown()) {
|
|
||||||
s_renderQueue.clear();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef PLASMA_NO_SOLID
|
|
||||||
const int numProcs = qMax(1, Solid::Device::listFromType(Solid::DeviceInterface::Processor).count());
|
|
||||||
#else
|
|
||||||
const int numProcs = 1;
|
|
||||||
#endif
|
|
||||||
kDebug() << "checking rendering against" << s_rendererCount << numProcs;
|
|
||||||
if (s_rendererCount < numProcs) {
|
|
||||||
WallpaperRenderThread *renderThread = new WallpaperRenderThread(s_renderQueue.dequeue());
|
|
||||||
renderThread->start();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void WallpaperRenderThread::run()
|
|
||||||
{
|
|
||||||
kDebug() << "rendering wallpaper" << m_request.file;
|
|
||||||
QImage result(m_request.size, QImage::Format_ARGB32_Premultiplied);
|
|
||||||
result.fill(m_request.color.rgba());
|
|
||||||
|
|
||||||
if (m_request.file.isEmpty() && m_request.providedImage.isNull() && !QFile::exists(m_request.file)) {
|
|
||||||
if (!m_abort) {
|
|
||||||
emit done(m_request, result);
|
|
||||||
}
|
|
||||||
|
|
||||||
kDebug() << "wrong request or file does not exist";
|
|
||||||
deleteLater();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
QPoint pos(0, 0);
|
|
||||||
//const float ratio = qMax(float(1), m_request.size.width() / float(m_request.size.height()));
|
|
||||||
const bool scalable = m_request.file.endsWith(QLatin1String("svg")) || m_request.file.endsWith(QLatin1String("svgz"));
|
|
||||||
bool tiled = false;
|
|
||||||
QSize scaledSize;
|
|
||||||
QImage img;
|
|
||||||
|
|
||||||
// set image size
|
|
||||||
QSize imgSize(1, 1);
|
|
||||||
if (!m_request.providedImage.isNull()) {
|
|
||||||
img = m_request.providedImage;
|
|
||||||
kDebug() << "going to resize the img" << img.size();
|
|
||||||
imgSize = imgSize.expandedTo(img.size());
|
|
||||||
} else if (scalable) {
|
|
||||||
// scalable: image can be of any size
|
|
||||||
imgSize = imgSize.expandedTo(m_request.size);
|
|
||||||
} else {
|
|
||||||
// otherwise, use the natural size of the loaded image
|
|
||||||
img = QImage(m_request.file);
|
|
||||||
imgSize = imgSize.expandedTo(img.size());
|
|
||||||
//kDebug() << "loaded with" << imgSize << ratio;
|
|
||||||
}
|
|
||||||
|
|
||||||
// set render parameters according to resize mode
|
|
||||||
switch (m_request.resizeMethod)
|
|
||||||
{
|
|
||||||
case Wallpaper::ScaledResize:
|
|
||||||
scaledSize = m_request.size;
|
|
||||||
break;
|
|
||||||
case Wallpaper::CenteredResize:
|
|
||||||
scaledSize = imgSize;
|
|
||||||
pos = QPoint((m_request.size.width() - scaledSize.width()) / 2,
|
|
||||||
(m_request.size.height() - scaledSize.height()) / 2);
|
|
||||||
|
|
||||||
//If the picture is bigger than the screen, shrink it
|
|
||||||
if (m_request.size.width() < imgSize.width() && imgSize.width() > imgSize.height()) {
|
|
||||||
int width = m_request.size.width();
|
|
||||||
int height = width * scaledSize.height() / imgSize.width();
|
|
||||||
scaledSize = QSize(width, height);
|
|
||||||
pos = QPoint((m_request.size.width() - scaledSize.width()) / 2,
|
|
||||||
(m_request.size.height() - scaledSize.height()) / 2);
|
|
||||||
} else if (m_request.size.height() < imgSize.height()) {
|
|
||||||
int height = m_request.size.height();
|
|
||||||
int width = height * imgSize.width() / imgSize.height();
|
|
||||||
scaledSize = QSize(width, height);
|
|
||||||
pos = QPoint((m_request.size.width() - scaledSize.width()) / 2,
|
|
||||||
(m_request.size.height() - scaledSize.height()) / 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
case Wallpaper::MaxpectResize: {
|
|
||||||
float xratio = (float) m_request.size.width() / imgSize.width();
|
|
||||||
float yratio = (float) m_request.size.height() / imgSize.height();
|
|
||||||
if (xratio > yratio) {
|
|
||||||
int height = m_request.size.height();
|
|
||||||
int width = height * imgSize.width() / imgSize.height();
|
|
||||||
scaledSize = QSize(width, height);
|
|
||||||
} else {
|
|
||||||
int width = m_request.size.width();
|
|
||||||
int height = width * imgSize.height() / imgSize.width();
|
|
||||||
scaledSize = QSize(width, height);
|
|
||||||
}
|
|
||||||
|
|
||||||
pos = QPoint((m_request.size.width() - scaledSize.width()) / 2,
|
|
||||||
(m_request.size.height() - scaledSize.height()) / 2);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case Wallpaper::ScaledAndCroppedResize: {
|
|
||||||
float xratio = (float) m_request.size.width() / imgSize.width();
|
|
||||||
float yratio = (float) m_request.size.height() / imgSize.height();
|
|
||||||
if (xratio > yratio) {
|
|
||||||
int width = m_request.size.width();
|
|
||||||
int height = width * imgSize.height() / imgSize.width();
|
|
||||||
scaledSize = QSize(width, height);
|
|
||||||
} else {
|
|
||||||
int height = m_request.size.height();
|
|
||||||
int width = height * imgSize.width() / imgSize.height();
|
|
||||||
scaledSize = QSize(width, height);
|
|
||||||
}
|
|
||||||
pos = QPoint((m_request.size.width() - scaledSize.width()) / 2,
|
|
||||||
(m_request.size.height() - scaledSize.height()) / 2);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case Wallpaper::TiledResize:
|
|
||||||
scaledSize = imgSize;
|
|
||||||
tiled = true;
|
|
||||||
break;
|
|
||||||
case Wallpaper::CenterTiledResize:
|
|
||||||
scaledSize = imgSize;
|
|
||||||
pos = QPoint(-scaledSize.width() + ((m_request.size.width() - scaledSize.width()) / 2) % scaledSize.width(),
|
|
||||||
-scaledSize.height() + ((m_request.size.height() - scaledSize.height()) / 2) % scaledSize.height());
|
|
||||||
tiled = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
QPainter p(&result);
|
|
||||||
//kDebug() << token << scalable << scaledSize << imgSize;
|
|
||||||
if (scalable) {
|
|
||||||
// tiling is ignored for scalable wallpapers
|
|
||||||
QSvgRenderer svg(m_request.file);
|
|
||||||
if (m_abort) {
|
|
||||||
deleteLater();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
svg.render(&p);
|
|
||||||
} else {
|
|
||||||
if (scaledSize != imgSize) {
|
|
||||||
img = img.scaled(scaledSize, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_abort) {
|
|
||||||
deleteLater();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tiled) {
|
|
||||||
for (int x = pos.x(); x < m_request.size.width(); x += scaledSize.width()) {
|
|
||||||
for (int y = pos.y(); y < m_request.size.height(); y += scaledSize.height()) {
|
|
||||||
p.drawImage(QPoint(x, y), img);
|
|
||||||
if (m_abort) {
|
|
||||||
deleteLater();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
p.drawImage(pos, img);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// signal we're done
|
|
||||||
if (!m_abort) {
|
|
||||||
emit done(m_request, result);
|
|
||||||
}
|
|
||||||
|
|
||||||
deleteLater();
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace Plasma
|
|
||||||
|
|
||||||
#include "moc_wallpaperrenderthread_p.cpp"
|
|
||||||
|
|
|
@ -1,83 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2007 Paolo Capriotti <p.capriotti@gmail.com>
|
|
||||||
* Copyright (c) 2009 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 as
|
|
||||||
* published by the Free Software Foundation; either 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_WALLPAPERRENDERTHREAD_P_H
|
|
||||||
#define PLASMA_WALLPAPERRENDERTHREAD_P_H
|
|
||||||
|
|
||||||
#include <QColor>
|
|
||||||
#include <QImage>
|
|
||||||
#include <QMutex>
|
|
||||||
#include <QQueue>
|
|
||||||
#include <QThread>
|
|
||||||
#include <QWaitCondition>
|
|
||||||
|
|
||||||
#include "plasma/wallpaper.h"
|
|
||||||
|
|
||||||
namespace Plasma
|
|
||||||
{
|
|
||||||
|
|
||||||
class WallpaperRenderRequest
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
WallpaperRenderRequest()
|
|
||||||
: token(++s_token)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
QWeakPointer<QObject> requester;
|
|
||||||
QImage providedImage;
|
|
||||||
QString file;
|
|
||||||
QSize size;
|
|
||||||
Wallpaper::ResizeMethod resizeMethod;
|
|
||||||
QColor color;
|
|
||||||
int token;
|
|
||||||
|
|
||||||
static int s_token;
|
|
||||||
};
|
|
||||||
|
|
||||||
class WallpaperRenderThread : public QThread
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
public:
|
|
||||||
WallpaperRenderThread(const WallpaperRenderRequest &request, QObject *parent = 0);
|
|
||||||
virtual ~WallpaperRenderThread();
|
|
||||||
|
|
||||||
static void render(const WallpaperRenderRequest &request);
|
|
||||||
|
|
||||||
Q_SIGNALS:
|
|
||||||
void done(const WallpaperRenderRequest &request, const QImage &image);
|
|
||||||
|
|
||||||
protected:
|
|
||||||
virtual void run();
|
|
||||||
|
|
||||||
private:
|
|
||||||
static void checkQueue();
|
|
||||||
WallpaperRenderRequest m_request;
|
|
||||||
|
|
||||||
bool m_abort;
|
|
||||||
static int s_rendererCount;
|
|
||||||
static QQueue<WallpaperRenderRequest> s_renderQueue;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace Plasma
|
|
||||||
|
|
||||||
Q_DECLARE_METATYPE(Plasma::WallpaperRenderRequest)
|
|
||||||
#endif // PLASMA_WALLPAPERRENDERTHREAD_P_H
|
|
|
@ -31,6 +31,8 @@
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <QRunnable>
|
#include <QRunnable>
|
||||||
#include <QThreadPool>
|
#include <QThreadPool>
|
||||||
|
#include <QPainter>
|
||||||
|
#include <QSvgRenderer>
|
||||||
|
|
||||||
#include <kdebug.h>
|
#include <kdebug.h>
|
||||||
#include <kglobal.h>
|
#include <kglobal.h>
|
||||||
|
@ -480,16 +482,138 @@ void WallpaperPrivate::renderWallpaper(const QString &sourceImagePath, const QIm
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
WallpaperRenderRequest request;
|
kDebug() << "rendering wallpaper" << sourceImagePath;
|
||||||
renderToken = request.token;
|
QImage result(size, QImage::Format_ARGB32_Premultiplied);
|
||||||
request.requester = q;
|
result.fill(color.rgba());
|
||||||
request.providedImage = image;
|
|
||||||
request.file = sourceImagePath;
|
if (sourceImagePath.isEmpty() && image.isNull() && !QFile::exists(sourceImagePath)) {
|
||||||
request.size = size;
|
kDebug() << "wrong request or file does not exist";
|
||||||
request.resizeMethod = resizeMethod;
|
return;
|
||||||
request.color = color;
|
}
|
||||||
WallpaperRenderThread::render(request);
|
|
||||||
//kDebug() << "rendering" << sourceImagePath << ", token is" << d->renderToken;
|
QPoint pos(0, 0);
|
||||||
|
//const float ratio = qMax(float(1), size.width() / float(size.height()));
|
||||||
|
const bool scalable = sourceImagePath.endsWith(QLatin1String("svg")) || sourceImagePath.endsWith(QLatin1String("svgz"));
|
||||||
|
bool tiled = false;
|
||||||
|
QSize scaledSize;
|
||||||
|
QImage img;
|
||||||
|
|
||||||
|
// set image size
|
||||||
|
QSize imgSize(1, 1);
|
||||||
|
if (!image.isNull()) {
|
||||||
|
img = image;
|
||||||
|
kDebug() << "going to resize the img" << img.size();
|
||||||
|
imgSize = imgSize.expandedTo(img.size());
|
||||||
|
} else if (scalable) {
|
||||||
|
// scalable: image can be of any size
|
||||||
|
imgSize = imgSize.expandedTo(size);
|
||||||
|
} else {
|
||||||
|
// otherwise, use the natural size of the loaded image
|
||||||
|
img = QImage(sourceImagePath);
|
||||||
|
imgSize = imgSize.expandedTo(img.size());
|
||||||
|
//kDebug() << "loaded with" << imgSize << ratio;
|
||||||
|
}
|
||||||
|
|
||||||
|
// set render parameters according to resize mode
|
||||||
|
switch (resizeMethod)
|
||||||
|
{
|
||||||
|
case Wallpaper::ScaledResize:
|
||||||
|
scaledSize = size;
|
||||||
|
break;
|
||||||
|
case Wallpaper::CenteredResize:
|
||||||
|
scaledSize = imgSize;
|
||||||
|
pos = QPoint((size.width() - scaledSize.width()) / 2,
|
||||||
|
(size.height() - scaledSize.height()) / 2);
|
||||||
|
|
||||||
|
//If the picture is bigger than the screen, shrink it
|
||||||
|
if (size.width() < imgSize.width() && imgSize.width() > imgSize.height()) {
|
||||||
|
int width = size.width();
|
||||||
|
int height = width * scaledSize.height() / imgSize.width();
|
||||||
|
scaledSize = QSize(width, height);
|
||||||
|
pos = QPoint((size.width() - scaledSize.width()) / 2,
|
||||||
|
(size.height() - scaledSize.height()) / 2);
|
||||||
|
} else if (size.height() < imgSize.height()) {
|
||||||
|
int height = size.height();
|
||||||
|
int width = height * imgSize.width() / imgSize.height();
|
||||||
|
scaledSize = QSize(width, height);
|
||||||
|
pos = QPoint((size.width() - scaledSize.width()) / 2,
|
||||||
|
(size.height() - scaledSize.height()) / 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
case Wallpaper::MaxpectResize: {
|
||||||
|
float xratio = (float) size.width() / imgSize.width();
|
||||||
|
float yratio = (float) size.height() / imgSize.height();
|
||||||
|
if (xratio > yratio) {
|
||||||
|
int height = size.height();
|
||||||
|
int width = height * imgSize.width() / imgSize.height();
|
||||||
|
scaledSize = QSize(width, height);
|
||||||
|
} else {
|
||||||
|
int width = size.width();
|
||||||
|
int height = width * imgSize.height() / imgSize.width();
|
||||||
|
scaledSize = QSize(width, height);
|
||||||
|
}
|
||||||
|
|
||||||
|
pos = QPoint((size.width() - scaledSize.width()) / 2,
|
||||||
|
(size.height() - scaledSize.height()) / 2);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Wallpaper::ScaledAndCroppedResize: {
|
||||||
|
float xratio = (float) size.width() / imgSize.width();
|
||||||
|
float yratio = (float) size.height() / imgSize.height();
|
||||||
|
if (xratio > yratio) {
|
||||||
|
int width = size.width();
|
||||||
|
int height = width * imgSize.height() / imgSize.width();
|
||||||
|
scaledSize = QSize(width, height);
|
||||||
|
} else {
|
||||||
|
int height = size.height();
|
||||||
|
int width = height * imgSize.width() / imgSize.height();
|
||||||
|
scaledSize = QSize(width, height);
|
||||||
|
}
|
||||||
|
pos = QPoint((size.width() - scaledSize.width()) / 2,
|
||||||
|
(size.height() - scaledSize.height()) / 2);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Wallpaper::TiledResize:
|
||||||
|
scaledSize = imgSize;
|
||||||
|
tiled = true;
|
||||||
|
break;
|
||||||
|
case Wallpaper::CenterTiledResize:
|
||||||
|
scaledSize = imgSize;
|
||||||
|
pos = QPoint(-scaledSize.width() + ((size.width() - scaledSize.width()) / 2) % scaledSize.width(),
|
||||||
|
-scaledSize.height() + ((size.height() - scaledSize.height()) / 2) % scaledSize.height());
|
||||||
|
tiled = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
QPainter p(&result);
|
||||||
|
//kDebug() << token << scalable << scaledSize << imgSize;
|
||||||
|
if (scalable) {
|
||||||
|
// tiling is ignored for scalable wallpapers
|
||||||
|
QSvgRenderer svg(sourceImagePath);
|
||||||
|
svg.render(&p);
|
||||||
|
} else {
|
||||||
|
if (scaledSize != imgSize) {
|
||||||
|
img = img.scaled(scaledSize, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tiled) {
|
||||||
|
for (int x = pos.x(); x < size.width(); x += scaledSize.width()) {
|
||||||
|
for (int y = pos.y(); y < size.height(); y += scaledSize.height()) {
|
||||||
|
p.drawImage(QPoint(x, y), img);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.drawImage(pos, img);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cacheRendering) {
|
||||||
|
q->insertIntoCache(cacheKey(sourceImagePath, size, resizeMethod, color), result);
|
||||||
|
}
|
||||||
|
|
||||||
|
//kDebug() << "rendering complete!";
|
||||||
|
emit q->renderCompleted(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
WallpaperPrivate::WallpaperPrivate(KService::Ptr service, Wallpaper *wallpaper) :
|
WallpaperPrivate::WallpaperPrivate(KService::Ptr service, Wallpaper *wallpaper) :
|
||||||
|
@ -542,22 +666,6 @@ QString WallpaperPrivate::cachePath(const QString &key) const
|
||||||
return KGlobal::dirs()->locateLocal("cache", "plasma-wallpapers/" + key + ".png");
|
return KGlobal::dirs()->locateLocal("cache", "plasma-wallpapers/" + key + ".png");
|
||||||
}
|
}
|
||||||
|
|
||||||
void WallpaperPrivate::newRenderCompleted(const WallpaperRenderRequest &request, const QImage &image)
|
|
||||||
{
|
|
||||||
kDebug() << request.token << renderToken;
|
|
||||||
if (request.token != renderToken) {
|
|
||||||
//kDebug() << "render token mismatch" << token << renderToken;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cacheRendering) {
|
|
||||||
q->insertIntoCache(cacheKey(request.file, request.size, request.resizeMethod, request.color), image);
|
|
||||||
}
|
|
||||||
|
|
||||||
//kDebug() << "rendering complete!";
|
|
||||||
emit q->renderCompleted(image);
|
|
||||||
}
|
|
||||||
|
|
||||||
// put all setup routines for script here. at this point we can assume that
|
// put all setup routines for script here. at this point we can assume that
|
||||||
// package exists and that we have a script engine
|
// package exists and that we have a script engine
|
||||||
void WallpaperPrivate::setupScriptSupport()
|
void WallpaperPrivate::setupScriptSupport()
|
||||||
|
|
|
@ -565,8 +565,6 @@ class PLASMA_EXPORT Wallpaper : public QObject
|
||||||
void setPreviewDuringConfiguration(const bool preview);
|
void setPreviewDuringConfiguration(const bool preview);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Q_PRIVATE_SLOT(d, void newRenderCompleted(const WallpaperRenderRequest &request,
|
|
||||||
const QImage &image))
|
|
||||||
Q_PRIVATE_SLOT(d, void initScript())
|
Q_PRIVATE_SLOT(d, void initScript())
|
||||||
|
|
||||||
friend class WallpaperPackage;
|
friend class WallpaperPackage;
|
||||||
|
|
Loading…
Add table
Reference in a new issue