From e9ae80694875f869892f13f4fcaf1170a00dea41 Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdewebdev@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kommander/widgets/pixmaplabel.cpp | 132 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 132 insertions(+) create mode 100644 kommander/widgets/pixmaplabel.cpp (limited to 'kommander/widgets/pixmaplabel.cpp') diff --git a/kommander/widgets/pixmaplabel.cpp b/kommander/widgets/pixmaplabel.cpp new file mode 100644 index 00000000..7d7095e3 --- /dev/null +++ b/kommander/widgets/pixmaplabel.cpp @@ -0,0 +1,132 @@ +/*************************************************************************** + pixmaplabel.cpp - Pixmap label widget + ------------------- + copyright : (C) 2004 Michal Rudolf + ***************************************************************************/ + +/*************************************************************************** + * * + * 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. * + * * + ***************************************************************************/ + +/* QT INCLUDES */ +#include +#include +#include +#include +#include +#include + +/* KDE INCLUDES */ +#include +#include + +/* OTHER INCLUDES */ +#include +#include +#include "pixmaplabel.h" + +PixmapLabel::PixmapLabel(QWidget *a_parent, const char *a_name) + : QLabel(a_parent, a_name), KommanderWidget(this) +{ + QStringList states; + states << "default"; + setStates(states); + setDisplayStates(states); + if (KommanderWidget::inEditor) + setPixmap(KGlobal::iconLoader()->loadIcon("tux", KIcon::NoGroup, 128)); + setAutoResize(false); +} + +PixmapLabel::~PixmapLabel() +{ +} + +QString PixmapLabel::currentState() const +{ + return QString("default"); +} + +bool PixmapLabel::isKommanderWidget() const +{ + return true; +} + +QStringList PixmapLabel::associatedText() const +{ + return KommanderWidget::associatedText(); +} + +void PixmapLabel::setAssociatedText(const QStringList& a_at) +{ + KommanderWidget::setAssociatedText(a_at); +} + +void PixmapLabel::setPopulationText(const QString& a_text) +{ + KommanderWidget::setPopulationText(a_text); +} + +QString PixmapLabel::populationText() const +{ + return KommanderWidget::populationText(); +} + +void PixmapLabel::populate() +{ + setWidgetText(KommanderWidget::evalAssociatedText(populationText())); +} + +void PixmapLabel::setWidgetText(const QString& a_text) +{ + QPixmap pixmap; + if (pixmap.load(a_text)) + setPixmap(pixmap); +} + +void PixmapLabel::showEvent(QShowEvent *e) +{ + QLabel::showEvent(e); + emit widgetOpened(); +} + +void PixmapLabel::contextMenuEvent( QContextMenuEvent * e ) +{ + e->accept(); + QPoint p = e->globalPos(); + emit contextMenuRequested(p.x(), p.y()); +} + +bool PixmapLabel::isFunctionSupported(int f) +{ + return f == DCOP::text || f == DCOP::setText || f == DCOP::clear || f == DCOP::geometry; +} + +QString PixmapLabel::handleDCOP(int function, const QStringList& args) +{ + switch (function) { + case DCOP::setText: + setWidgetText(args[0]); + break; + case DCOP::clear: + setPixmap(QPixmap()); + break; + case DCOP::text: + return text(); + case DCOP::geometry: + { + QString geo = QString::number(this->x())+" "+QString::number(this->y())+" "+QString::number(this->width())+" "+QString::number(this->height()); + return geo; + break; + } + default: + return KommanderWidget::handleDCOP(function, args); + } + return QString(); +} + +#include "pixmaplabel.moc" -- cgit v1.2.1