bloberosion.cpp 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. #include "bloberosion.h"
  2. #include "ui_bloberosion.h"
  3. #include "../ToolDialog.h"
  4. class ToolDialogImpl;
  5. BlobErosion::BlobErosion(QWidget *parent , ToolDialogImpl* p)
  6. : ToolInterface(parent), ui(new Ui::BlobErosion)
  7. {
  8. ui->setupUi(this);
  9. m_pToolDialogImpl = p;
  10. ui->lineEdit_Width->setText("5");
  11. ui->lineEdit_Height->setText("6");
  12. ui->lineEdit_Size->setText("1");
  13. ui->lineEdit_Width->setValidator(new QIntValidator(1, 16777215, this));
  14. ui->lineEdit_Height->setValidator(new QIntValidator(1, 16777215, this));
  15. ui->lineEdit_Size->setValidator(new QIntValidator(1, 16777215, this));
  16. ui->widget2->setVisible(false);
  17. ui->comboBox->setView(new QListView());
  18. ui->comboBox_index->setView(new QListView());
  19. if(m_pToolDialogImpl->m_LinkProcess.size() > 0)
  20. {
  21. ui->comboBox_index->setVisible(true);
  22. ui->label_index->setVisible(true);
  23. }
  24. else
  25. {
  26. ui->comboBox_index->setVisible(false);
  27. ui->label_index->setVisible(false);
  28. }
  29. for(int i = 0; i < m_pToolDialogImpl->m_LinkProcess.size(); i++)
  30. {
  31. ui->comboBox_index->addItem(QString::number(i));
  32. }
  33. }
  34. bool BlobErosion::Serialized(QDataStream& ar, bool bIsOut)
  35. {
  36. int paranum;//参数数量
  37. if (bIsOut)//保存参数流程
  38. {
  39. paranum = 6;
  40. ar << paranum;//先保存参数数量
  41. ar << (int)1 << m_nWidth;
  42. ar << (int)2 << m_nHeight;
  43. ar << (int)3 << m_nSize;
  44. ar << (int)4 << m_nType;
  45. ar << (int)5 << ui->comboBox_index->currentIndex();
  46. ar << (int)6 << ui->comboBox->currentIndex();
  47. }
  48. else//加载参数流程,参数加载顺序一定要跟保存顺序一致
  49. {
  50. int nCurrentIndex1 = 0;
  51. int nCurrentIndex2 = 0;
  52. int para;
  53. ar >> paranum;//读取参数数量
  54. for (int i = 0; i < paranum; i++)
  55. {
  56. ar >> para;
  57. switch (para)
  58. {
  59. case 1: ar >> m_nWidth; break;
  60. case 2: ar >> m_nHeight; break;
  61. case 3: ar >> m_nSize; break;
  62. case 4: ar >> m_nType; break;
  63. case 5: ar >> nCurrentIndex1; break;
  64. case 6: ar >> nCurrentIndex2; break;
  65. default:
  66. {
  67. qWarning() << "Serialized(In) Error";
  68. return false;
  69. }
  70. break;
  71. }
  72. }
  73. {
  74. ui->comboBox_index->setCurrentIndex(nCurrentIndex1);
  75. ui->comboBox->setCurrentIndex(nCurrentIndex2);
  76. ui->lineEdit_Width->setText(QString::number(m_nWidth));
  77. ui->lineEdit_Height->setText(QString::number(m_nHeight));
  78. ui->lineEdit_Size->setText(QString::number(m_nSize));
  79. emit updateParameter(ShowParameter());
  80. }
  81. }
  82. return true;
  83. }
  84. BlobErosion::~BlobErosion()
  85. {
  86. delete ui;
  87. }
  88. QString BlobErosion::ShowParameter()
  89. {
  90. QString str;
  91. m_nSize = ui->lineEdit_Size->text().toInt();
  92. m_nWidth = ui->lineEdit_Width->text().toInt();
  93. m_nHeight = ui->lineEdit_Height->text().toInt();
  94. m_nType = ui->comboBox->currentIndex();
  95. if(m_nType == 0)
  96. {
  97. str += ui->comboBox->currentText();
  98. str += ",";
  99. str += QString::number(m_nSize);
  100. }
  101. else
  102. {
  103. str += ui->comboBox->currentText();
  104. str += ",";
  105. str += QString::number(m_nWidth);
  106. str += ",";
  107. str += QString::number(m_nHeight);
  108. }
  109. return str;
  110. }
  111. int BlobErosion::Execute()
  112. {
  113. int result = 1;
  114. m_nSize = ui->lineEdit_Size->text().toInt();
  115. m_nType = ui->comboBox->currentIndex();
  116. m_nWidth = ui->lineEdit_Width->text().toInt();
  117. m_nHeight = ui->lineEdit_Height->text().toInt();
  118. try
  119. {
  120. if(ui->comboBox_index->currentIndex() == 0)
  121. {
  122. if(m_nType == 0)
  123. {
  124. ErosionCircle (m_InImage, &m_OutImage, m_nSize);
  125. }
  126. else
  127. {
  128. ErosionRectangle1 (m_InImage, &m_OutImage, m_nWidth, m_nHeight);
  129. }
  130. }
  131. else
  132. {
  133. int index = ui->comboBox_index->currentIndex() - 1;
  134. HObject inputimage = m_pToolDialogImpl->m_LinkProcess[index].p_dlg->GetResult();
  135. if(m_nType == 0)
  136. {
  137. ErosionCircle (inputimage, &m_OutImage, m_nSize);
  138. }
  139. else
  140. {
  141. ErosionRectangle1 (inputimage, &m_OutImage, m_nWidth, m_nHeight);
  142. }
  143. }
  144. }
  145. catch(...)
  146. {
  147. }
  148. return result;
  149. }
  150. void BlobErosion::on_BTN_Add1_clicked()
  151. {
  152. ui->lineEdit_Size->setText(QString::number(ui->lineEdit_Size->text().toInt() + 1));
  153. emit updateParameter(ShowParameter());
  154. }
  155. void BlobErosion::on_BTN_Sub1_clicked()
  156. {
  157. if(ui->lineEdit_Size->text().toInt() >= 2)
  158. {
  159. ui->lineEdit_Size->setText(QString::number(ui->lineEdit_Size->text().toInt() - 1));
  160. emit updateParameter(ShowParameter());
  161. }
  162. }
  163. void BlobErosion::on_BTN_Add2_clicked()
  164. {
  165. ui->lineEdit_Width->setText(QString::number(ui->lineEdit_Width->text().toInt() + 1));
  166. emit updateParameter(ShowParameter());
  167. }
  168. void BlobErosion::on_BTN_Sub2_clicked()
  169. {
  170. if(ui->lineEdit_Width->text().toInt() >= 2)
  171. {
  172. ui->lineEdit_Width->setText(QString::number(ui->lineEdit_Width->text().toInt() - 1));
  173. emit updateParameter(ShowParameter());
  174. }
  175. }
  176. void BlobErosion::on_BTN_Add3_clicked()
  177. {
  178. ui->lineEdit_Height->setText(QString::number(ui->lineEdit_Height->text().toInt() + 1));
  179. emit updateParameter(ShowParameter());
  180. }
  181. void BlobErosion::on_BTN_Sub3_clicked()
  182. {
  183. if(ui->lineEdit_Height->text().toInt() >= 2)
  184. {
  185. ui->lineEdit_Height->setText(QString::number(ui->lineEdit_Height->text().toInt() - 1));
  186. emit updateParameter(ShowParameter());
  187. }
  188. }
  189. void BlobErosion::on_lineEdit_Size_editingFinished()
  190. {
  191. emit updateParameter(ShowParameter());
  192. }
  193. void BlobErosion::on_lineEdit_Width_editingFinished()
  194. {
  195. emit updateParameter(ShowParameter());
  196. }
  197. void BlobErosion::on_lineEdit_Height_editingFinished()
  198. {
  199. emit updateParameter(ShowParameter());
  200. }
  201. void BlobErosion::on_comboBox_currentIndexChanged(int index)
  202. {
  203. emit updateParameter(ShowParameter());
  204. if(index == 0)
  205. {
  206. ui->widget1->setVisible(true);
  207. ui->widget2->setVisible(false);
  208. }
  209. else
  210. {
  211. ui->widget1->setVisible(false);
  212. ui->widget2->setVisible(true);
  213. }
  214. }
  215. void BlobErosion::on_comboBox_index_currentIndexChanged(int index)
  216. {
  217. if(index > 0)
  218. {
  219. emit updateParameterIndex(QString::number(index - 1));
  220. }
  221. emit updateParameter(ShowParameter());
  222. }