123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- #include "SchemeFlowWidget.h"
- #include "shemeFlow/FlowGraphNodeWidget.h"
- #include "ProjectManager.h"
- #include <dbService/ClassSet.h>
- #include <QGroupBox>
- #include <QCheckBox>
- #include <QBoxLayout>
- #include <QDebug>
- #include <QtNodes/GraphicsView>
- using QtNodes::GraphicsView;
- static std::shared_ptr<NodeDelegateModelRegistry> registerDataModels()
- {
- auto ret = std::make_shared<NodeDelegateModelRegistry>();
- ret->registerModel<FlowTemplateDataModel>();
- ret->registerModel<FlowIndexDataModel>();
- ret->registerModel<FlowSampleDataModel>();
- ret->registerModel<FlowPCADataModel>();
- ret->registerModel<FlowWeightDataModel>();
- ret->registerModel<FlowResultDataModel>();
- ret->registerModel<FlowReportDataModel>();
- ret->registerModel<FlowEffiLevDataModel>();
- ret->registerModel<FlowSchemeDataModel>();
- ret->registerModel<FlowEffiDataModel>();
- ret->registerModel<FlowCommonDataModel>();
- return ret;
- }
- static void setStyle_()
- {
- GraphicsViewStyle::setStyle(
- R"(
- {
- "GraphicsViewStyle": {
- "BackgroundColor": [255, 255, 255],
- "FineGridColor": [255, 255, 255],
- "CoarseGridColor": [255, 255, 255]
- }
- }
- )");
- NodeStyle::setNodeStyle(
- R"(
- {
- "NodeStyle": {
- "NormalBoundaryColor": "darkgray",
- "SelectedBoundaryColor": "deepskyblue",
- "GradientColor0": "mintcream",
- "GradientColor1": "mintcream",
- "GradientColor2": "mintcream",
- "GradientColor3": "mintcream",
- "ShadowColor": [200, 200, 200],
- "FontColor": [10, 10, 10],
- "FontColorFaded": [100, 100, 100],
- "ConnectionPointColor": "white",
- "PenWidth": 2.0,
- "HoveredPenWidth": 2.5,
- "ConnectionPointDiameter": 10.0,
- "Opacity": 1.0
- }
- }
- )");
- ConnectionStyle::setConnectionStyle(
- R"(
- {
- "ConnectionStyle": {
- "ConstructionColor": "gray",
- "NormalColor": "black",
- "SelectedColor": "gray",
- "SelectedHaloColor": "deepskyblue",
- "HoveredColor": "deepskyblue",
- "LineWidth": 3.0,
- "ConstructionLineWidth": 2.0,
- "PointDiameter": 10.0,
- "UseDataDefinedColors": false
- }
- }
- )");
- }
- SchemeFlowWidget::SchemeFlowWidget(ProjectInfo *proj, int indexType, QWidget *parent) : QWidget(parent), m_proj(proj)
- {
- setStyle_();
- initWidget();
- setType(indexType);
- }
- SchemeFlowWidget::~SchemeFlowWidget()
- {
- delete m_graphModel;
- }
- void SchemeFlowWidget::setType(int t)
- {
- m_indexType = t;
- refresh();
- }
- QList<SchemePlanManager::SchemeProcessType> SchemeFlowWidget::schemeTemplate(int indexType)
- {
- /// 方案流程模板
- QList<SchemePlanManager::SchemeProcessType> scheme;
- switch (indexType) {
- case ProjectManager::AbilityIndex: {
- scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportWeightData,
- SchemePlanManager::OptimizeIndex, SchemePlanManager::CalculateWeight,
- SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
- break;
- }
- case ProjectManager::TechIndex: {
- scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportEvalData, SchemePlanManager::RunEvaluate,
- SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
- break;
- }
- case ProjectManager::OptimalIndex: {
- scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportWeightData,
- SchemePlanManager::OptimizeIndex, SchemePlanManager::CalculateWeight,
- SchemePlanManager::ImportEvalData, SchemePlanManager::RunEvaluate,
- SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
- break;
- }
- case ProjectManager::EfficiencyIndex: {
- scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportWeightData,
- SchemePlanManager::OptimizeIndex, SchemePlanManager::CalculateWeight,
- SchemePlanManager::ImportEvalData, SchemePlanManager::RunEvaluate,
- SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
- break;
- }
- }
- return scheme;
- }
- void SchemeFlowWidget::initWidget()
- {
- m_graphModel = new DataFlowModel(registerDataModels());
- m_graphModel->setNodesLocked(true);
- m_graphModel->setDetachPossible(false);
- auto scene = new DataFlowGraphicsScene(*m_graphModel);
- GraphicsView *view = new GraphicsView(scene);
- scene->setOrientation(Qt::Vertical);
- QHBoxLayout *l = new QHBoxLayout(this);
- l->addWidget(view);
- }
- void SchemeFlowWidget::clearAllNodes()
- {
- for (int id : m_graphModel->allNodeIds()) {
- m_graphModel->deleteNode(id);
- }
- }
- void SchemeFlowWidget::refresh()
- {
- clearAllNodes();
- int y = 0; // 流程图节点位置
- int space = 50; // 流程图节点间距
- NodeId lastId = -1;
- QList<SchemePlanManager::SchemeProcessType> scheme = schemeTemplate(m_indexType);
- for (int i = 0; i < scheme.count(); i++) {
- NodeId id = m_graphModel->addNode(FlowCommonData().type().id);
- m_graphModel->setNodeData(id, NodeRole::Position, QPointF(0, y));
- FlowGraphCommonNodeWidget *w = new FlowGraphCommonNodeWidget();
- connect(w, &FlowGraphCommonNodeWidget::sigProcessChanged, this, &SchemeFlowWidget::slotSchemeProcessEdited);
- SchemePlanManager::SchemeProcessInfo process;
- process.projectId = m_proj->id;
- process.indexType = m_indexType;
- process.type = scheme[i];
- process.step = i;
- w->setProcess(process);
- if (w->isTitleHidden()) {
- m_graphModel->setNodeData(id, NodeRole::Caption, SchemePlanManager::processName(process));
- }
- m_graphModel->setNodeData(id, NodeRole::Widget, QVariant::fromValue(w));
- if (lastId >= 0) {
- m_graphModel->addConnection(ConnectionId { lastId, 0, id, 0 });
- }
- QSize s = m_graphModel->nodeData(id, NodeRole::Size).toSize();
- y += (s.height() + space);
- lastId = id;
- }
- }
- void SchemeFlowWidget::slotSchemeProcessEdited(const SchemePlanManager::SchemeProcessInfo &process)
- {
- qDebug() << __FUNCTION__ << __LINE__ << process.algorithm << endl;
- }
|