ImageExporter.cs 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614
  1. using OpenCvSharp;
  2. using OpenCvSharp.Extensions;
  3. using OTSCommon.DBOperate.Model;
  4. using OTSIncAReportApp._1_UI.Control_Graph.Controls;
  5. using OTSIncAReportApp.DataOperation.DataAccess;
  6. using OTSIncAReportApp.OTSRstMgrFunction;
  7. using OTSIncAReportGraph;
  8. using OTSIncAReportGraph.Class;
  9. using OTSIncAReportGraph.Controls;
  10. using OTSMeasureApp.ServiceCenter;
  11. using OTSModelSharp.ServiceCenter;
  12. using System;
  13. using System.Collections.Generic;
  14. using System.Data;
  15. using System.Drawing;
  16. using System.IO;
  17. using System.Linq;
  18. using System.Text;
  19. using System.Threading.Tasks;
  20. using System.Windows.Forms;
  21. namespace OTSIncAReportApp._3_ServiceCenter
  22. {
  23. class ImageExporter
  24. {
  25. public OTSIncAReportApp.frmReportApp m_ReportApp;
  26. //包含particle的field的列表对象
  27. public List<DisplayRectangle> m_list_allDfield = null;
  28. public ResultFile resultFile = null;
  29. public SaveFileDialog sfd = null;
  30. public DataTable ParticleData = new DataTable();
  31. public DataTable ParticleClassData = new DataTable();
  32. /// <summary>
  33. /// 国标一框框
  34. /// </summary>
  35. public DataTable GBDatatableOne { get; set; }
  36. /// <summary>
  37. ///国标格子大小(像素)
  38. /// </summary>
  39. public int GridLength { get; set; }
  40. public int type = 0;
  41. //像素大小
  42. public double pixelSize = 0;
  43. private double picGBYmin = 0;
  44. private double OverlapParamPX = 0;
  45. public void opencv_outpic()
  46. {
  47. ImageSplicer imageSplicer = new ImageSplicer();
  48. Dictionary<string, object> sampleMembers = ((Dictionary<string, object>)((Dictionary<string, object>)resultFile.ResultInfo["Sample"])["Members"]);
  49. Dictionary<string, object> imageProcessParam = (Dictionary<string, object>)((Dictionary<string, object>)((Dictionary<string, object>)sampleMembers["MsrParams"])["Members"])["ImageProcessParam"];
  50. object strOverlapParam = "";
  51. imageProcessParam.TryGetValue("OverlapParam", out strOverlapParam);
  52. if (strOverlapParam == null)
  53. {
  54. strOverlapParam = "0";
  55. //NLog.LogManager.GetCurrentClassLogger().Info("There are no overlapping dimensions");
  56. //return;
  57. }
  58. //获取图像重叠参数(微米需要转换成像素)
  59. int OverlapParam = int.Parse(strOverlapParam.ToString());
  60. if (OverlapParam==0)
  61. {
  62. OverlapParamPX = 0;
  63. }else
  64. {
  65. OverlapParamPX = OverlapParam / pixelSize;
  66. }
  67. List<DataTable> list_dt_picdata = new List<DataTable>();
  68. OpenCvSharp.Mat[] list_mats;
  69. //导出拼接图片外加颗粒渲染
  70. if (type ==(int)Outpic_enum.ColoredParticles)
  71. {
  72. list_dt_picdata = imageSplicer.ImageStitchingParticleRendering(resultFile, m_list_allDfield);
  73. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  74. }
  75. //导出国标外加颗粒渲染
  76. else if (type == (int)Outpic_enum.GBOne)
  77. {
  78. list_dt_picdata = imageSplicer.ImageStitchingParticleRendering(resultFile, m_list_allDfield);
  79. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  80. }
  81. //导出拼接图片
  82. else
  83. {
  84. list_dt_picdata = imageSplicer.Mosaics(resultFile, m_list_allDfield);
  85. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  86. }
  87. NLog.LogManager.GetCurrentClassLogger().Info("Organize and splice all pictures......");
  88. List<OpenCvSharp.Mat> list_pano = new List<OpenCvSharp.Mat>();
  89. List<Bitmap> list_panos = new List<Bitmap>();
  90. //循环保存每行拼接的图片
  91. for (int i = list_dt_picdata.Count-1; i >= 0; i--)
  92. {
  93. // 计算新Bitmap的总宽度和高度
  94. int totalWidth = 0;
  95. int maxHeight = 0;
  96. for ( int c=0;c< list_dt_picdata[i].Rows.Count;c++)
  97. {
  98. Bitmap bitmap = (Bitmap)list_dt_picdata[i].Rows[c]["mat"];
  99. totalWidth += bitmap.Width; // 减去重叠部分将在绘制时处理
  100. maxHeight = Math.Max(maxHeight, bitmap.Height);
  101. }
  102. // 因为有n张图片,它们之间会有n-1个重叠区域,所以需要从总宽度中减去这些重叠的像素
  103. // 注意:如果图片数量小于2,则不需要减去任何重叠部分
  104. if (list_dt_picdata[i].Rows.Count > 1)
  105. {
  106. totalWidth -= (list_dt_picdata[i].Rows.Count - 1) * (int)OverlapParamPX;
  107. }
  108. // 创建一个新的Bitmap对象来存储拼接后的图像
  109. Bitmap combinedImage = new Bitmap(totalWidth, maxHeight);
  110. // 使用Graphics对象来绘制拼接后的图像
  111. using (Graphics g = Graphics.FromImage(combinedImage))
  112. {
  113. int currentX = 0;
  114. for (int b=0;b< list_dt_picdata[i].Rows.Count; b++)
  115. {
  116. Bitmap bitmap = (Bitmap)list_dt_picdata[i].Rows[b]["mat"];
  117. // 绘制当前图片,注意调整X坐标以实现重叠
  118. g.DrawImage(bitmap, new Rectangle(currentX, 0, bitmap.Width, bitmap.Height));
  119. // 更新当前X坐标,为下一张图片留出空间(包括重叠部分)
  120. currentX += bitmap.Width - (list_dt_picdata[i].Rows.Count > 1 ? (int)OverlapParamPX : 0); // 如果不是最后一张图片,则减去重叠的20像素
  121. }
  122. }
  123. Mat mat = BitmapConverter.ToMat(combinedImage);
  124. list_pano.Add(mat);
  125. list_panos.Add(combinedImage);
  126. }
  127. //导出原图(渲染图)在下方增加每种颜色的标注和面积占比
  128. if (type == (int)Outpic_enum.ColoredParticles || type == (int)Outpic_enum.GBOne)
  129. {
  130. DataTable particleData = ParticleDataIntegration(ParticleData, ParticleClassData);
  131. int NumberOfRows = getPICstringLong(particleData, list_pano);
  132. Bitmap bitmap = new Bitmap(list_pano[0].Width, NumberOfRows*140);
  133. Graphics g = Graphics.FromImage(bitmap);
  134. g.Clear(Color.White);
  135. int rowData = 10;
  136. //矩形格子宽500
  137. SolidBrush mysbrush1 = new SolidBrush(ColorTranslator.FromHtml("#000000"));
  138. Pen mypen = new Pen(mysbrush1, 2);
  139. Font myFont = new Font("宋体", 13, FontStyle.Bold);
  140. SolidBrush sbrush = new SolidBrush(Color.Black);
  141. int Color_Y = 10; int TypeName_Y = 40; int Prozentsatz_Y = 100;int Area_Y = 70;
  142. int Gitter_X = 10;
  143. picKopfzeile(mypen, myFont, sbrush, g, 10, rowData);
  144. Gitter_X = Gitter_X + 350;
  145. for (int i = 0; i < particleData.Rows.Count; i++)
  146. {
  147. if (Gitter_X+350> list_pano[0].Width)
  148. {
  149. rowData = rowData + 130;
  150. picKopfzeile(mypen, myFont, sbrush, g, 10, rowData);
  151. Color_Y = Color_Y + 130;
  152. TypeName_Y = TypeName_Y + 130;
  153. Prozentsatz_Y = Prozentsatz_Y + 130;
  154. Area_Y = Area_Y + 130;
  155. Gitter_X = 360;
  156. }
  157. g.DrawRectangle(mypen, Gitter_X, Color_Y, 350, 30);
  158. g.DrawRectangle(mypen, Gitter_X, TypeName_Y, 350, 30);
  159. g.DrawRectangle(mypen, Gitter_X, Area_Y, 350, 30);
  160. g.DrawRectangle(mypen, Gitter_X, Prozentsatz_Y, 350, 30);
  161. SolidBrush mysbrush = new SolidBrush(ColorTranslator.FromHtml(particleData.Rows[i]["Color"].ToString()));
  162. g.FillRectangle(mysbrush, Gitter_X + 1, Color_Y + 1, 348, 28);
  163. g.DrawString(particleData.Rows[i]["TypeName"].ToString(), myFont, sbrush, Gitter_X + 1, TypeName_Y + 2);
  164. g.DrawString(particleData.Rows[i]["Area"].ToString(), myFont, sbrush, Gitter_X + 1, Area_Y + 2);
  165. g.DrawString(particleData.Rows[i]["Percentage"].ToString()+"%", myFont, sbrush, Gitter_X + 1, Prozentsatz_Y + 2);
  166. Gitter_X = Gitter_X + 350;
  167. }
  168. list_panos.Add(bitmap);
  169. g.Dispose();
  170. }
  171. Bitmap combined = MergeImagesVertically(list_panos, (int)OverlapParamPX);
  172. NLog.LogManager.GetCurrentClassLogger().Info("Picture splicing completed.");
  173. NLog.LogManager.GetCurrentClassLogger().Info("Save to disk......");
  174. OpenCvSharp.Mat save_pano = BitmapConverter.ToMat(combined);
  175. if (type == (int)Outpic_enum.GBOne)
  176. {
  177. imageSplicer.DrawingOfNationalStandardBoxes(GBDatatableOne, GridLength, save_pano);
  178. }
  179. OpenCvSharp.Cv2.ImWrite(sfd.FileName, save_pano);
  180. NLog.LogManager.GetCurrentClassLogger().Info("Save complete.");
  181. Control_DrawDistrbutionImageAndBSE v = m_ReportApp.im_Control_DrawDistrbutionImageAndBSE;
  182. MyEvent += new MyEntrust(v.msgInform);
  183. v.Invoke(MyEvent);
  184. }
  185. private Bitmap MergeImagesVertically(List<Bitmap> images, int overlap)
  186. {
  187. if (images == null || images.Count == 0)
  188. {
  189. throw new ArgumentException("输入的图片数组不能为空或没有元素");
  190. }
  191. // 计算新Bitmap的宽度和高度
  192. int totalWidth = 0;
  193. int totalHeight = 0;
  194. // 找到最宽的宽度
  195. foreach (var img in images)
  196. {
  197. if (img.Width > totalWidth)
  198. {
  199. totalWidth = img.Width;
  200. }
  201. //totalHeight += img.Height - (img != images[images.Count - 1] ? overlap : 0); // 最后一张图片不减去重叠
  202. }
  203. int imgHeight = (int)OverlapParamPX * (images.Count - 1);
  204. totalHeight = images[0].Height * (images.Count-1) - imgHeight;
  205. // 为最后一张图片添加完整的高度
  206. if (images.Count > 1)
  207. {
  208. totalHeight += images[images.Count - 1].Height;
  209. }
  210. else
  211. {
  212. // 如果只有一张图片,则不需要调整高度
  213. totalHeight = images[0].Height;
  214. }
  215. Bitmap result = new Bitmap(totalWidth, totalHeight);
  216. using (Graphics g = Graphics.FromImage(result))
  217. {
  218. g.Clear(Color.Transparent); // 或者设置为其他背景色
  219. int offsetY = 0;
  220. foreach (var img in images)
  221. {
  222. // 绘制图片,考虑重叠部分
  223. g.DrawImage(img, new Rectangle(0, offsetY, img.Width, img.Height));
  224. // 更新偏移量
  225. offsetY += img.Height - (img != images[images.Count - 1] ? overlap : 0);
  226. }
  227. }
  228. return result;
  229. }
  230. private int getPICstringLong(DataTable particleData, List<OpenCvSharp.Mat> list_pano)
  231. {
  232. int Long = 1;
  233. int Gitter_X = 10;
  234. for (int i = 0; i < particleData.Rows.Count; i++)
  235. {
  236. if (Gitter_X + 350 > list_pano[0].Width)
  237. {
  238. Long = Long + 1;
  239. Gitter_X = 10;
  240. }
  241. Gitter_X = Gitter_X + 350;
  242. }
  243. return Long;
  244. }
  245. private void picKopfzeile(Pen mypen, Font myFont, SolidBrush sbrush, Graphics g ,int X,int Y)
  246. {
  247. int Color_Y = Y; int TypeName_Y = Y+30; int Prozentsatz_Y = Y + 90; int Area_Y = Y+ 60;
  248. int Gitter_X = X;
  249. g.DrawRectangle(mypen, Gitter_X, Color_Y, 350, 30);
  250. g.DrawRectangle(mypen, Gitter_X, TypeName_Y, 350, 30);
  251. g.DrawRectangle(mypen, Gitter_X, Area_Y, 350, 30);
  252. g.DrawRectangle(mypen, Gitter_X, Prozentsatz_Y, 350, 30);
  253. g.DrawString("Color", myFont, sbrush, Gitter_X + 1, Color_Y + 2);
  254. g.DrawString("TypeName", myFont, sbrush, Gitter_X + 1, TypeName_Y + 2);
  255. g.DrawString("Area", myFont, sbrush, Gitter_X + 1, Area_Y + 2);
  256. g.DrawString("Prozentsatz", myFont, sbrush, Gitter_X + 1, Prozentsatz_Y + 2);
  257. }
  258. private DataTable ParticleDataIntegration(DataTable ParticleAll,DataTable ParticleClass)
  259. {
  260. double totalArea = m_list_allDfield[0].OriginalImage.Height * pixelSize * m_list_allDfield[0].OriginalImage.Width * pixelSize * m_list_allDfield.Count;
  261. DataTable dt = ParticleClass.Copy();
  262. dt.Columns.Add("Area", typeof(float));
  263. dt.Columns.Add("Percentage");
  264. dt.Columns.Add("Color");
  265. double ParticleAreaTotal = 0;
  266. for (int i=0;i< ParticleAll.Rows.Count;i++)
  267. {
  268. ParticleAreaTotal = ParticleAreaTotal + Convert.ToDouble(ParticleAll.Rows[i]["Area"]);
  269. }
  270. for (int i=0;i< dt.Rows.Count;i++)
  271. {
  272. double ParticleArea = 0;
  273. string ParticleColer = "";
  274. for (int a=0;a< ParticleAll.Rows.Count;a++)
  275. {
  276. if (dt.Rows[i]["TypeName"].ToString()== ParticleAll.Rows[a]["TypeName"].ToString())
  277. {
  278. ParticleArea = ParticleArea + Convert.ToDouble(ParticleAll.Rows[a]["Area"]);
  279. ParticleColer = ParticleAll.Rows[a]["TypeColor"].ToString();
  280. }
  281. }
  282. dt.Rows[i]["Area"] = ParticleArea;
  283. dt.Rows[i]["Percentage"] = ParameterNormalization(totalArea, ParticleArea);
  284. //dt.Rows[i]["Percentage"] = ParameterNormalization(ParticleAreaTotal, ParticleArea);
  285. dt.Rows[i]["Color"] = ParticleColer;
  286. }
  287. return dt;
  288. }
  289. /// <summary>
  290. /// 参数归一化
  291. /// </summary>
  292. /// <param name="a_mi">总数</param>
  293. /// <param name="m">传参</param>
  294. /// <returns></returns>
  295. private string ParameterNormalization(double a_mi, double m)
  296. {
  297. double ColVal = Convert.ToDouble(m / a_mi * 100);
  298. if (ColVal == 0)
  299. {
  300. return "";
  301. }
  302. else
  303. {
  304. return Math.Round(ColVal, 6).ToString();
  305. }
  306. }
  307. #region 合并天宇颗粒融合新增函数
  308. public void opencv_outpic2(/*int type*/)
  309. {
  310. List<DataTable> list_dt_picdata = new List<DataTable>();
  311. if (type == (int)Outpic_enum.pic || type == (int)Outpic_enum.Combin)
  312. {
  313. list_dt_picdata = opencv_piclist2();
  314. }
  315. else if (type == (int)Outpic_enum.Render_pic || type == (int)Outpic_enum.Render_Combin)
  316. {
  317. list_dt_picdata = opencv_piclist_Render2();
  318. }
  319. OpenCvSharp.Mat save_pano = new OpenCvSharp.Mat();
  320. OpenCvSharp.Mat[] list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  321. if (type == (int)Outpic_enum.Combin || type == (int)Outpic_enum.Render_Combin)
  322. {
  323. ImageStitchUsingOpenCvSharp cImageHandler = new ImageStitchUsingOpenCvSharp();
  324. Dictionary<string, object> sampleMembers = ((Dictionary<string, object>)((Dictionary<string, object>)resultFile.ResultInfo["Sample"])["Members"]);
  325. Dictionary<string, object> imageProcessParam = (Dictionary<string, object>)((Dictionary<string, object>)((Dictionary<string, object>)sampleMembers["MsrParams"])["Members"])["ImageProcessParam"];
  326. object strOverlapParam = "";
  327. imageProcessParam.TryGetValue("OverlapParam", out strOverlapParam);
  328. if (strOverlapParam == null)
  329. {
  330. NLog.LogManager.GetCurrentClassLogger().Info("There are no overlapping dimensions");
  331. return;
  332. }
  333. int OverlapParam = int.Parse(strOverlapParam.ToString());
  334. List<OpenCvSharp.Mat> maxXList = new List<OpenCvSharp.Mat>();
  335. for (int i = 0; i < list_dt_picdata.Count; i++)
  336. {
  337. OpenCvSharp.Mat[] mats = new OpenCvSharp.Mat[list_dt_picdata[i].Rows.Count];
  338. for (int a = 0; a < list_dt_picdata[i].Rows.Count; a++)
  339. {
  340. mats[a] = OpenCvSharp.Extensions.BitmapConverter.ToMat((Bitmap)list_dt_picdata[i].Rows[a]["mat"]);
  341. }
  342. //横向拼接
  343. maxXList.Add(cImageHandler.CombinImageX(mats, OverlapParam, type));
  344. }
  345. save_pano = cImageHandler.CombinImageY(maxXList.ToArray(), OverlapParam, type);
  346. OpenCvSharp.Cv2.ImWrite(sfd.FileName, save_pano);
  347. NLog.LogManager.GetCurrentClassLogger().Info("Save complete.");
  348. }
  349. else
  350. {
  351. NLog.LogManager.GetCurrentClassLogger().Info("Organize and splice all pictures......");
  352. for (int i = 0; i < list_dt_picdata.Count; i++)
  353. {
  354. OpenCvSharp.Mat[] mats = new OpenCvSharp.Mat[list_dt_picdata[i].Rows.Count];
  355. for (int a = 0; a < list_dt_picdata[i].Rows.Count; a++)
  356. {
  357. mats[a] = OpenCvSharp.Extensions.BitmapConverter.ToMat((Bitmap)list_dt_picdata[i].Rows[a]["mat"]);
  358. }
  359. OpenCvSharp.Mat pano = new OpenCvSharp.Mat();
  360. OpenCvSharp.Cv2.HConcat(mats, pano);
  361. list_mats[i] = pano;
  362. }
  363. NLog.LogManager.GetCurrentClassLogger().Info("Picture splicing completed.");
  364. NLog.LogManager.GetCurrentClassLogger().Info("Save to disk......");
  365. OpenCvSharp.Cv2.VConcat(list_mats, save_pano);
  366. OpenCvSharp.Cv2.ImWrite(sfd.FileName, save_pano);
  367. NLog.LogManager.GetCurrentClassLogger().Info("Save complete.");
  368. }
  369. }
  370. private List<DataTable> opencv_piclist_Render2()
  371. {
  372. List<DataTable> list_dt_picdata = new List<DataTable>();
  373. DataTable picDatat = new DataTable();
  374. List<Field> fieldlist = resultFile.List_OTSField;
  375. picDatat.Columns.Add("X", typeof(double));
  376. picDatat.Columns.Add("Y", typeof(double));
  377. foreach (var f in m_list_allDfield)
  378. {
  379. DataRow dr = picDatat.NewRow();
  380. dr["X"] = f.GetShowRect().X;
  381. dr["Y"] = f.GetShowRect().Y;
  382. picDatat.Rows.Add(dr);
  383. }
  384. int y_max = Convert.ToInt32(picDatat.Compute("Max(Y)", "true"));
  385. int y_min = Convert.ToInt32(picDatat.Compute("Min(Y)", "true"));
  386. DataTable total_dt_X = picDatat.Copy();
  387. DataView dv_x = total_dt_X.DefaultView;
  388. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  389. dv_x_2.Sort = "X ASC";
  390. total_dt_X = dv_x_2.ToTable();
  391. DataTable total_dt_Y = picDatat.Copy();
  392. DataView dv_Y = total_dt_Y.DefaultView;
  393. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  394. dv_Y_2.Sort = "Y ASC";
  395. total_dt_Y = dv_Y_2.ToTable();
  396. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  397. {
  398. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  399. DataTable data = new DataTable();
  400. data.Columns.Add("mat", typeof(Bitmap));
  401. data.Columns.Add("X", typeof(double));
  402. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  403. {
  404. DataRow dr2 = data.NewRow();
  405. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].GetShowRect().Width, (int)m_list_allDfield[0].GetShowRect().Height);
  406. Graphics g = Graphics.FromImage(bitmap);
  407. g.Clear(Color.White);
  408. g.Dispose();
  409. dr2["mat"] = bitmap;
  410. dr2["X"] = total_dt_X.Rows[a]["X"];
  411. data.Rows.Add(dr2);
  412. }
  413. foreach (var f in m_list_allDfield)
  414. {
  415. if (total_dt_Y.Rows[i]["Y"].ToString() == f.GetShowRect().Y.ToString())
  416. {
  417. for (int c = 0; c < data.Rows.Count; c++)
  418. {
  419. if (data.Rows[c]["X"].ToString() == f.GetShowRect().X.ToString())
  420. {
  421. Bitmap image = new Bitmap(f.OriginalImage.Width, f.OriginalImage.Height);
  422. Graphics g2 = Graphics.FromImage(image);
  423. g2.DrawImage(f.OriginalImage, 0, 0, f.OriginalImage.Width, f.OriginalImage.Height);
  424. Graphics graph_2 = Graphics.FromImage(image);
  425. for (int a = 0; a < fieldlist.Count; a++)
  426. {
  427. if (fieldlist[a].FieldID.ToString() == f.FieldID.ToString())
  428. {
  429. //先获取该Field中的所有Particle
  430. List<Particle> list_particle;
  431. list_particle = fieldlist[a].ParticleList;
  432. //再循环计算所有的Particle对象
  433. foreach (Particle particle in list_particle)
  434. {
  435. //创建DParticle颗粒
  436. DisplayParticle dp = new DisplayParticle(particle);
  437. List<Segment> list_seg;
  438. list_seg = particle.SegmentList;
  439. //创建颗粒分布图对应的类对象
  440. List<DisplaySegment> list_dsegment = new List<DisplaySegment>();
  441. //再循环取出里面所有的segment
  442. foreach (Segment seg in list_seg)
  443. {
  444. #region 创建DSegment对象,并将STD分析出的化合物颜色保存到DSegment对象中
  445. System.Drawing.Point on_p = new System.Drawing.Point() { X = seg.Start, Y = seg.Height };
  446. System.Drawing.Point off_p = new System.Drawing.Point() { X = seg.Start + seg.Length, Y = seg.Height };
  447. Pen npen = new Pen(dp.Color);
  448. graph_2.DrawLine(npen, on_p, off_p);
  449. #endregion
  450. }
  451. }
  452. }
  453. }
  454. data.Rows[c]["mat"] = image;
  455. data.Rows[c]["X"] = f.GetShowRect().X;
  456. }
  457. }
  458. }
  459. }
  460. DataView dataView1 = data.DefaultView;
  461. dataView1.Sort = "X ASC";
  462. data = dataView1.ToTable();
  463. list_dt_picdata.Add(data);
  464. }
  465. return list_dt_picdata;
  466. }
  467. /// <summary>
  468. /// 获取每行图片的位置配合opencv方法使用
  469. /// </summary>
  470. /// <returns></returns>
  471. private List<DataTable> opencv_piclist2()
  472. {
  473. List<DataTable> list_dt_picdata = new List<DataTable>();
  474. DataTable picDatat = new DataTable();
  475. picDatat.Columns.Add("X", typeof(double));
  476. picDatat.Columns.Add("Y", typeof(double));
  477. foreach (var f in m_list_allDfield)
  478. {
  479. DataRow dr = picDatat.NewRow();
  480. dr["X"] = f.GetShowRect().X;
  481. dr["Y"] = f.GetShowRect().Y;
  482. picDatat.Rows.Add(dr);
  483. }
  484. int y_max = Convert.ToInt32(picDatat.Compute("Max(Y)", "true"));
  485. int y_min = Convert.ToInt32(picDatat.Compute("Min(Y)", "true"));
  486. DataTable total_dt_X = picDatat.Copy();
  487. DataView dv_x = total_dt_X.DefaultView;
  488. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  489. dv_x_2.Sort = "X ASC";
  490. total_dt_X = dv_x_2.ToTable();
  491. DataTable total_dt_Y = picDatat.Copy();
  492. DataView dv_Y = total_dt_Y.DefaultView;
  493. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  494. dv_Y_2.Sort = "Y ASC";
  495. total_dt_Y = dv_Y_2.ToTable();
  496. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  497. {
  498. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  499. DataTable data = new DataTable();
  500. data.Columns.Add("mat", typeof(Bitmap));
  501. data.Columns.Add("X", typeof(double));
  502. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  503. {
  504. DataRow dr2 = data.NewRow();
  505. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].GetShowRect().Width, (int)m_list_allDfield[0].GetShowRect().Height);
  506. Graphics g = Graphics.FromImage(bitmap);
  507. g.Clear(Color.White);
  508. g.Dispose();
  509. dr2["mat"] = bitmap;
  510. dr2["X"] = total_dt_X.Rows[a]["X"];
  511. data.Rows.Add(dr2);
  512. }
  513. foreach (var f in m_list_allDfield)
  514. {
  515. if (total_dt_Y.Rows[i]["Y"].ToString() == f.GetShowRect().Y.ToString())
  516. {
  517. for (int c = 0; c < data.Rows.Count; c++)
  518. {
  519. if (data.Rows[c]["X"].ToString() == f.GetShowRect().X.ToString())
  520. {
  521. data.Rows[c]["mat"] = f.OriginalImage;
  522. data.Rows[c]["X"] = f.GetShowRect().X;
  523. }
  524. }
  525. }
  526. }
  527. DataView dataView1 = data.DefaultView;
  528. dataView1.Sort = "X ASC";
  529. data = dataView1.ToTable();
  530. list_dt_picdata.Add(data);
  531. }
  532. return list_dt_picdata;
  533. }
  534. #endregion
  535. public delegate void MyEntrust();
  536. public event MyEntrust MyEvent;
  537. }
  538. }