SchemeFlowWidget.cpp 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. #include "SchemeFlowWidget.h"
  2. #include "ProjectManager.h"
  3. #include <dbService/ClassSet.h>
  4. #include <QGroupBox>
  5. #include <QCheckBox>
  6. #include <QBoxLayout>
  7. #include <QDebug>
  8. #include <QtNodes/GraphicsView>
  9. using QtNodes::GraphicsView;
  10. static std::shared_ptr<NodeDelegateModelRegistry> registerDataModels()
  11. {
  12. auto ret = std::make_shared<NodeDelegateModelRegistry>();
  13. ret->registerModel<FlowTemplateDataModel>();
  14. ret->registerModel<FlowIndexDataModel>();
  15. ret->registerModel<FlowSampleDataModel>();
  16. ret->registerModel<FlowPCADataModel>();
  17. ret->registerModel<FlowWeightDataModel>();
  18. ret->registerModel<FlowResultDataModel>();
  19. ret->registerModel<FlowReportDataModel>();
  20. ret->registerModel<FlowEffiLevDataModel>();
  21. ret->registerModel<FlowSchemeDataModel>();
  22. ret->registerModel<FlowEffiDataModel>();
  23. return ret;
  24. }
  25. static void setStyle_()
  26. {
  27. GraphicsViewStyle::setStyle(
  28. R"(
  29. {
  30. "GraphicsViewStyle": {
  31. "BackgroundColor": [255, 255, 255],
  32. "FineGridColor": [255, 255, 255],
  33. "CoarseGridColor": [255, 255, 255]
  34. }
  35. }
  36. )");
  37. NodeStyle::setNodeStyle(
  38. R"(
  39. {
  40. "NodeStyle": {
  41. "NormalBoundaryColor": "darkgray",
  42. "SelectedBoundaryColor": "deepskyblue",
  43. "GradientColor0": "mintcream",
  44. "GradientColor1": "mintcream",
  45. "GradientColor2": "mintcream",
  46. "GradientColor3": "mintcream",
  47. "ShadowColor": [200, 200, 200],
  48. "FontColor": [10, 10, 10],
  49. "FontColorFaded": [100, 100, 100],
  50. "ConnectionPointColor": "white",
  51. "PenWidth": 2.0,
  52. "HoveredPenWidth": 2.5,
  53. "ConnectionPointDiameter": 10.0,
  54. "Opacity": 1.0
  55. }
  56. }
  57. )");
  58. ConnectionStyle::setConnectionStyle(
  59. R"(
  60. {
  61. "ConnectionStyle": {
  62. "ConstructionColor": "gray",
  63. "NormalColor": "black",
  64. "SelectedColor": "gray",
  65. "SelectedHaloColor": "deepskyblue",
  66. "HoveredColor": "deepskyblue",
  67. "LineWidth": 3.0,
  68. "ConstructionLineWidth": 2.0,
  69. "PointDiameter": 10.0,
  70. "UseDataDefinedColors": false
  71. }
  72. }
  73. )");
  74. }
  75. SchemeFlowWidget::SchemeFlowWidget(ProjectInfo *proj, int indexType, QWidget *parent) : QWidget(parent), m_proj(proj)
  76. {
  77. setStyle_();
  78. initWidget();
  79. setType(indexType);
  80. }
  81. SchemeFlowWidget::~SchemeFlowWidget()
  82. {
  83. delete graphModel;
  84. }
  85. void SchemeFlowWidget::setType(int t)
  86. {
  87. m_indexType = t;
  88. refresh();
  89. }
  90. void SchemeFlowWidget::initWidget()
  91. {
  92. graphModel = new DataFlowModel(registerDataModels());
  93. graphModel->setNodesLocked(true);
  94. graphModel->setDetachPossible(false);
  95. auto scene = new DataFlowGraphicsScene(*graphModel);
  96. GraphicsView *view = new GraphicsView(scene);
  97. scene->setOrientation(Qt::Vertical);
  98. QHBoxLayout *l = new QHBoxLayout(this);
  99. l->addWidget(view);
  100. }
  101. void SchemeFlowWidget::clearAllNodes()
  102. {
  103. for (int id : graphModel->allNodeIds()) {
  104. graphModel->deleteNode(id);
  105. }
  106. }
  107. void SchemeFlowWidget::refresh()
  108. {
  109. clearAllNodes();
  110. qreal h = 120;
  111. switch (m_indexType) {
  112. case ProjectManager::AbilityIndex:
  113. case ProjectManager::TechIndex: {
  114. NodeId id1 = graphModel->addNode(FlowIndexData().type().id);
  115. graphModel->setNodeData(id1, NodeRole::Position, QPointF(0, h * 0));
  116. NodeId id2 = graphModel->addNode(FlowSampleData().type().id);
  117. graphModel->setNodeData(id2, NodeRole::Position, QPointF(0, h * 1));
  118. graphModel->setNodeData(id2, NodeRole::Caption, QString("收集权重分析数据"));
  119. graphModel->addConnection(ConnectionId { id1, 0, id2, 0 });
  120. NodeId id3 = graphModel->addNode(FlowPCAData().type().id);
  121. graphModel->setNodeData(id3, NodeRole::Position, QPointF(0, h * 2));
  122. graphModel->addConnection(ConnectionId { id2, 0, id3, 0 });
  123. NodeId id4 = graphModel->addNode(FlowWeightData().type().id);
  124. graphModel->setNodeData(id4, NodeRole::Position, QPointF(0, h * 3));
  125. graphModel->addConnection(ConnectionId { id3, 0, id4, 0 });
  126. NodeId id5 = graphModel->addNode(FlowResultData().type().id);
  127. graphModel->setNodeData(id5, NodeRole::Position, QPointF(0, h * 4));
  128. graphModel->addConnection(ConnectionId { id4, 0, id5, 0 });
  129. NodeId id6 = graphModel->addNode(FlowReportData().type().id);
  130. graphModel->setNodeData(id6, NodeRole::Position, QPointF(0, h * 5));
  131. graphModel->addConnection(ConnectionId { id5, 0, id6, 0 });
  132. break;
  133. }
  134. case ProjectManager::OptimalIndex: {
  135. NodeId id1 = graphModel->addNode(FlowIndexData().type().id);
  136. graphModel->setNodeData(id1, NodeRole::Position, QPointF(0, h * 0));
  137. NodeId id2 = graphModel->addNode(FlowSampleData().type().id);
  138. graphModel->setNodeData(id2, NodeRole::Position, QPointF(0, h * 1));
  139. graphModel->addConnection(ConnectionId { id1, 0, id2, 0 });
  140. NodeId id8 = graphModel->addNode(FlowSchemeData().type().id);
  141. graphModel->setNodeData(id8, NodeRole::Position, QPointF(0, h * 2));
  142. graphModel->addConnection(ConnectionId { id2, 0, id8, 0 });
  143. NodeId id5 = graphModel->addNode(FlowResultData().type().id);
  144. graphModel->setNodeData(id5, NodeRole::Position, QPointF(0, h * 3));
  145. graphModel->addConnection(ConnectionId { id8, 0, id5, 0 });
  146. NodeId id6 = graphModel->addNode(FlowReportData().type().id);
  147. graphModel->setNodeData(id6, NodeRole::Position, QPointF(0, h * 4));
  148. graphModel->addConnection(ConnectionId { id5, 0, id6, 0 });
  149. break;
  150. }
  151. case ProjectManager::EfficiencyIndex: {
  152. NodeId id1 = graphModel->addNode(FlowIndexData().type().id);
  153. graphModel->setNodeData(id1, NodeRole::Position, QPointF(0, h * 0));
  154. NodeId id7 = graphModel->addNode(FlowEffiLevData().type().id);
  155. graphModel->setNodeData(id7, NodeRole::Position, QPointF(0, h * 1));
  156. graphModel->addConnection(ConnectionId { id1, 0, id7, 0 });
  157. NodeId id9 = graphModel->addNode(FlowEffiData().type().id);
  158. graphModel->setNodeData(id9, NodeRole::Position, QPointF(0, h * 2));
  159. graphModel->addConnection(ConnectionId { id7, 0, id9, 0 });
  160. NodeId id5 = graphModel->addNode(FlowResultData().type().id);
  161. graphModel->setNodeData(id5, NodeRole::Position, QPointF(0, h * 3));
  162. graphModel->addConnection(ConnectionId { id9, 0, id5, 0 });
  163. NodeId id6 = graphModel->addNode(FlowReportData().type().id);
  164. graphModel->setNodeData(id6, NodeRole::Position, QPointF(0, h * 4));
  165. graphModel->addConnection(ConnectionId { id5, 0, id6, 0 });
  166. break;
  167. }
  168. }
  169. }