OutPIC.cs 13 KB

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