kwin/kcmkwin/kwintabbox/thumbnailitem.cpp
Martin Gräßlin 19d567ef7f [kcm-kwintabbox] Use QQuickItem for Thumbnail instead of QQuickPaintedItem
We are only rendering an image, so it's better to load the image into a
texture. This allows to properly scale the example preview which
magically fixes all the layouting problems which used to be there.
2014-01-03 14:10:17 +01:00

101 lines
3.1 KiB
C++

/********************************************************************
KWin - the KDE window manager
This file is part of the KDE project.
Copyright (C) 2011 Martin Gräßlin <mgraesslin@kde.org>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, 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 General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*********************************************************************/
#include "thumbnailitem.h"
// Qt
#include <QtCore/QStandardPaths>
#include <QQuickWindow>
#include <QSGSimpleTextureNode>
namespace KWin
{
WindowThumbnailItem::WindowThumbnailItem(QQuickItem* parent)
: QQuickItem(parent)
, m_wId(0)
, m_image()
, m_clipToItem(nullptr)
{
setFlag(ItemHasContents);
}
WindowThumbnailItem::~WindowThumbnailItem()
{
}
void WindowThumbnailItem::setWId(qulonglong wId)
{
m_wId = wId;
emit wIdChanged(wId);
findImage();
}
void WindowThumbnailItem::setClipTo(QQuickItem *clip)
{
if (m_clipToItem == clip) {
return;
}
m_clipToItem = clip;
emit clipToChanged();
}
void WindowThumbnailItem::findImage()
{
QString imagePath;
switch (m_wId) {
case Konqueror:
imagePath = QStandardPaths::locate(QStandardPaths::GenericDataLocation, "kwin/kcm_kwintabbox/konqueror.png");
break;
case Systemsettings:
imagePath = QStandardPaths::locate(QStandardPaths::GenericDataLocation, "kwin/kcm_kwintabbox/systemsettings.png");
break;
case KMail:
imagePath = QStandardPaths::locate(QStandardPaths::GenericDataLocation, "kwin/kcm_kwintabbox/kmail.png");
break;
case Dolphin:
imagePath = QStandardPaths::locate(QStandardPaths::GenericDataLocation, "kwin/kcm_kwintabbox/dolphin.png");
break;
default:
// ignore
break;
}
if (imagePath.isNull()) {
m_image = QImage();
} else {
m_image = QImage(imagePath);
}
}
QSGNode *WindowThumbnailItem::updatePaintNode(QSGNode *oldNode, UpdatePaintNodeData *updatePaintNodeData)
{
Q_UNUSED(updatePaintNodeData)
QSGSimpleTextureNode *node = static_cast<QSGSimpleTextureNode*>(oldNode);
if (!node) {
node = new QSGSimpleTextureNode();
node->setFiltering(QSGTexture::Linear);
node->setTexture(window()->createTextureFromImage(m_image));
}
const QSize size(node->texture()->textureSize().scaled(boundingRect().size().toSize(), Qt::KeepAspectRatio));
const qreal x = boundingRect().x() + (boundingRect().width() - size.width())/2;
const qreal y = boundingRect().y() + (boundingRect().height() - size.height())/2;
node->setRect(QRectF(QPointF(x, y), size));
return node;
}
} // namespace KWin