OutPIC.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. using OTSCommon.Model;
  2. using OTSIncAReportGraph;
  3. using OTSIncAReportGraph.Class;
  4. using OTSIncAReportGraph.Controls;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Data;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. using System.Windows.Forms;
  13. namespace OTSIncAReportApp._3_ServiceCenter
  14. {
  15. class OutPIC
  16. {
  17. //包含particle的field的列表对象
  18. public List<DisplayField> m_list_allDfield = null;
  19. public ResultFile resultFile = null;
  20. public SaveFileDialog sfd = null;
  21. public int type = 0;
  22. /// <summary>
  23. /// 获取每行图片的位置配合opencv方法使用
  24. /// </summary>
  25. /// <returns></returns>
  26. private List<DataTable> opencv_piclist()
  27. {
  28. List<DataTable> list_dt_picdata = new List<DataTable>();
  29. DataTable picDatat = new DataTable();
  30. picDatat.Columns.Add("X", typeof(double));
  31. picDatat.Columns.Add("Y", typeof(double));
  32. foreach (var f in m_list_allDfield)
  33. {
  34. DataRow dr = picDatat.NewRow();
  35. dr["X"] = f.GetShowRect().X;
  36. dr["Y"] = f.GetShowRect().Y;
  37. picDatat.Rows.Add(dr);
  38. }
  39. int y_max = Convert.ToInt32(picDatat.Compute("Max(Y)", "true"));
  40. int y_min = Convert.ToInt32(picDatat.Compute("Min(Y)", "true"));
  41. DataTable total_dt_X = picDatat.Copy();
  42. DataView dv_x = total_dt_X.DefaultView;
  43. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  44. dv_x_2.Sort = "X ASC";
  45. total_dt_X = dv_x_2.ToTable();
  46. DataTable total_dt_Y = picDatat.Copy();
  47. DataView dv_Y = total_dt_Y.DefaultView;
  48. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  49. dv_Y_2.Sort = "Y ASC";
  50. total_dt_Y = dv_Y_2.ToTable();
  51. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  52. {
  53. NLog.LogManager.GetCurrentClassLogger().Info("Splice line"+i+1.ToString()+"of"+ total_dt_Y.Rows.Count.ToString()+".....");
  54. DataTable data = new DataTable();
  55. data.Columns.Add("mat", typeof(Bitmap));
  56. data.Columns.Add("X", typeof(double));
  57. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  58. {
  59. DataRow dr2 = data.NewRow();
  60. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].GetShowRect().Width, (int)m_list_allDfield[0].GetShowRect().Height);
  61. Graphics g = Graphics.FromImage(bitmap);
  62. g.Clear(Color.White);
  63. g.Dispose();
  64. dr2["mat"] = bitmap;
  65. dr2["X"] = total_dt_X.Rows[a]["X"];
  66. data.Rows.Add(dr2);
  67. }
  68. foreach (var f in m_list_allDfield)
  69. {
  70. if (total_dt_Y.Rows[i]["Y"].ToString() == f.GetShowRect().Y.ToString())
  71. {
  72. for (int c = 0; c < data.Rows.Count; c++)
  73. {
  74. if (data.Rows[c]["X"].ToString() == f.GetShowRect().X.ToString())
  75. {
  76. data.Rows[c]["mat"] = f.OriginalImage;
  77. data.Rows[c]["X"] = f.GetShowRect().X;
  78. }
  79. }
  80. }
  81. }
  82. DataView dataView1 = data.DefaultView;
  83. dataView1.Sort = "X ASC";
  84. data = dataView1.ToTable();
  85. list_dt_picdata.Add(data);
  86. }
  87. return list_dt_picdata;
  88. }
  89. public void opencv_outpic(/*int type*/)
  90. {
  91. List<DataTable> list_dt_picdata = new List<DataTable>();
  92. if (type == (int)Outpic_enum.pic)
  93. {
  94. list_dt_picdata = opencv_piclist();
  95. }
  96. else
  97. if (type == (int)Outpic_enum.Render_pic)
  98. {
  99. list_dt_picdata = opencv_piclist_Render();
  100. }
  101. OpenCvSharp.Mat[] list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  102. NLog.LogManager.GetCurrentClassLogger().Info("Organize and splice all pictures......");
  103. for (int i = 0; i < list_dt_picdata.Count; i++)
  104. {
  105. OpenCvSharp.Mat[] mats = new OpenCvSharp.Mat[list_dt_picdata[i].Rows.Count];
  106. for (int a = 0; a < list_dt_picdata[i].Rows.Count; a++)
  107. {
  108. mats[a] = OpenCvSharp.Extensions.BitmapConverter.ToMat((Bitmap)list_dt_picdata[i].Rows[a]["mat"]);
  109. }
  110. OpenCvSharp.Mat pano = new OpenCvSharp.Mat();
  111. OpenCvSharp.Cv2.HConcat(mats, pano);
  112. list_mats[i] = pano;
  113. }
  114. NLog.LogManager.GetCurrentClassLogger().Info("Picture splicing completed.");
  115. NLog.LogManager.GetCurrentClassLogger().Info("Save to disk......");
  116. OpenCvSharp.Mat save_pano = new OpenCvSharp.Mat();
  117. OpenCvSharp.Cv2.VConcat(list_mats, save_pano);
  118. OpenCvSharp.Cv2.ImWrite(sfd.FileName, save_pano);
  119. NLog.LogManager.GetCurrentClassLogger().Info("Save complete.");
  120. }
  121. private List<DataTable> opencv_piclist_Render()
  122. {
  123. List<DataTable> list_dt_picdata = new List<DataTable>();
  124. DataTable picDatat = new DataTable();
  125. List<Field> fieldlist = resultFile.List_OTSField;
  126. picDatat.Columns.Add("X", typeof(double));
  127. picDatat.Columns.Add("Y", typeof(double));
  128. foreach (var f in m_list_allDfield)
  129. {
  130. DataRow dr = picDatat.NewRow();
  131. dr["X"] = f.GetShowRect().X;
  132. dr["Y"] = f.GetShowRect().Y;
  133. picDatat.Rows.Add(dr);
  134. }
  135. int y_max = Convert.ToInt32(picDatat.Compute("Max(Y)", "true"));
  136. int y_min = Convert.ToInt32(picDatat.Compute("Min(Y)", "true"));
  137. DataTable total_dt_X = picDatat.Copy();
  138. DataView dv_x = total_dt_X.DefaultView;
  139. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  140. dv_x_2.Sort = "X ASC";
  141. total_dt_X = dv_x_2.ToTable();
  142. DataTable total_dt_Y = picDatat.Copy();
  143. DataView dv_Y = total_dt_Y.DefaultView;
  144. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  145. dv_Y_2.Sort = "Y ASC";
  146. total_dt_Y = dv_Y_2.ToTable();
  147. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  148. {
  149. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  150. DataTable data = new DataTable();
  151. data.Columns.Add("mat", typeof(Bitmap));
  152. data.Columns.Add("X", typeof(double));
  153. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  154. {
  155. DataRow dr2 = data.NewRow();
  156. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].GetShowRect().Width, (int)m_list_allDfield[0].GetShowRect().Height);
  157. Graphics g = Graphics.FromImage(bitmap);
  158. g.Clear(Color.White);
  159. g.Dispose();
  160. dr2["mat"] = bitmap;
  161. dr2["X"] = total_dt_X.Rows[a]["X"];
  162. data.Rows.Add(dr2);
  163. }
  164. foreach (var f in m_list_allDfield)
  165. {
  166. if (total_dt_Y.Rows[i]["Y"].ToString() == f.GetShowRect().Y.ToString())
  167. {
  168. for (int c = 0; c < data.Rows.Count; c++)
  169. {
  170. if (data.Rows[c]["X"].ToString() == f.GetShowRect().X.ToString())
  171. {
  172. Bitmap image = new Bitmap(f.OriginalImage.Width, f.OriginalImage.Height);
  173. Graphics g2 = Graphics.FromImage(image);
  174. g2.DrawImage(f.OriginalImage, 0, 0, f.OriginalImage.Width, f.OriginalImage.Height);
  175. Graphics graph_2 = Graphics.FromImage(image);
  176. for (int a = 0; a < fieldlist.Count; a++)
  177. {
  178. if (fieldlist[a].FieldID.ToString() == f.FieldID.ToString())
  179. {
  180. //先获取该Field中的所有Particle
  181. List<Particle> list_particle;
  182. list_particle = fieldlist[a].ParticleList;
  183. //再循环计算所有的Particle对象
  184. foreach (Particle particle in list_particle)
  185. {
  186. List<Segment> list_seg;
  187. list_seg = particle.SegmentList;
  188. //创建颗粒分布图对应的类对象
  189. List<DisplaySegment> list_dsegment = new List<DisplaySegment>();
  190. //再循环取出里面所有的segment
  191. foreach (Segment seg in list_seg)
  192. {
  193. #region 创建DSegment对象,并将STD分析出的化合物颜色保存到DSegment对象中
  194. Point on_p = new Point() { X = seg.Start, Y = seg.Height };
  195. Point off_p = new Point() { X = seg.Start + seg.Length, Y = seg.Height };
  196. var color = DrawFunction.GetColorBySTDTypeIDForBSEAndSorImage(particle.TypeColor, particle.TypeId);
  197. Pen npen = new Pen(color);
  198. graph_2.DrawLine(npen, on_p, off_p);
  199. #endregion
  200. }
  201. }
  202. }
  203. }
  204. data.Rows[c]["mat"] = image;
  205. data.Rows[c]["X"] = f.GetShowRect().X;
  206. }
  207. }
  208. }
  209. }
  210. DataView dataView1 = data.DefaultView;
  211. dataView1.Sort = "X ASC";
  212. data = dataView1.ToTable();
  213. list_dt_picdata.Add(data);
  214. }
  215. return list_dt_picdata;
  216. }
  217. }
  218. }