Experimental:添加了【图层提升/下放功能】
parent
56777c1f00
commit
b2f37cc4eb
|
@ -110,6 +110,8 @@ void LayerTreeWidget::popMenu(const QPoint &pos)
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
menu.addAction(getPromoteUpAction());
|
||||||
|
menu.addAction(getPromoteDownAction());
|
||||||
}
|
}
|
||||||
menu.exec(mapToGlobal(pos));
|
menu.exec(mapToGlobal(pos));
|
||||||
}
|
}
|
||||||
|
@ -204,3 +206,103 @@ void LayerTreeWidget::pushDownLayer()
|
||||||
this->setCurrentItem(layer->qTreeWidgetItem);
|
this->setCurrentItem(layer->qTreeWidgetItem);
|
||||||
emit triggerCentralRefresh();
|
emit triggerCentralRefresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QAction* LayerTreeWidget::getPromoteUpAction()
|
||||||
|
{
|
||||||
|
QAction* action = new QAction(QString::fromLocal8Bit("提升 (experimental)"), this);
|
||||||
|
QMenu* optionMenu = new QMenu();
|
||||||
|
QList<QAction*> optionList;
|
||||||
|
std::vector<FolderLayerWrapper*> layers;
|
||||||
|
auto layer = this->selectedItem->data(0, Qt::UserRole).value<LayerWrapper*>();
|
||||||
|
layer = layer->getParent();
|
||||||
|
while (layer != nullptr)
|
||||||
|
{
|
||||||
|
if (layer->getParent() == nullptr)
|
||||||
|
break;
|
||||||
|
layer = layer->getParent();
|
||||||
|
layers.push_back(dynamic_cast<FolderLayerWrapper*>(layer));
|
||||||
|
}
|
||||||
|
reverse(layers.begin(), layers.end());
|
||||||
|
if (layers.size() == 0)
|
||||||
|
{
|
||||||
|
action->setEnabled(false);
|
||||||
|
return action;
|
||||||
|
}
|
||||||
|
for (auto layer : layers)
|
||||||
|
{
|
||||||
|
if (layer == nullptr)
|
||||||
|
continue;
|
||||||
|
QAction* option = new QAction(QString::fromLocal8Bit("提升至 ") + layer->property.name + QString::fromLocal8Bit(" 下"), this);
|
||||||
|
option->setData(QVariant::fromValue(std::pair<LayerWrapper*, FolderLayerWrapper*>({this->selectedItem->data(0, Qt::UserRole).value<LayerWrapper*>(), layer})));
|
||||||
|
connect(option, &QAction::triggered, this, [this, option]() {
|
||||||
|
auto pair = option->data().value<std::pair<LayerWrapper*, FolderLayerWrapper*>>();
|
||||||
|
auto layer = pair.first;
|
||||||
|
auto parent = pair.second;
|
||||||
|
this->moveLayer(layer, parent);
|
||||||
|
});
|
||||||
|
optionList.append(option);
|
||||||
|
}
|
||||||
|
optionMenu->addActions(optionList);
|
||||||
|
action->setMenu(optionMenu);
|
||||||
|
return action;
|
||||||
|
}
|
||||||
|
|
||||||
|
QAction* LayerTreeWidget::getPromoteDownAction()
|
||||||
|
{
|
||||||
|
QAction* action = new QAction(QString::fromLocal8Bit("下放 (experimental)"), this);
|
||||||
|
QMenu* optionMenu = new QMenu();
|
||||||
|
QList<QAction*> optionList;
|
||||||
|
std::vector<FolderLayerWrapper*> layers;
|
||||||
|
auto layer = this->selectedItem->data(0, Qt::UserRole).value<LayerWrapper*>();
|
||||||
|
auto parent = layer->getParent();
|
||||||
|
for (auto child : parent->children)
|
||||||
|
{
|
||||||
|
if (child.get() == layer || typeid(*child) != typeid(FolderLayerWrapper))
|
||||||
|
continue;
|
||||||
|
layers.push_back(dynamic_cast<FolderLayerWrapper*>(child.get()));
|
||||||
|
}
|
||||||
|
reverse(layers.begin(), layers.end());
|
||||||
|
if (layers.size() == 0)
|
||||||
|
{
|
||||||
|
action->setEnabled(false);
|
||||||
|
return action;
|
||||||
|
}
|
||||||
|
for (auto layer : layers)
|
||||||
|
{
|
||||||
|
if (layer == nullptr)
|
||||||
|
continue;
|
||||||
|
QAction* option = new QAction(QString::fromLocal8Bit("下放至 ") + layer->property.name + QString::fromLocal8Bit(" 中"), this);
|
||||||
|
option->setData(QVariant::fromValue(std::pair<LayerWrapper*, FolderLayerWrapper*>({ this->selectedItem->data(0, Qt::UserRole).value<LayerWrapper*>(), layer })));
|
||||||
|
connect(option, &QAction::triggered, this, [this, option]() {
|
||||||
|
auto pair = option->data().value<std::pair<LayerWrapper*, FolderLayerWrapper*>>();
|
||||||
|
auto layer = pair.first;
|
||||||
|
auto parent = pair.second;
|
||||||
|
this->moveLayer(layer, parent);
|
||||||
|
});
|
||||||
|
optionList.append(option);
|
||||||
|
}
|
||||||
|
optionMenu->addActions(optionList);
|
||||||
|
action->setMenu(optionMenu);
|
||||||
|
return action;
|
||||||
|
}
|
||||||
|
|
||||||
|
void LayerTreeWidget::moveLayer(LayerWrapper* layer, FolderLayerWrapper* parent)
|
||||||
|
{
|
||||||
|
auto oldParent = layer->getParent();
|
||||||
|
std::shared_ptr<LayerWrapper> layerPtr = nullptr;
|
||||||
|
for (int i = 0; i < oldParent->children.size(); i++)
|
||||||
|
{
|
||||||
|
if (oldParent->children[i].get() == layer)
|
||||||
|
{
|
||||||
|
layerPtr = oldParent->children[i];
|
||||||
|
oldParent->children.erase(oldParent->children.begin() + i);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
oldParent->qTreeWidgetItem->removeChild(layer->qTreeWidgetItem);
|
||||||
|
parent->qTreeWidgetItem->addChild(layer->qTreeWidgetItem);
|
||||||
|
parent->addChild(layerPtr);
|
||||||
|
layer->setParent(parent);
|
||||||
|
oldParent->removeChild(layer);
|
||||||
|
emit triggerCentralRefresh();
|
||||||
|
}
|
|
@ -11,6 +11,9 @@ class LayerTreeWidget : public QTreeWidget
|
||||||
LayerWrapper *copiedItem;
|
LayerWrapper *copiedItem;
|
||||||
void pushUpLayer();
|
void pushUpLayer();
|
||||||
void pushDownLayer();
|
void pushDownLayer();
|
||||||
|
QAction* getPromoteUpAction();
|
||||||
|
QAction* getPromoteDownAction();
|
||||||
|
void moveLayer(LayerWrapper* source, FolderLayerWrapper* parent);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ElementManager* elementManager;
|
ElementManager* elementManager;
|
||||||
|
|
Loading…
Reference in New Issue