SchemeFlowWidget.cpp 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  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. int y = 0;
  113. int space = 50;
  114. NodeId lastId = -1;
  115. QList<SchemePlanManager::SchemeProcessType> scheme;
  116. switch (m_indexType) {
  117. case ProjectManager::AbilityIndex: {
  118. scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportWeightData,
  119. SchemePlanManager::OptimizeIndex, SchemePlanManager::CalculateWeight,
  120. SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
  121. break;
  122. }
  123. case ProjectManager::TechIndex: {
  124. scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportEvalData, SchemePlanManager::RunEvaluate,
  125. SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
  126. break;
  127. }
  128. case ProjectManager::OptimalIndex: {
  129. scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportWeightData,
  130. SchemePlanManager::OptimizeIndex, SchemePlanManager::CalculateWeight,
  131. SchemePlanManager::ImportEvalData, SchemePlanManager::RunEvaluate,
  132. SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
  133. break;
  134. }
  135. case ProjectManager::EfficiencyIndex: {
  136. scheme = { SchemePlanManager::IndexSystem, SchemePlanManager::ImportWeightData,
  137. SchemePlanManager::OptimizeIndex, SchemePlanManager::CalculateWeight,
  138. SchemePlanManager::ImportEvalData, SchemePlanManager::RunEvaluate,
  139. SchemePlanManager::ShowEvalResult, SchemePlanManager::GenerateReport };
  140. break;
  141. }
  142. }
  143. for (int i = 0; i < scheme.count(); i++) {
  144. NodeId id = m_graphModel->addNode(FlowCommonData().type().id);
  145. m_graphModel->setNodeData(id, NodeRole::Position, QPointF(0, y));
  146. FlowGraphCommonNodeWidget *w = new FlowGraphCommonNodeWidget();
  147. SchemePlanManager::SchemeProcessInfo process;
  148. process.projectId = m_proj->id;
  149. process.indexType = m_indexType;
  150. process.type = scheme[i];
  151. process.step = i;
  152. w->setProcess(process);
  153. if (w->isTitleHidden()) {
  154. m_graphModel->setNodeData(id, NodeRole::Caption, SchemePlanManager::processName(process));
  155. }
  156. m_graphModel->setNodeData(id, NodeRole::Widget, QVariant::fromValue(w));
  157. if (lastId >= 0) {
  158. m_graphModel->addConnection(ConnectionId { lastId, 0, id, 0 });
  159. }
  160. QSize s = m_graphModel->nodeData(id, NodeRole::Size).toSize();
  161. y += (s.height() + space);
  162. lastId = id;
  163. }
  164. // std::unordered_set<NodeId> set = m_graphModel->allNodeIds();
  165. // for (auto iter = set.begin(); iter != set.end(); ++iter) { }
  166. }