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();
|
||||
}
|
||||
|
||||
void hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
|
||||
void hoverLeaveEvent(QGraphicsSceneHoverEvent *)
|
||||
{
|
||||
m_itemBackground->hide();
|
||||
}
|
||||
@ -195,6 +195,7 @@ public:
|
||||
QColor fgColor;
|
||||
QColor bgColor;
|
||||
bool hovering : 1;
|
||||
QMultiMap<AbstractToolBox::ToolType, IconWidget *> tools;
|
||||
};
|
||||
|
||||
DesktopToolBox::DesktopToolBox(Containment *parent)
|
||||
@ -537,12 +538,82 @@ void DesktopToolBox::showToolBox()
|
||||
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()
|
||||
{
|
||||
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();
|
||||
}
|
||||
|
||||
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()
|
||||
{
|
||||
if (!d->toolBacker) {
|
||||
@ -550,8 +621,7 @@ void DesktopToolBox::adjustToolBackerGeometry()
|
||||
}
|
||||
|
||||
d->toolBacker->clearLayout();
|
||||
QMap<ToolType, IconWidget *> t = tools();
|
||||
QMapIterator<ToolType, IconWidget *> it(t);
|
||||
QMapIterator<ToolType, IconWidget *> it(d->tools);
|
||||
while (it.hasNext()) {
|
||||
it.next();
|
||||
IconWidget *icon = it.value();
|
||||
|
@ -49,6 +49,8 @@ public:
|
||||
QRectF boundingRect() const;
|
||||
QPainterPath shape() const;
|
||||
|
||||
void addTool(QAction *action);
|
||||
void removeTool(QAction *action);
|
||||
void showToolBox();
|
||||
void hideToolBox();
|
||||
|
||||
|
@ -51,7 +51,8 @@ public:
|
||||
showing(false),
|
||||
movable(false),
|
||||
dragging(false),
|
||||
userMoved(false)
|
||||
userMoved(false),
|
||||
iconic(true)
|
||||
{}
|
||||
|
||||
Containment *containment;
|
||||
@ -60,12 +61,13 @@ public:
|
||||
QSize iconSize;
|
||||
QPoint dragStartRelative;
|
||||
QTransform viewTransform;
|
||||
QMultiMap<AbstractToolBox::ToolType, IconWidget *> tools;
|
||||
QList<QAction *> actions;
|
||||
bool hidden : 1;
|
||||
bool showing : 1;
|
||||
bool movable : 1;
|
||||
bool dragging : 1;
|
||||
bool userMoved : 1;
|
||||
bool iconic : 1;
|
||||
};
|
||||
|
||||
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()
|
||||
{
|
||||
return this;
|
||||
@ -125,92 +122,33 @@ void InternalToolBox::addTool(QAction *action)
|
||||
return;
|
||||
}
|
||||
|
||||
foreach (IconWidget *tool, d->tools) {
|
||||
//kDebug() << "checking tool" << child << child->data(ToolName);
|
||||
if (tool->action() == action) {
|
||||
if (d->actions.contains(action)) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
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()));
|
||||
connect(action, SIGNAL(destroyed(QObject*)), this, SLOT(actionDestroyed(QObject*)));
|
||||
connect(action, SIGNAL(triggered(bool)), this, SLOT(toolTriggered(bool)));
|
||||
|
||||
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)
|
||||
{
|
||||
d->actions.append(action);
|
||||
}
|
||||
|
||||
void InternalToolBox::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;
|
||||
disconnect(action, 0, this, 0);
|
||||
d->actions.removeAll(action);
|
||||
}
|
||||
|
||||
void InternalToolBox::actionDestroyed(QObject *object)
|
||||
{
|
||||
d->actions.removeAll(static_cast<QAction*>(object));
|
||||
}
|
||||
|
||||
bool InternalToolBox::isEmpty() const
|
||||
{
|
||||
return d->actions.isEmpty();
|
||||
}
|
||||
|
||||
void InternalToolBox::toolTriggered(bool)
|
||||
{
|
||||
}
|
||||
|
||||
int InternalToolBox::size() const
|
||||
|
@ -87,19 +87,17 @@ public:
|
||||
virtual QSize fullWidth() const;
|
||||
virtual QSize fullHeight() const;
|
||||
virtual QSize cornerSize() const;
|
||||
virtual void updateToolBox() {}
|
||||
|
||||
void setIconic(bool iconic);
|
||||
bool iconic() const;
|
||||
|
||||
virtual void showToolBox() = 0;
|
||||
virtual void hideToolBox() = 0;
|
||||
public Q_SLOTS:
|
||||
/**
|
||||
* re-show the toolbox, in case any tools have changed
|
||||
*/
|
||||
virtual void updateToolBox();
|
||||
|
||||
protected:
|
||||
Containment *containment();
|
||||
QPoint toolPosition(int toolHeight);
|
||||
QMap<AbstractToolBox::ToolType, IconWidget *> tools() const;
|
||||
|
||||
void mousePressEvent(QGraphicsSceneMouseEvent *event);
|
||||
void mouseMoveEvent(QGraphicsSceneMouseEvent *event);
|
||||
@ -107,6 +105,7 @@ protected:
|
||||
|
||||
protected Q_SLOTS:
|
||||
virtual void toolTriggered(bool);
|
||||
void actionDestroyed(QObject *object);
|
||||
|
||||
private:
|
||||
InternalToolBoxPrivate *d;
|
||||
|
Loading…
Reference in New Issue
Block a user