/* * Copyright 2007 by Aaron Seigo * * 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 "desktoptoolbox_p.h" #include #include #include #include #include "widgets/widget.h" namespace Plasma { // used with QGrahphicsItem::setData static const int ToolName = 7001; DesktopToolbox::DesktopToolbox(QGraphicsItem *parent) : QGraphicsItem(parent), m_icon("plasma"), m_size(50), m_showing(false), m_animId(0), m_animFrame(0) { setAcceptsHoverEvents(true); setZValue(10000); setFlag(ItemClipsToShape, true); setFlag(ItemClipsChildrenToShape, false); connect(Plasma::Phase::self(), SIGNAL(movementComplete(QGraphicsItem*)), this, SLOT(toolMoved(QGraphicsItem*))); } /*QRectF DesktopToolbox::sizeHint() const { return boundingRect(); }*/ QRectF DesktopToolbox::boundingRect() const { return QRectF(0, 0, m_size*2, m_size*2); } void DesktopToolbox::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { Q_UNUSED(option) Q_UNUSED(widget) QPainterPath p = shape(); QRadialGradient gradient(QPoint(m_size*2, 0), m_size*3); gradient.setFocalPoint(QPointF(m_size*2, 0)); gradient.setColorAt(0, QColor(255, 255, 255, 96)); gradient.setColorAt(.33, QColor(128, 128, 128, 96)); gradient.setColorAt(.66, QColor(128, 128, 128, 0)); painter->save(); painter->setPen(Qt::NoPen); painter->setRenderHint(QPainter::Antialiasing, true); painter->setBrush(gradient); painter->drawPath(p); painter->restore(); m_icon.paint(painter, QRect(m_size*2 - 34, 2, 32, 32)); } QPainterPath DesktopToolbox::shape() const { QPainterPath path; int size = m_size + m_animFrame; path.moveTo(m_size*2, 0); path.arcTo(QRectF(m_size*2 - size, -size, size*2, size*2), 180, 90); return path; } void DesktopToolbox::hoverEnterEvent(QGraphicsSceneHoverEvent *event) { // Plasma::Phase::self()->moveItem(this, Phase::SlideIn, QPoint(-25, -25)); int x = -35; // pos().x(); int y = 0; // pos().y(); Plasma::Phase* phase = Plasma::Phase::self(); foreach (QGraphicsItem* tool, QGraphicsItem::children()) { if (!tool->isEnabled()) { continue; } //kDebug() << "let's show and move" << tool << tool->boundingRect(); tool->show(); phase->moveItem(tool, Plasma::Phase::SlideIn, QPoint(x, y)); //x += 0; y += static_cast(tool->boundingRect().height()) + 5; } if (m_animId) { phase->stopCustomAnimation(m_animId); } m_showing = true; // TODO: 10 and 200 shouldn't be hardcoded here. There needs to be a way to // match whatever the time is that moveItem() takes. Same in hoverLeaveEvent(). m_animId = phase->customAnimation(10, 250, Plasma::Phase::EaseInCurve, this, "animate"); QGraphicsItem::hoverEnterEvent(event); } void DesktopToolbox::hoverLeaveEvent(QGraphicsSceneHoverEvent *event) { // Plasma::Phase::self->moveItem(this, Phase::SlideOut, boundingRect()QPoint(-50, -50)); int x = 0; // pos().x() + geometry().width(); int y = 0; Plasma::Phase* phase = Plasma::Phase::self(); foreach (QGraphicsItem* tool, QGraphicsItem::children()) { if (!tool->isEnabled()) { tool->hide(); continue; } phase->moveItem(tool, Plasma::Phase::SlideOut, QPoint(x, y)); } if (m_animId) { phase->stopCustomAnimation(m_animId); } m_showing = false; m_animId = phase->customAnimation(10, 250, Plasma::Phase::EaseOutCurve, this, "animate"); QGraphicsItem::hoverLeaveEvent(event); } void DesktopToolbox::animate(qreal progress) { if (m_showing) { m_animFrame = static_cast(m_size * progress); } else { m_animFrame = static_cast(m_size * (1.0 - progress)); } //kDebug() << "animating at" << progress << "for" << m_animFrame; if (progress >= 1) { m_animId = 0; } update(); } void DesktopToolbox::toolMoved(QGraphicsItem *item) { //kDebug() << "geometry is now " << static_cast(item)->geometry(); if (!m_showing && QGraphicsItem::children().indexOf(static_cast(item)) != -1) { item->hide(); } } void DesktopToolbox::addTool(QGraphicsItem *tool, const QString &name) { if (!tool) { return; } tool->hide(); tool->setPos(QPoint(0,0)); tool->setZValue(zValue() + 1); tool->setParentItem(this); tool->setData(ToolName, name); } void DesktopToolbox::enableTool(const QString &toolName, bool visible) { //kDebug() << (visible? "enabling" : "disabling") << "tool" << toolName; QGraphicsItem *t = tool(toolName); if (t) { t->setEnabled(visible); } } bool DesktopToolbox::isToolEnabled(const QString &toolName) const { QGraphicsItem *t = tool(toolName); if (t) { return t->isEnabled(); } return false; } QGraphicsItem* DesktopToolbox::tool(const QString &toolName) const { foreach (QGraphicsItem *child, QGraphicsItem::children()) { //kDebug() << "checking tool" << child << child->data(ToolName); if (child->data(ToolName).toString() == toolName) { //kDebug() << "tool found!"; return child; } } return 0; } } // plasma namespace #include "desktoptoolbox_p.moc"