move the IconWidget version of the tools into the desktop tool box; it is what uses them and this prevents having to keep fixing the "tools are showing in the panel" bug every time something in the toolboxes and/or panel containments and/or panel views changes ;)
svn path=/trunk/KDE/kdelibs/; revision=1130635
This commit is contained in:
parent
30b2a10d57
commit
6a286f380e
@ -123,7 +123,7 @@ class EmptyGraphicsItem : public QGraphicsWidget
|
|||||||
event->accept();
|
event->accept();
|
||||||
}
|
}
|
||||||
|
|
||||||
void hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
|
void hoverLeaveEvent(QGraphicsSceneHoverEvent *)
|
||||||
{
|
{
|
||||||
m_itemBackground->hide();
|
m_itemBackground->hide();
|
||||||
}
|
}
|
||||||
@ -195,6 +195,7 @@ public:
|
|||||||
QColor fgColor;
|
QColor fgColor;
|
||||||
QColor bgColor;
|
QColor bgColor;
|
||||||
bool hovering : 1;
|
bool hovering : 1;
|
||||||
|
QMultiMap<AbstractToolBox::ToolType, IconWidget *> tools;
|
||||||
};
|
};
|
||||||
|
|
||||||
DesktopToolBox::DesktopToolBox(Containment *parent)
|
DesktopToolBox::DesktopToolBox(Containment *parent)
|
||||||
@ -537,12 +538,82 @@ void DesktopToolBox::showToolBox()
|
|||||||
fadeAnim->start(QAbstractAnimation::DeleteWhenStopped);
|
fadeAnim->start(QAbstractAnimation::DeleteWhenStopped);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DesktopToolBox::addTool(QAction *action)
|
||||||
|
{
|
||||||
|
InternalToolBox::addTool(action);
|
||||||
|
Plasma::IconWidget *tool = new Plasma::IconWidget(toolParent());
|
||||||
|
|
||||||
|
tool->setTextBackgroundColor(QColor());
|
||||||
|
tool->setAction(action);
|
||||||
|
tool->setDrawBackground(true);
|
||||||
|
tool->setOrientation(Qt::Horizontal);
|
||||||
|
tool->resize(tool->sizeFromIconSize(KIconLoader::SizeSmallMedium));
|
||||||
|
tool->setPreferredIconSize(QSizeF(KIconLoader::SizeSmallMedium, KIconLoader::SizeSmallMedium));
|
||||||
|
tool->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Fixed);
|
||||||
|
|
||||||
|
tool->hide();
|
||||||
|
const int height = static_cast<int>(tool->boundingRect().height());
|
||||||
|
tool->setPos(toolPosition(height));
|
||||||
|
tool->setZValue(zValue() + 10);
|
||||||
|
tool->setToolTip(action->text());
|
||||||
|
|
||||||
|
//make enabled/disabled tools appear/disappear instantly
|
||||||
|
connect(tool, SIGNAL(changed()), this, SLOT(updateToolBox()));
|
||||||
|
|
||||||
|
ToolType type = AbstractToolBox::MiscTool;
|
||||||
|
if (!action->data().isNull() && action->data().type() == QVariant::Int) {
|
||||||
|
int t = action->data().toInt();
|
||||||
|
if (t >= 0 && t < AbstractToolBox::UserToolType) {
|
||||||
|
type = static_cast<AbstractToolBox::ToolType>(t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
d->tools.insert(type, tool);
|
||||||
|
//kDebug() << "added tool" << type << action->text();
|
||||||
|
}
|
||||||
|
|
||||||
void DesktopToolBox::updateToolBox()
|
void DesktopToolBox::updateToolBox()
|
||||||
{
|
{
|
||||||
InternalToolBox::updateToolBox();
|
Plasma::IconWidget *tool = qobject_cast<Plasma::IconWidget *>(sender());
|
||||||
|
if (tool && !tool->action()) {
|
||||||
|
QMutableMapIterator<ToolType, IconWidget *> it(d->tools);
|
||||||
|
while (it.hasNext()) {
|
||||||
|
it.next();
|
||||||
|
if (it.value() == tool) {
|
||||||
|
it.remove();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tool->deleteLater();
|
||||||
|
tool = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isShowing()) {
|
||||||
|
showToolBox();
|
||||||
|
} else if (tool && !tool->isEnabled()) {
|
||||||
|
tool->hide();
|
||||||
|
}
|
||||||
|
|
||||||
adjustToolBackerGeometry();
|
adjustToolBackerGeometry();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DesktopToolBox::removeTool(QAction *action)
|
||||||
|
{
|
||||||
|
QMutableMapIterator<ToolType, IconWidget *> it(d->tools);
|
||||||
|
while (it.hasNext()) {
|
||||||
|
it.next();
|
||||||
|
IconWidget *tool = it.value();
|
||||||
|
//kDebug() << "checking tool" << tool
|
||||||
|
if (tool && tool->action() == action) {
|
||||||
|
//kDebug() << "tool found!";
|
||||||
|
tool->deleteLater();
|
||||||
|
it.remove();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void DesktopToolBox::adjustToolBackerGeometry()
|
void DesktopToolBox::adjustToolBackerGeometry()
|
||||||
{
|
{
|
||||||
if (!d->toolBacker) {
|
if (!d->toolBacker) {
|
||||||
@ -550,8 +621,7 @@ void DesktopToolBox::adjustToolBackerGeometry()
|
|||||||
}
|
}
|
||||||
|
|
||||||
d->toolBacker->clearLayout();
|
d->toolBacker->clearLayout();
|
||||||
QMap<ToolType, IconWidget *> t = tools();
|
QMapIterator<ToolType, IconWidget *> it(d->tools);
|
||||||
QMapIterator<ToolType, IconWidget *> it(t);
|
|
||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
it.next();
|
it.next();
|
||||||
IconWidget *icon = it.value();
|
IconWidget *icon = it.value();
|
||||||
|
@ -49,6 +49,8 @@ public:
|
|||||||
QRectF boundingRect() const;
|
QRectF boundingRect() const;
|
||||||
QPainterPath shape() const;
|
QPainterPath shape() const;
|
||||||
|
|
||||||
|
void addTool(QAction *action);
|
||||||
|
void removeTool(QAction *action);
|
||||||
void showToolBox();
|
void showToolBox();
|
||||||
void hideToolBox();
|
void hideToolBox();
|
||||||
|
|
||||||
|
@ -51,7 +51,8 @@ public:
|
|||||||
showing(false),
|
showing(false),
|
||||||
movable(false),
|
movable(false),
|
||||||
dragging(false),
|
dragging(false),
|
||||||
userMoved(false)
|
userMoved(false),
|
||||||
|
iconic(true)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
Containment *containment;
|
Containment *containment;
|
||||||
@ -60,12 +61,13 @@ public:
|
|||||||
QSize iconSize;
|
QSize iconSize;
|
||||||
QPoint dragStartRelative;
|
QPoint dragStartRelative;
|
||||||
QTransform viewTransform;
|
QTransform viewTransform;
|
||||||
QMultiMap<AbstractToolBox::ToolType, IconWidget *> tools;
|
QList<QAction *> actions;
|
||||||
bool hidden : 1;
|
bool hidden : 1;
|
||||||
bool showing : 1;
|
bool showing : 1;
|
||||||
bool movable : 1;
|
bool movable : 1;
|
||||||
bool dragging : 1;
|
bool dragging : 1;
|
||||||
bool userMoved : 1;
|
bool userMoved : 1;
|
||||||
|
bool iconic : 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
InternalToolBox::InternalToolBox(Containment *parent)
|
InternalToolBox::InternalToolBox(Containment *parent)
|
||||||
@ -109,11 +111,6 @@ QPoint InternalToolBox::toolPosition(int toolHeight)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QMap<AbstractToolBox::ToolType, IconWidget *> InternalToolBox::tools() const
|
|
||||||
{
|
|
||||||
return d->tools;
|
|
||||||
}
|
|
||||||
|
|
||||||
QGraphicsWidget *InternalToolBox::toolParent()
|
QGraphicsWidget *InternalToolBox::toolParent()
|
||||||
{
|
{
|
||||||
return this;
|
return this;
|
||||||
@ -125,92 +122,33 @@ void InternalToolBox::addTool(QAction *action)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach (IconWidget *tool, d->tools) {
|
if (d->actions.contains(action)) {
|
||||||
//kDebug() << "checking tool" << child << child->data(ToolName);
|
|
||||||
if (tool->action() == action) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
Plasma::IconWidget *tool = new Plasma::IconWidget(toolParent());
|
connect(action, SIGNAL(destroyed(QObject*)), this, SLOT(actionDestroyed(QObject*)));
|
||||||
|
|
||||||
tool->setTextBackgroundColor(QColor());
|
|
||||||
tool->setAction(action);
|
|
||||||
tool->setDrawBackground(true);
|
|
||||||
tool->setOrientation(Qt::Horizontal);
|
|
||||||
tool->resize(tool->sizeFromIconSize(KIconLoader::SizeSmallMedium));
|
|
||||||
tool->setPreferredIconSize(QSizeF(KIconLoader::SizeSmallMedium, KIconLoader::SizeSmallMedium));
|
|
||||||
tool->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Fixed);
|
|
||||||
|
|
||||||
tool->hide();
|
|
||||||
const int height = static_cast<int>(tool->boundingRect().height());
|
|
||||||
tool->setPos(toolPosition(height));
|
|
||||||
tool->setZValue(zValue() + 10);
|
|
||||||
tool->setToolTip(action->text());
|
|
||||||
|
|
||||||
//make enabled/disabled tools appear/disappear instantly
|
|
||||||
connect(tool, SIGNAL(changed()), this, SLOT(updateToolBox()));
|
|
||||||
connect(action, SIGNAL(triggered(bool)), this, SLOT(toolTriggered(bool)));
|
connect(action, SIGNAL(triggered(bool)), this, SLOT(toolTriggered(bool)));
|
||||||
|
d->actions.append(action);
|
||||||
ToolType type = AbstractToolBox::MiscTool;
|
|
||||||
if (!action->data().isNull() && action->data().type() == QVariant::Int) {
|
|
||||||
int t = action->data().toInt();
|
|
||||||
if (t >= 0 && t < AbstractToolBox::UserToolType) {
|
|
||||||
type = static_cast<AbstractToolBox::ToolType>(t);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
d->tools.insert(type, tool);
|
|
||||||
//kDebug() << "added tool" << type << action->text();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool InternalToolBox::isEmpty() const
|
|
||||||
{
|
|
||||||
return d->tools.isEmpty();
|
|
||||||
}
|
|
||||||
|
|
||||||
void InternalToolBox::updateToolBox()
|
|
||||||
{
|
|
||||||
Plasma::IconWidget *tool = qobject_cast<Plasma::IconWidget *>(sender());
|
|
||||||
if (tool && !tool->action()) {
|
|
||||||
QMutableMapIterator<ToolType, IconWidget *> it(d->tools);
|
|
||||||
while (it.hasNext()) {
|
|
||||||
it.next();
|
|
||||||
if (it.value() == tool) {
|
|
||||||
it.remove();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tool->deleteLater();
|
|
||||||
tool = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (d->showing) {
|
|
||||||
showToolBox();
|
|
||||||
} else if (tool && !tool->isEnabled()) {
|
|
||||||
tool->hide();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void InternalToolBox::toolTriggered(bool)
|
|
||||||
{
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void InternalToolBox::removeTool(QAction *action)
|
void InternalToolBox::removeTool(QAction *action)
|
||||||
{
|
{
|
||||||
QMutableMapIterator<ToolType, IconWidget *> it(d->tools);
|
disconnect(action, 0, this, 0);
|
||||||
while (it.hasNext()) {
|
d->actions.removeAll(action);
|
||||||
it.next();
|
}
|
||||||
IconWidget *tool = it.value();
|
|
||||||
//kDebug() << "checking tool" << tool
|
void InternalToolBox::actionDestroyed(QObject *object)
|
||||||
if (tool && tool->action() == action) {
|
{
|
||||||
//kDebug() << "tool found!";
|
d->actions.removeAll(static_cast<QAction*>(object));
|
||||||
tool->deleteLater();
|
}
|
||||||
it.remove();
|
|
||||||
break;
|
bool InternalToolBox::isEmpty() const
|
||||||
}
|
{
|
||||||
}
|
return d->actions.isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
void InternalToolBox::toolTriggered(bool)
|
||||||
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
int InternalToolBox::size() const
|
int InternalToolBox::size() const
|
||||||
|
@ -87,19 +87,17 @@ public:
|
|||||||
virtual QSize fullWidth() const;
|
virtual QSize fullWidth() const;
|
||||||
virtual QSize fullHeight() const;
|
virtual QSize fullHeight() const;
|
||||||
virtual QSize cornerSize() const;
|
virtual QSize cornerSize() const;
|
||||||
|
virtual void updateToolBox() {}
|
||||||
|
|
||||||
|
void setIconic(bool iconic);
|
||||||
|
bool iconic() const;
|
||||||
|
|
||||||
virtual void showToolBox() = 0;
|
virtual void showToolBox() = 0;
|
||||||
virtual void hideToolBox() = 0;
|
virtual void hideToolBox() = 0;
|
||||||
public Q_SLOTS:
|
|
||||||
/**
|
|
||||||
* re-show the toolbox, in case any tools have changed
|
|
||||||
*/
|
|
||||||
virtual void updateToolBox();
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Containment *containment();
|
Containment *containment();
|
||||||
QPoint toolPosition(int toolHeight);
|
QPoint toolPosition(int toolHeight);
|
||||||
QMap<AbstractToolBox::ToolType, IconWidget *> tools() const;
|
|
||||||
|
|
||||||
void mousePressEvent(QGraphicsSceneMouseEvent *event);
|
void mousePressEvent(QGraphicsSceneMouseEvent *event);
|
||||||
void mouseMoveEvent(QGraphicsSceneMouseEvent *event);
|
void mouseMoveEvent(QGraphicsSceneMouseEvent *event);
|
||||||
@ -107,6 +105,7 @@ protected:
|
|||||||
|
|
||||||
protected Q_SLOTS:
|
protected Q_SLOTS:
|
||||||
virtual void toolTriggered(bool);
|
virtual void toolTriggered(bool);
|
||||||
|
void actionDestroyed(QObject *object);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
InternalToolBoxPrivate *d;
|
InternalToolBoxPrivate *d;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user