EvalSchemeWidget.cpp 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. #include "EvalSchemeWidget.h"
  2. #include <CCanvas/CSchemeView.h>
  3. #include <CCanvas/CSchemeItem.h>
  4. #include <Widgets/Button.h>
  5. #include <Widgets/Menu.h>
  6. #include <Widgets/CheckBox.h>
  7. #include <QLabel>
  8. #include <QLayout>
  9. #include <QMetaEnum>
  10. #include <QDebug>
  11. QString EvalSchemeWidget::nameOfScheme(Scheme s)
  12. {
  13. switch (s) {
  14. case Index:
  15. return "构建指标体系";
  16. case Collect:
  17. return "收集数据";
  18. case Process:
  19. return "处理数据";
  20. case Output:
  21. return "生成报告";
  22. }
  23. }
  24. QString EvalSchemeWidget::nameOfAlgorithm(EvalSchemeWidget::Algorithm a)
  25. {
  26. switch (a) {
  27. case Alg1:
  28. return "层次分析法";
  29. case Alg2:
  30. return "集对分析法";
  31. case Alg3:
  32. return "熵值法";
  33. case Alg4:
  34. return "物元分析法";
  35. case Alg5:
  36. return "灰色聚类评估法";
  37. }
  38. }
  39. EvalSchemeWidget::EvalSchemeWidget(ProjectInfo *proj, int type, QWidget *parent) : EvalWidget(proj, type, parent)
  40. {
  41. setTitle("评估方案规划");
  42. m_schemes["指标体系"] = { Index | Process | Output, Alg1 };
  43. m_schemes["收集数据"] = { Collect | Process | Output, Alg1 };
  44. m_schemes["指标体系和收集数据"] = { Index | Collect | Process | Output, Alg1 };
  45. initWidgets();
  46. initLayout();
  47. connectSignalsAndSlots();
  48. loadScheme(m_schemes.keys().first());
  49. updateButtonState();
  50. }
  51. void EvalSchemeWidget::initWidgets()
  52. {
  53. m_schemeBtn = new PushButton("加载方案", this);
  54. m_index = new CheckBox("指标体系", this);
  55. m_data = new CheckBox("收集数据", this);
  56. m_algBtn = new PushButton("数据处理", this);
  57. m_clear = new PushButton("清空");
  58. m_schemeView = new CSchemeView(this);
  59. m_schemeSep = new QWidget(this);
  60. m_schemeSep->setFixedWidth(1);
  61. m_description = new QLabel("description", this);
  62. m_description->setFixedWidth(150);
  63. m_schemeMenu = new RoundMenu("scheme", this);
  64. for (QString key : m_schemes.keys()) {
  65. QAction *act = new QAction(key);
  66. m_schemeMenu->addAction(act);
  67. connect(act, &QAction::triggered, [this, act]() { loadScheme(act->text()); });
  68. }
  69. // 按照算法枚举值添加算法选项
  70. m_algMenu = new RoundMenu("alg", this);
  71. QMetaEnum alg = QMetaEnum::fromType<Algorithm>();
  72. for (int i = 0; i < alg.keyCount(); i++) {
  73. Algorithm t = Algorithm(alg.value(i));
  74. QAction *act = new QAction(nameOfAlgorithm(t));
  75. m_algMenu->addAction(act);
  76. connect(act, &QAction::triggered, [this, t]() { slotSelectAlgorithm(t); });
  77. }
  78. }
  79. void EvalSchemeWidget::initLayout()
  80. {
  81. // 总体布局
  82. m_buttonLayout = new QHBoxLayout();
  83. m_contentLayout->addLayout(m_buttonLayout);
  84. m_schemeLayout = new QHBoxLayout();
  85. m_contentLayout->addLayout(m_schemeLayout);
  86. m_buttonLayout->addWidget(m_schemeBtn);
  87. m_buttonLayout->addSpacing(20);
  88. m_buttonLayout->addWidget(m_index);
  89. m_buttonLayout->addSpacing(20);
  90. m_buttonLayout->addWidget(m_data);
  91. m_buttonLayout->addSpacing(20);
  92. m_buttonLayout->addWidget(m_algBtn);
  93. m_buttonLayout->addSpacing(20);
  94. m_buttonLayout->addWidget(m_clear);
  95. m_buttonLayout->addStretch();
  96. m_schemeLayout->addWidget(m_schemeView);
  97. m_schemeLayout->addWidget(m_seperator);
  98. m_schemeLayout->addWidget(m_description);
  99. }
  100. void EvalSchemeWidget::connectSignalsAndSlots()
  101. {
  102. connect(m_schemeBtn, &PushButton::clicked, this, &EvalSchemeWidget::slotShowSchemeMenu);
  103. connect(m_index, &CheckBox::clicked, this, &EvalSchemeWidget::slotIndexClicked);
  104. connect(m_data, &CheckBox::clicked, this, &EvalSchemeWidget::slotDataClicked);
  105. connect(m_algBtn, &PushButton::clicked, this, &EvalSchemeWidget::slotAlgBtnClicked);
  106. connect(m_clear, &PushButton::clicked, this, &EvalSchemeWidget::slotClearClicked);
  107. }
  108. void EvalSchemeWidget::refreshSchemeView()
  109. {
  110. updateButtonState();
  111. m_schemeView->clear();
  112. if (m_scheme > 0) {
  113. m_scheme |= Output;
  114. }
  115. QMetaEnum sch = QMetaEnum::fromType<Scheme>();
  116. for (int i = 0; i < sch.keyCount(); i++) {
  117. Scheme s = Scheme(sch.value(i));
  118. if (s == Process) {
  119. for (Algorithm a : m_algs) {
  120. CSchemeItem *item = new CSchemeItem(nameOfAlgorithm(a));
  121. m_schemeView->addItem(item);
  122. }
  123. } else {
  124. if ((m_scheme & s) == s) {
  125. CSchemeItem *item = new CSchemeItem(nameOfScheme(s));
  126. m_schemeView->addItem(item);
  127. }
  128. }
  129. }
  130. }
  131. void EvalSchemeWidget::testData()
  132. {
  133. m_scheme = Index | Collect | Output;
  134. m_algs = { Alg1 };
  135. refreshSchemeView();
  136. }
  137. void EvalSchemeWidget::loadScheme(const QString scheme)
  138. {
  139. if (m_schemes.contains(scheme) == false) {
  140. return;
  141. }
  142. SchemeAndAlg s = m_schemes[scheme];
  143. m_scheme = s.scheme;
  144. m_algs.clear();
  145. m_algs.append(s.alg);
  146. refreshSchemeView();
  147. }
  148. void EvalSchemeWidget::updateButtonState()
  149. {
  150. bool e = m_scheme > 0 && m_algs.count() > 0;
  151. m_index->setEnabled(e);
  152. m_data->setEnabled(e);
  153. m_algBtn->setEnabled(e);
  154. m_clear->setEnabled(e);
  155. m_index->setChecked((m_scheme & Index) == Index);
  156. m_data->setChecked((m_scheme & Collect) == Collect);
  157. }
  158. void EvalSchemeWidget::slotShowSchemeMenu()
  159. {
  160. QPoint pos = m_schemeBtn->mapToGlobal(QPoint()) + QPoint(m_schemeBtn->width(), -10);
  161. m_schemeMenu->exec(pos, true);
  162. }
  163. void EvalSchemeWidget::slotIndexClicked()
  164. {
  165. m_scheme ^= Index;
  166. refreshSchemeView();
  167. }
  168. void EvalSchemeWidget::slotDataClicked()
  169. {
  170. m_scheme ^= Collect;
  171. refreshSchemeView();
  172. }
  173. void EvalSchemeWidget::slotAlgBtnClicked()
  174. {
  175. QPoint pos = m_algBtn->mapToGlobal(QPoint()) + QPoint(m_algBtn->width(), -10);
  176. m_algMenu->exec(pos, true);
  177. }
  178. void EvalSchemeWidget::slotClearClicked()
  179. {
  180. m_scheme = 0;
  181. m_algs.clear();
  182. refreshSchemeView();
  183. }
  184. void EvalSchemeWidget::slotSelectAlgorithm(EvalSchemeWidget::Algorithm alg)
  185. {
  186. if (m_algs.contains(alg)) {
  187. return;
  188. }
  189. m_algs.clear();
  190. m_algs.append(alg);
  191. refreshSchemeView();
  192. }