SchemeFlowWidget.cpp 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. #include "SchemeFlowWidget.h"
  2. #include "shemeFlow/FlowGraphNodeWidget.h"
  3. #include "ProjectManager.h"
  4. #include <dbService/ClassSet.h>
  5. #include <QGroupBox>
  6. #include <QCheckBox>
  7. #include <QBoxLayout>
  8. #include <QDebug>
  9. #include <QtNodes/GraphicsView>
  10. using QtNodes::GraphicsView;
  11. static std::shared_ptr<NodeDelegateModelRegistry> registerDataModels()
  12. {
  13. auto ret = std::make_shared<NodeDelegateModelRegistry>();
  14. ret->registerModel<FlowTemplateDataModel>();
  15. ret->registerModel<FlowIndexDataModel>();
  16. ret->registerModel<FlowSampleDataModel>();
  17. ret->registerModel<FlowPCADataModel>();
  18. ret->registerModel<FlowWeightDataModel>();
  19. ret->registerModel<FlowResultDataModel>();
  20. ret->registerModel<FlowReportDataModel>();
  21. ret->registerModel<FlowEffiLevDataModel>();
  22. ret->registerModel<FlowSchemeDataModel>();
  23. ret->registerModel<FlowEffiDataModel>();
  24. ret->registerModel<FlowCommonDataModel>();
  25. return ret;
  26. }
  27. static void setStyle_()
  28. {
  29. GraphicsViewStyle::setStyle(
  30. R"(
  31. {
  32. "GraphicsViewStyle": {
  33. "BackgroundColor": [255, 255, 255],
  34. "FineGridColor": [255, 255, 255],
  35. "CoarseGridColor": [255, 255, 255]
  36. }
  37. }
  38. )");
  39. NodeStyle::setNodeStyle(
  40. R"(
  41. {
  42. "NodeStyle": {
  43. "NormalBoundaryColor": "darkgray",
  44. "SelectedBoundaryColor": "deepskyblue",
  45. "GradientColor0": "mintcream",
  46. "GradientColor1": "mintcream",
  47. "GradientColor2": "mintcream",
  48. "GradientColor3": "mintcream",
  49. "ShadowColor": [200, 200, 200],
  50. "FontColor": [10, 10, 10],
  51. "FontColorFaded": [100, 100, 100],
  52. "ConnectionPointColor": "white",
  53. "PenWidth": 2.0,
  54. "HoveredPenWidth": 2.5,
  55. "ConnectionPointDiameter": 10.0,
  56. "Opacity": 1.0
  57. }
  58. }
  59. )");
  60. ConnectionStyle::setConnectionStyle(
  61. R"(
  62. {
  63. "ConnectionStyle": {
  64. "ConstructionColor": "gray",
  65. "NormalColor": "black",
  66. "SelectedColor": "gray",
  67. "SelectedHaloColor": "deepskyblue",
  68. "HoveredColor": "deepskyblue",
  69. "LineWidth": 3.0,
  70. "ConstructionLineWidth": 2.0,
  71. "PointDiameter": 10.0,
  72. "UseDataDefinedColors": false
  73. }
  74. }
  75. )");
  76. }
  77. SchemeFlowWidget::SchemeFlowWidget(ProjectInfo *proj, int indexType, QWidget *parent) : QWidget(parent), m_proj(proj)
  78. {
  79. setStyle_();
  80. initWidget();
  81. setType(indexType);
  82. }
  83. SchemeFlowWidget::~SchemeFlowWidget()
  84. {
  85. delete m_graphModel;
  86. }
  87. void SchemeFlowWidget::setType(int t)
  88. {
  89. m_indexType = t;
  90. refresh();
  91. }
  92. void SchemeFlowWidget::initWidget()
  93. {
  94. m_graphModel = new DataFlowModel(registerDataModels());
  95. m_graphModel->setNodesLocked(true);
  96. m_graphModel->setDetachPossible(false);
  97. auto scene = new DataFlowGraphicsScene(*m_graphModel);
  98. GraphicsView *view = new GraphicsView(scene);
  99. scene->setOrientation(Qt::Vertical);
  100. QHBoxLayout *l = new QHBoxLayout(this);
  101. l->addWidget(view);
  102. }
  103. void SchemeFlowWidget::clearAllNodes()
  104. {
  105. for (int id : m_graphModel->allNodeIds()) {
  106. m_graphModel->deleteNode(id);
  107. }
  108. }
  109. void SchemeFlowWidget::refresh()
  110. {
  111. clearAllNodes();
  112. qreal h = 200;
  113. switch (m_indexType) {
  114. case ProjectManager::AbilityIndex:
  115. break;
  116. case ProjectManager::TechIndex: {
  117. NodeId id11 = m_graphModel->addNode(FlowCommonData().type().id);
  118. m_graphModel->setNodeData(id11, NodeRole::Position, QPointF(0, h * 0));
  119. FlowGraphCommonNodeWidget *w11 = new FlowGraphCommonNodeWidget();
  120. SchemePlanManager::SchemeProcessInfo process11;
  121. process11.indexType = m_indexType;
  122. process11.type = SchemePlanManager::IndexSystem;
  123. w11->setProcess(process11);
  124. m_graphModel->setNodeData(id11, NodeRole::Widget, QVariant::fromValue(w11));
  125. NodeId id12 = m_graphModel->addNode(FlowCommonData().type().id);
  126. m_graphModel->setNodeData(id12, NodeRole::Position, QPointF(0, h * 1));
  127. FlowGraphCommonNodeWidget *w12 = new FlowGraphCommonNodeWidget();
  128. SchemePlanManager::SchemeProcessInfo process12;
  129. process12.indexType = m_indexType;
  130. process12.type = SchemePlanManager::ImportEvalData;
  131. process12.dSource = SchemePlanManager::FromExpert;
  132. w12->setProcess(process12);
  133. if (w12->isTitleHidden()) {
  134. m_graphModel->setNodeData(id12, NodeRole::Caption, SchemePlanManager::processName(process12));
  135. }
  136. m_graphModel->setNodeData(id12, NodeRole::Widget, QVariant::fromValue(w12));
  137. m_graphModel->addConnection(ConnectionId { id11, 0, id12, 0 });
  138. break;
  139. NodeId id1 = m_graphModel->addNode(FlowCommonData().type().id);
  140. m_graphModel->setNodeData(id1, NodeRole::Position, QPointF(0, h * 0));
  141. FlowGraphPlainNodeWidget *w1 = new FlowGraphPlainNodeWidget();
  142. w1->setText("构建权重分析指标体系");
  143. m_graphModel->setNodeData(id1, NodeRole::Widget, QVariant::fromValue(w1));
  144. NodeId id2 = m_graphModel->addNode(FlowCommonData().type().id);
  145. m_graphModel->setNodeData(id2, NodeRole::Position, QPointF(0, h * 1));
  146. m_graphModel->setNodeData(id2, NodeRole::Caption, QString("收集权重分析数据"));
  147. m_graphModel->addConnection(ConnectionId { id1, 0, id2, 0 });
  148. NodeId id3 = m_graphModel->addNode(FlowCommonData().type().id);
  149. m_graphModel->setNodeData(id3, NodeRole::Position, QPointF(0, h * 2));
  150. m_graphModel->setNodeData(id3, NodeRole::Caption, QString("指标体系优化"));
  151. m_graphModel->addConnection(ConnectionId { id2, 0, id3, 0 });
  152. NodeId id4 = m_graphModel->addNode(FlowCommonData().type().id);
  153. m_graphModel->setNodeData(id4, NodeRole::Position, QPointF(0, h * 3));
  154. m_graphModel->setNodeData(id4, NodeRole::Caption, QString("指标权重计算"));
  155. m_graphModel->addConnection(ConnectionId { id3, 0, id4, 0 });
  156. NodeId id5 = m_graphModel->addNode(FlowCommonData().type().id);
  157. m_graphModel->setNodeData(id5, NodeRole::Position, QPointF(0, h * 4));
  158. FlowGraphPlainNodeWidget *w5 = new FlowGraphPlainNodeWidget();
  159. w5->setText("分析结果展示");
  160. m_graphModel->setNodeData(id5, NodeRole::Widget, QVariant::fromValue(w5));
  161. m_graphModel->addConnection(ConnectionId { id4, 0, id5, 0 });
  162. NodeId id6 = m_graphModel->addNode(FlowCommonData().type().id);
  163. m_graphModel->setNodeData(id6, NodeRole::Position, QPointF(0, h * 5));
  164. m_graphModel->setNodeData(id6, NodeRole::Caption, QString("生成分析评估报告"));
  165. m_graphModel->addConnection(ConnectionId { id5, 0, id6, 0 });
  166. break;
  167. }
  168. case ProjectManager::OptimalIndex: {
  169. NodeId id1 = m_graphModel->addNode(FlowIndexData().type().id);
  170. m_graphModel->setNodeData(id1, NodeRole::Position, QPointF(0, h * 0));
  171. NodeId id2 = m_graphModel->addNode(FlowSampleData().type().id);
  172. m_graphModel->setNodeData(id2, NodeRole::Position, QPointF(0, h * 1));
  173. m_graphModel->addConnection(ConnectionId { id1, 0, id2, 0 });
  174. NodeId id8 = m_graphModel->addNode(FlowSchemeData().type().id);
  175. m_graphModel->setNodeData(id8, NodeRole::Position, QPointF(0, h * 2));
  176. m_graphModel->addConnection(ConnectionId { id2, 0, id8, 0 });
  177. NodeId id5 = m_graphModel->addNode(FlowResultData().type().id);
  178. m_graphModel->setNodeData(id5, NodeRole::Position, QPointF(0, h * 3));
  179. m_graphModel->addConnection(ConnectionId { id8, 0, id5, 0 });
  180. NodeId id6 = m_graphModel->addNode(FlowReportData().type().id);
  181. m_graphModel->setNodeData(id6, NodeRole::Position, QPointF(0, h * 4));
  182. m_graphModel->addConnection(ConnectionId { id5, 0, id6, 0 });
  183. break;
  184. }
  185. case ProjectManager::EfficiencyIndex: {
  186. NodeId id1 = m_graphModel->addNode(FlowIndexData().type().id);
  187. m_graphModel->setNodeData(id1, NodeRole::Position, QPointF(0, h * 0));
  188. NodeId id7 = m_graphModel->addNode(FlowEffiLevData().type().id);
  189. m_graphModel->setNodeData(id7, NodeRole::Position, QPointF(0, h * 1));
  190. m_graphModel->addConnection(ConnectionId { id1, 0, id7, 0 });
  191. NodeId id9 = m_graphModel->addNode(FlowEffiData().type().id);
  192. m_graphModel->setNodeData(id9, NodeRole::Position, QPointF(0, h * 2));
  193. m_graphModel->addConnection(ConnectionId { id7, 0, id9, 0 });
  194. NodeId id5 = m_graphModel->addNode(FlowResultData().type().id);
  195. m_graphModel->setNodeData(id5, NodeRole::Position, QPointF(0, h * 3));
  196. m_graphModel->addConnection(ConnectionId { id9, 0, id5, 0 });
  197. NodeId id6 = m_graphModel->addNode(FlowReportData().type().id);
  198. m_graphModel->setNodeData(id6, NodeRole::Position, QPointF(0, h * 4));
  199. m_graphModel->addConnection(ConnectionId { id5, 0, id6, 0 });
  200. break;
  201. }
  202. }
  203. // std::unordered_set<NodeId> set = m_graphModel->allNodeIds();
  204. // for (auto iter = set.begin(); iter != set.end(); ++iter) { }
  205. }