OutPIC.cs 48 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057
  1. using OpenCvSharp;
  2. using OTSCommon.Model;
  3. using OTSIncAReportGraph;
  4. using OTSIncAReportGraph.Class;
  5. using OTSIncAReportGraph.Controls;
  6. using OTSModelSharp.ServiceCenter;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Data;
  10. using System.Drawing;
  11. using System.Linq;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. using System.Windows.Forms;
  15. namespace OTSIncAReportApp._3_ServiceCenter
  16. {
  17. class OutPIC
  18. {
  19. public OTSIncAReportApp.frmReportApp m_ReportApp;
  20. //包含particle的field的列表对象
  21. public List<DisplayField> m_list_allDfield = null;
  22. public ResultFile resultFile = null;
  23. public SaveFileDialog sfd = null;
  24. public DataTable ParticleData = new DataTable();
  25. public DataTable ParticleClassData = new DataTable();
  26. /// <summary>
  27. /// 国标一框框
  28. /// </summary>
  29. public DataTable GBDatatableOne { get; set; }
  30. /// <summary>
  31. ///国标格子大小(像素)
  32. /// </summary>
  33. public int GridLength { get; set; }
  34. public int type = 0;
  35. private double picYmin = 0;
  36. private double picGBYmin = 0;
  37. private int imgeH = 0;
  38. private int imgeW = 0;
  39. /// <summary>
  40. /// 获取每行图片的位置配合opencv方法使用
  41. /// </summary>
  42. /// <returns></returns>
  43. private List<DataTable> opencv_piclist()
  44. {
  45. List<DataTable> list_dt_picdata = new List<DataTable>();
  46. DataTable picDatat = new DataTable();
  47. picDatat.Columns.Add("X", typeof(double));
  48. picDatat.Columns.Add("Y", typeof(double));
  49. foreach (var f in m_list_allDfield)
  50. {
  51. DataRow dr = picDatat.NewRow();
  52. dr["X"] = f.OTSCoordinatePos.X;
  53. dr["Y"] = f.OTSCoordinatePos.Y;
  54. picDatat.Rows.Add(dr);
  55. }
  56. DataTable total_dt_X = picDatat.Copy();
  57. DataView dv_x = total_dt_X.DefaultView;
  58. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  59. dv_x_2.Sort = "X ASC";
  60. total_dt_X = dv_x_2.ToTable();
  61. DataTable total_dt_Y = picDatat.Copy();
  62. DataView dv_Y = total_dt_Y.DefaultView;
  63. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  64. dv_Y_2.Sort = "Y ASC";
  65. total_dt_Y = dv_Y_2.ToTable();
  66. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  67. {
  68. NLog.LogManager.GetCurrentClassLogger().Info("Splice line"+i+1.ToString()+"of"+ total_dt_Y.Rows.Count.ToString()+".....");
  69. DataTable data = new DataTable();
  70. data.Columns.Add("mat", typeof(Bitmap));
  71. data.Columns.Add("X", typeof(double));
  72. data.Columns.Add("Y", typeof(double));
  73. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  74. {
  75. DataRow dr2 = data.NewRow();
  76. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].OriginalImage.Width, (int)m_list_allDfield[0].OriginalImage.Height);
  77. Graphics g = Graphics.FromImage(bitmap);
  78. g.Clear(Color.White);
  79. g.Dispose();
  80. dr2["mat"] = bitmap;
  81. dr2["X"] = total_dt_X.Rows[a]["X"];
  82. data.Rows.Add(dr2);
  83. }
  84. foreach (var f in m_list_allDfield)
  85. {
  86. if (total_dt_Y.Rows[i]["Y"].ToString() == f.OTSCoordinatePos.Y.ToString())
  87. {
  88. for (int c = 0; c < data.Rows.Count; c++)
  89. {
  90. if (data.Rows[c]["X"].ToString() == f.OTSCoordinatePos.X.ToString())
  91. {
  92. data.Rows[c]["mat"] = f.OriginalImage;
  93. data.Rows[c]["X"] = f.OTSCoordinatePos.X;
  94. data.Rows[c]["Y"] = f.OTSCoordinatePos.Y;
  95. }
  96. }
  97. }
  98. }
  99. DataView dataView1 = data.DefaultView;
  100. dataView1.Sort = "X ASC";
  101. data = dataView1.ToTable();
  102. list_dt_picdata.Add(data);
  103. }
  104. return list_dt_picdata;
  105. }
  106. private List<DataTable> color_piclist()
  107. {
  108. List<DataTable> list_dt_picdata = new List<DataTable>();
  109. DataTable picDatat = new DataTable();
  110. List<Field> fieldlist = resultFile.List_OTSField;
  111. picDatat.Columns.Add("X", typeof(double));
  112. picDatat.Columns.Add("Y", typeof(double));
  113. foreach (var f in m_list_allDfield)
  114. {
  115. DataRow dr = picDatat.NewRow();
  116. dr["X"] = f.OTSCoordinatePos.X;
  117. dr["Y"] = f.OTSCoordinatePos.Y;
  118. picDatat.Rows.Add(dr);
  119. }
  120. DataTable total_dt_X = picDatat.Copy();
  121. DataView dv_x = total_dt_X.DefaultView;
  122. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  123. dv_x_2.Sort = "X ASC";
  124. total_dt_X = dv_x_2.ToTable();
  125. DataTable total_dt_Y = picDatat.Copy();
  126. DataView dv_Y = total_dt_Y.DefaultView;
  127. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  128. dv_Y_2.Sort = "Y ASC";
  129. total_dt_Y = dv_Y_2.ToTable();
  130. picYmin = Convert.ToDouble(total_dt_Y.Rows[0]["Y"]);
  131. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  132. {
  133. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  134. DataTable data = new DataTable();
  135. data.Columns.Add("mat", typeof(Bitmap));
  136. data.Columns.Add("X", typeof(double));
  137. data.Columns.Add("Y", typeof(double));
  138. imgeH = (int)m_list_allDfield[0].OriginalImage.Height;
  139. imgeW = (int)m_list_allDfield[0].OriginalImage.Width;
  140. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].OriginalImage.Width, (int)m_list_allDfield[0].OriginalImage.Height);
  141. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  142. {
  143. DataRow dr2 = data.NewRow();
  144. Graphics g = Graphics.FromImage(bitmap);
  145. g.Clear(Color.White);
  146. g.Dispose();
  147. dr2["mat"] = bitmap;
  148. dr2["X"] = total_dt_X.Rows[a]["X"];
  149. data.Rows.Add(dr2);
  150. }
  151. foreach (var f in m_list_allDfield)
  152. {
  153. if (total_dt_Y.Rows[i]["Y"].ToString() == f.OTSCoordinatePos.Y.ToString())
  154. {
  155. for (int c = 0; c < data.Rows.Count; c++)
  156. {
  157. if (data.Rows[c]["X"].ToString() == f.OTSCoordinatePos.X.ToString())
  158. {
  159. Bitmap image = new Bitmap(bitmap.Width, bitmap.Height);
  160. Graphics graph_2 = Graphics.FromImage(image);
  161. Color color1 = Color.FromArgb(217, 217, 217);
  162. graph_2.Clear(color1);
  163. for (int a = 0; a < fieldlist.Count; a++)
  164. {
  165. if (fieldlist[a].FieldID.ToString() == f.FieldID.ToString())
  166. {
  167. //先获取该Field中的所有Particle
  168. List<Particle> list_particle;
  169. list_particle = fieldlist[a].ParticleList;
  170. //再循环计算所有的Particle对象
  171. foreach (Particle particle in list_particle)
  172. {
  173. List<Segment> list_seg;
  174. list_seg = particle.SegmentList;
  175. //创建颗粒分布图对应的类对象
  176. List<DisplaySegment> list_dsegment = new List<DisplaySegment>();
  177. //再循环取出里面所有的segment
  178. foreach (Segment seg in list_seg)
  179. {
  180. #region 创建DSegment对象,并将STD分析出的化合物颜色保存到DSegment对象中
  181. System.Drawing.Point on_p = new System.Drawing.Point() { X = seg.Start, Y = seg.Height };
  182. System.Drawing.Point off_p = new System.Drawing.Point() { X = seg.Start + seg.Length, Y = seg.Height };
  183. var color = DrawFunction.GetColorBySTDTypeIDForBSEAndSorImage(particle.TypeColor, particle.TypeId);
  184. Pen npen = new Pen(color);
  185. graph_2.DrawLine(npen, on_p, off_p);
  186. #endregion
  187. }
  188. }
  189. }
  190. }
  191. data.Rows[c]["mat"] = image;
  192. data.Rows[c]["X"] = f.OTSCoordinatePos.X;
  193. data.Rows[c]["Y"] = f.OTSCoordinatePos.Y;
  194. }
  195. }
  196. }
  197. }
  198. DataView dataView1 = data.DefaultView;
  199. dataView1.Sort = "X ASC";
  200. data = dataView1.ToTable();
  201. list_dt_picdata.Add(data);
  202. }
  203. return list_dt_picdata;
  204. }
  205. public void opencv_outpic()
  206. {
  207. List<DataTable> list_dt_picdata = new List<DataTable>();
  208. OpenCvSharp.Mat[] list_mats;
  209. if (type == (int)Outpic_enum.pic)
  210. {
  211. list_dt_picdata = opencv_piclist();
  212. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  213. }
  214. else if (type == (int)Outpic_enum.Render_pic)
  215. {
  216. list_dt_picdata = opencv_piclist_Render();
  217. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count + 1];
  218. }
  219. else if (type == (int)Outpic_enum.GBOne)
  220. {
  221. list_dt_picdata = color_piclist();
  222. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  223. }
  224. else if (type == (int)Outpic_enum.ColoredParticles)
  225. {
  226. list_dt_picdata = color_piclist();
  227. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  228. }
  229. else
  230. {
  231. list_dt_picdata = NoBackgroundParticleDiagram();
  232. list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  233. }
  234. NLog.LogManager.GetCurrentClassLogger().Info("Organize and splice all pictures......");
  235. List<OpenCvSharp.Mat> list_pano = new List<OpenCvSharp.Mat>();
  236. //循环保存每行拼接的图片
  237. for (int i = list_dt_picdata.Count-1; i >= 0; i--)
  238. {
  239. //拼接同一行中的图片
  240. OpenCvSharp.Mat[] mats = new OpenCvSharp.Mat[list_dt_picdata[i].Rows.Count];
  241. for (int a = 0; a < list_dt_picdata[i].Rows.Count; a++)
  242. {
  243. mats[a] = OpenCvSharp.Extensions.BitmapConverter.ToMat((Bitmap)list_dt_picdata[i].Rows[a]["mat"]);
  244. }
  245. OpenCvSharp.Mat pano = new OpenCvSharp.Mat();
  246. OpenCvSharp.Cv2.HConcat(mats, pano);
  247. list_pano.Add(pano);
  248. }
  249. //导出原图(渲染图)在下方增加每种颜色的标注和面积占比
  250. if (type == (int)Outpic_enum.Render_pic && type == (int)Outpic_enum.GBOne)
  251. {
  252. DataTable particleData = ParticleDataIntegration(ParticleData, ParticleClassData);
  253. int NumberOfRows = getPICstringLong(particleData, list_pano);
  254. Bitmap bitmap = new Bitmap(list_pano[0].Width, NumberOfRows*140);
  255. Graphics g = Graphics.FromImage(bitmap);
  256. g.Clear(Color.White);
  257. int rowData = 10;
  258. //矩形格子宽500
  259. SolidBrush mysbrush1 = new SolidBrush(ColorTranslator.FromHtml("#000000"));
  260. Pen mypen = new Pen(mysbrush1, 2);
  261. Font myFont = new Font("宋体", 13, FontStyle.Bold);
  262. SolidBrush sbrush = new SolidBrush(Color.Black);
  263. int Color_Y = 10; int TypeName_Y = 40; int Prozentsatz_Y = 100;int Area_Y = 70;
  264. int Gitter_X = 10;
  265. picKopfzeile(mypen, myFont, sbrush, g, 10, rowData);
  266. Gitter_X = Gitter_X + 350;
  267. for (int i = 0; i < particleData.Rows.Count; i++)
  268. {
  269. if (Gitter_X+350> list_pano[0].Width)
  270. {
  271. rowData = rowData + 130;
  272. picKopfzeile(mypen, myFont, sbrush, g, 10, rowData);
  273. Color_Y = Color_Y + 130;
  274. TypeName_Y = TypeName_Y + 130;
  275. Prozentsatz_Y = Prozentsatz_Y + 130;
  276. Area_Y = Area_Y + 130;
  277. Gitter_X = 360;
  278. }
  279. g.DrawRectangle(mypen, Gitter_X, Color_Y, 350, 30);
  280. g.DrawRectangle(mypen, Gitter_X, TypeName_Y, 350, 30);
  281. g.DrawRectangle(mypen, Gitter_X, Area_Y, 350, 30);
  282. g.DrawRectangle(mypen, Gitter_X, Prozentsatz_Y, 350, 30);
  283. SolidBrush mysbrush = new SolidBrush(ColorTranslator.FromHtml(particleData.Rows[i]["Color"].ToString()));
  284. g.FillRectangle(mysbrush, Gitter_X + 1, Color_Y + 1, 348, 28);
  285. g.DrawString(particleData.Rows[i]["TypeName"].ToString(), myFont, sbrush, Gitter_X + 1, TypeName_Y + 2);
  286. g.DrawString(particleData.Rows[i]["Area"].ToString(), myFont, sbrush, Gitter_X + 1, Area_Y + 2);
  287. g.DrawString(particleData.Rows[i]["Percentage"].ToString()+"%", myFont, sbrush, Gitter_X + 1, Prozentsatz_Y + 2);
  288. Gitter_X = Gitter_X + 350;
  289. }
  290. g.Dispose();
  291. OpenCvSharp.Mat pano = OpenCvSharp.Extensions.BitmapConverter.ToMat(bitmap);
  292. list_pano.Add(pano);
  293. }
  294. for (int i = 0; i < list_pano.Count; i++)
  295. {
  296. list_mats[i] = list_pano[i];
  297. }
  298. NLog.LogManager.GetCurrentClassLogger().Info("Picture splicing completed.");
  299. NLog.LogManager.GetCurrentClassLogger().Info("Save to disk......");
  300. OpenCvSharp.Mat save_pano = new OpenCvSharp.Mat();
  301. OpenCvSharp.Cv2.VConcat(list_mats, save_pano);
  302. if (type == (int)Outpic_enum.GBOne)
  303. {
  304. // 创建一个HashSet来存储唯一的值
  305. HashSet<int> distinctValuesY = new HashSet<int>();
  306. // 创建一个HashSet来存储唯一的值
  307. HashSet<int> distinctValuesX = new HashSet<int>();
  308. for (int i = 0; i < GBDatatableOne.Rows.Count; i++)
  309. {
  310. distinctValuesY.Add(Convert.ToInt32(GBDatatableOne.Rows[i]["fieldY"]));
  311. distinctValuesX.Add(Convert.ToInt32(GBDatatableOne.Rows[i]["fieldX"]));
  312. }
  313. //int picdataYmin = Convert.ToInt32(list_dt_picdata[0].Rows[0]["Y"]);
  314. //int picdataXmin = Convert.ToInt32(list_dt_picdata[0].Rows[0]["X"]);
  315. var distinctY = distinctValuesY.ToList();
  316. distinctY.Sort((a, b) => b.CompareTo(a));
  317. var distinctX = distinctValuesX.ToList();
  318. distinctX.Sort();
  319. //int Yzhou = 0;
  320. int Yzhou = (int)picYmin- distinctY.Min();
  321. Yzhou = Yzhou + (GridLength / 2)+(imgeH/2);
  322. for (int i = 0; i < distinctY.Count; i++)
  323. {
  324. int Xzhou = +(GridLength / 2) + (imgeW / 2);
  325. DataTable number = CountTheNumberOfX_axes(GBDatatableOne, "fieldY", distinctY[i].ToString());
  326. for (int j = 0; j < number.Rows.Count; j++)
  327. {
  328. // 定义矩形的左上角和右下角坐标
  329. OpenCvSharp.Point topLeft = new OpenCvSharp.Point(Xzhou, Yzhou);
  330. int XzhouDOW = Xzhou + GridLength;
  331. int YzhouDOW = Yzhou + GridLength;
  332. OpenCvSharp.Point textOrg = new OpenCvSharp.Point(Xzhou + 20, Yzhou + 70); // 文字开始的位置
  333. OpenCvSharp.Point bottomRight = new OpenCvSharp.Point(XzhouDOW, YzhouDOW);
  334. Xzhou = Xzhou + GridLength;
  335. // 定义矩形的颜色(BGR)和线宽
  336. OpenCvSharp.Scalar color = new OpenCvSharp.Scalar(0, 0, 255, 255); // 蓝色
  337. int thickness = 2;
  338. // 在图像上绘制矩形
  339. OpenCvSharp.Cv2.Rectangle(save_pano, topLeft, bottomRight, color, thickness);
  340. // 设置要绘制的文字及其位置
  341. string text = number.Rows[j]["data"].ToString();
  342. string input = number.Rows[j]["data"].ToString();
  343. double fontScale = 1; // 字体大小缩放因子
  344. int thickness2 = 1; // 字体粗细
  345. // 获取文字的大小,以便我们可以更好地定位它
  346. OpenCvSharp.Size textSize = OpenCvSharp.Cv2.GetTextSize(input, HersheyFonts.HersheySimplex, fontScale, thickness2, out int baseline);
  347. int chunkSize = GridLength / textSize.Height; // 分割长度
  348. // 使用LINQ的Enumerable.Chunk扩展方法分割字符串
  349. var chunks = Enumerable.Range(0, input.Length / chunkSize + (input.Length % chunkSize > 0 ? 1 : 0))
  350. .Select(x => input.Substring(x * chunkSize, Math.Min(chunkSize, input.Length - x * chunkSize)))
  351. .ToList();
  352. int topgrade = Convert.ToInt32(number.Rows[j]["color"]);
  353. // 设置字体样式和大小
  354. Color color1 = new Color();
  355. switch (topgrade)
  356. {
  357. case 0:
  358. color1 = Color.White;
  359. break;
  360. case 1:
  361. color1 = Color.DarkGray;
  362. break;
  363. case 2:
  364. color1 = Color.Purple;
  365. break;
  366. case 3:
  367. color1 = Color.Blue;
  368. break;
  369. case 4:
  370. color1 = Color.Red;
  371. break;
  372. case 5:
  373. color1 = Color.Red;
  374. break;
  375. default:
  376. color1 = Color.Red;
  377. break;
  378. }
  379. OpenCvSharp.Scalar fontColor = new OpenCvSharp.Scalar(color1.B, color1.G, color1.R, 255); // 文字颜色:黑色
  380. OpenCvSharp.LineTypes lineType = OpenCvSharp.LineTypes.AntiAlias; // 线条类型
  381. foreach (var chunk in chunks)
  382. {
  383. // 使用PutText方法在图像上绘制文字
  384. OpenCvSharp.Cv2.PutText(save_pano, chunk, textOrg, HersheyFonts.HersheySimplex, fontScale, fontColor, thickness, lineType);
  385. textOrg.Y = textOrg.Y + 70;
  386. }
  387. }
  388. Yzhou = Yzhou + GridLength;
  389. }
  390. }
  391. OpenCvSharp.Cv2.ImWrite(sfd.FileName, save_pano);
  392. NLog.LogManager.GetCurrentClassLogger().Info("Save complete.");
  393. Control_DrawDistrbutionImageAndBSE v = m_ReportApp.im_Control_DrawDistrbutionImageAndBSE;
  394. MyEvent += new MyEntrust(v.msgInform);
  395. v.Invoke(MyEvent);
  396. }
  397. private DataTable CountTheNumberOfX_axes(DataTable dataTable, string ColumnName, string name)
  398. {
  399. DataTable data = new DataTable();
  400. data.Columns.Add("data");
  401. data.Columns.Add("color");
  402. for (int i = 0; i < dataTable.Rows.Count; i++)
  403. {
  404. if (name == dataTable.Rows[i][ColumnName].ToString())
  405. {
  406. DataRow dr = data.NewRow();
  407. dr["data"] = dataTable.Rows[i]["gradeDetail"].ToString();
  408. dr["color"] = dataTable.Rows[i]["topGrade"].ToString();
  409. data.Rows.Add(dr);
  410. }
  411. }
  412. return data;
  413. }
  414. private int getPICstringLong(DataTable particleData, List<OpenCvSharp.Mat> list_pano)
  415. {
  416. int Long = 1;
  417. int Gitter_X = 10;
  418. for (int i = 0; i < particleData.Rows.Count; i++)
  419. {
  420. if (Gitter_X + 350 > list_pano[0].Width)
  421. {
  422. Long = Long + 1;
  423. Gitter_X = 10;
  424. }
  425. Gitter_X = Gitter_X + 350;
  426. }
  427. return Long;
  428. }
  429. private void picKopfzeile(Pen mypen, Font myFont, SolidBrush sbrush, Graphics g ,int X,int Y)
  430. {
  431. int Color_Y = Y; int TypeName_Y = Y+30; int Prozentsatz_Y = Y + 90; int Area_Y = Y+ 60;
  432. int Gitter_X = X;
  433. g.DrawRectangle(mypen, Gitter_X, Color_Y, 350, 30);
  434. g.DrawRectangle(mypen, Gitter_X, TypeName_Y, 350, 30);
  435. g.DrawRectangle(mypen, Gitter_X, Area_Y, 350, 30);
  436. g.DrawRectangle(mypen, Gitter_X, Prozentsatz_Y, 350, 30);
  437. g.DrawString("Color", myFont, sbrush, Gitter_X + 1, Color_Y + 2);
  438. g.DrawString("TypeName", myFont, sbrush, Gitter_X + 1, TypeName_Y + 2);
  439. g.DrawString("Area", myFont, sbrush, Gitter_X + 1, Area_Y + 2);
  440. g.DrawString("Prozentsatz", myFont, sbrush, Gitter_X + 1, Prozentsatz_Y + 2);
  441. }
  442. private DataTable ParticleDataIntegration(DataTable ParticleAll,DataTable ParticleClass)
  443. {
  444. DataTable dt = ParticleClass.Copy();
  445. dt.Columns.Add("Area", typeof(float));
  446. dt.Columns.Add("Percentage");
  447. dt.Columns.Add("Color");
  448. double ParticleAreaTotal = 0;
  449. for (int i=0;i< ParticleAll.Rows.Count;i++)
  450. {
  451. ParticleAreaTotal = ParticleAreaTotal + Convert.ToDouble(ParticleAll.Rows[i]["Area"]);
  452. }
  453. for (int i=0;i< dt.Rows.Count;i++)
  454. {
  455. double ParticleArea = 0;
  456. string ParticleColer = "";
  457. for (int a=0;a< ParticleAll.Rows.Count;a++)
  458. {
  459. if (dt.Rows[i]["TypeName"].ToString()== ParticleAll.Rows[a]["TypeName"].ToString())
  460. {
  461. ParticleArea = ParticleArea + Convert.ToDouble(ParticleAll.Rows[a]["Area"]);
  462. ParticleColer = ParticleAll.Rows[a]["TypeColor"].ToString();
  463. }
  464. }
  465. dt.Rows[i]["Area"] = ParticleArea;
  466. dt.Rows[i]["Percentage"] = ParameterNormalization(ParticleAreaTotal, ParticleArea);
  467. dt.Rows[i]["Color"] = ParticleColer;
  468. }
  469. return dt;
  470. }
  471. /// <summary>
  472. /// 参数归一化
  473. /// </summary>
  474. /// <param name="a_mi">总数</param>
  475. /// <param name="m">传参</param>
  476. /// <returns></returns>
  477. private string ParameterNormalization(double a_mi, double m)
  478. {
  479. double ColVal = Convert.ToDouble(m / a_mi * 100);
  480. if (ColVal == 0)
  481. {
  482. return "";
  483. }
  484. else
  485. {
  486. return Math.Round(ColVal, 2).ToString();
  487. }
  488. }
  489. private List<DataTable> NoBackgroundParticleDiagram()
  490. {
  491. List<DataTable> list_dt_picdata = new List<DataTable>();
  492. DataTable picDatat = new DataTable();
  493. List<Field> fieldlist = resultFile.List_OTSField;
  494. picDatat.Columns.Add("X", typeof(double));
  495. picDatat.Columns.Add("Y", typeof(double));
  496. foreach (var f in m_list_allDfield)
  497. {
  498. DataRow dr = picDatat.NewRow();
  499. dr["X"] = f.OTSCoordinatePos.X;
  500. dr["Y"] = f.OTSCoordinatePos.Y;
  501. picDatat.Rows.Add(dr);
  502. }
  503. DataTable total_dt_X = picDatat.Copy();
  504. DataView dv_x = total_dt_X.DefaultView;
  505. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  506. dv_x_2.Sort = "X ASC";
  507. total_dt_X = dv_x_2.ToTable();
  508. DataTable total_dt_Y = picDatat.Copy();
  509. DataView dv_Y = total_dt_Y.DefaultView;
  510. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  511. dv_Y_2.Sort = "Y ASC";
  512. total_dt_Y = dv_Y_2.ToTable();
  513. //循环每一行图片
  514. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  515. {
  516. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  517. DataTable data = new DataTable();
  518. data.Columns.Add("mat", typeof(Bitmap));
  519. data.Columns.Add("X", typeof(double));
  520. //循环每行图片进行拼接
  521. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].OriginalImage.Width, (int)m_list_allDfield[0].OriginalImage.Height);
  522. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  523. {
  524. DataRow dr2 = data.NewRow();
  525. Graphics g = Graphics.FromImage(bitmap);
  526. g.Clear(Color.White);
  527. g.Dispose();
  528. dr2["mat"] = bitmap;
  529. dr2["X"] = total_dt_X.Rows[a]["X"];
  530. data.Rows.Add(dr2);
  531. }
  532. //循环所有图片
  533. foreach (var f in m_list_allDfield)
  534. {
  535. if (total_dt_Y.Rows[i]["Y"].ToString() == f.OTSCoordinatePos.Y.ToString())
  536. {
  537. //循环图片的行数
  538. for (int c = 0; c < data.Rows.Count; c++)
  539. {
  540. if (data.Rows[c]["X"].ToString() == f.OTSCoordinatePos.X.ToString())
  541. {
  542. Bitmap image = new Bitmap(bitmap.Width, bitmap.Height);
  543. Graphics g2 = Graphics.FromImage(image);
  544. //g2.Clear(Color.White);
  545. Color color1 = Color.FromArgb(217, 217, 217);
  546. g2.Clear(color1);
  547. g2.DrawImage(image, 0, 0, f.OriginalImage.Width, f.OriginalImage.Height);
  548. Graphics graph_2 = Graphics.FromImage(image);
  549. for (int a = 0; a < fieldlist.Count; a++)
  550. {
  551. if (fieldlist[a].FieldID.ToString() == f.FieldID.ToString())
  552. {
  553. //先获取该Field中的所有Particle
  554. List<Particle> list_particle;
  555. list_particle = fieldlist[a].ParticleList;
  556. //再循环计算所有的Particle对象
  557. foreach (Particle particle in list_particle)
  558. {
  559. List<Segment> list_seg;
  560. list_seg = particle.SegmentList;
  561. //创建颗粒分布图对应的类对象
  562. List<DisplaySegment> list_dsegment = new List<DisplaySegment>();
  563. //再循环取出里面所有的segment
  564. foreach (Segment seg in list_seg)
  565. {
  566. #region 创建DSegment对象,并将STD分析出的化合物颜色保存到DSegment对象中
  567. System.Drawing.Point on_p = new System.Drawing.Point() { X = seg.Start, Y = seg.Height };
  568. System.Drawing.Point off_p = new System.Drawing.Point() { X = seg.Start + seg.Length, Y = seg.Height };
  569. Pen npen = new Pen(Color.FromArgb(255-particle.AveGray, 0, 0, 0));
  570. graph_2.DrawLine(npen, on_p, off_p);
  571. #endregion
  572. }
  573. }
  574. }
  575. }
  576. data.Rows[c]["mat"] = image;
  577. data.Rows[c]["X"] = f.OTSCoordinatePos.X;
  578. }
  579. }
  580. }
  581. }
  582. DataView dataView1 = data.DefaultView;
  583. dataView1.Sort = "X ASC";
  584. data = dataView1.ToTable();
  585. list_dt_picdata.Add(data);
  586. }
  587. return list_dt_picdata;
  588. }
  589. private List<DataTable> opencv_piclist_Render()
  590. {
  591. List<DataTable> list_dt_picdata = new List<DataTable>();
  592. DataTable picDatat = new DataTable();
  593. List<Field> fieldlist = resultFile.List_OTSField;
  594. picDatat.Columns.Add("X", typeof(double));
  595. picDatat.Columns.Add("Y", typeof(double));
  596. foreach (var f in m_list_allDfield)
  597. {
  598. DataRow dr = picDatat.NewRow();
  599. dr["X"] = f.OTSCoordinatePos.X;
  600. dr["Y"] = f.OTSCoordinatePos.Y;
  601. picDatat.Rows.Add(dr);
  602. }
  603. DataTable total_dt_X = picDatat.Copy();
  604. DataView dv_x = total_dt_X.DefaultView;
  605. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  606. dv_x_2.Sort = "X ASC";
  607. total_dt_X = dv_x_2.ToTable();
  608. DataTable total_dt_Y = picDatat.Copy();
  609. DataView dv_Y = total_dt_Y.DefaultView;
  610. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  611. dv_Y_2.Sort = "Y ASC";
  612. total_dt_Y = dv_Y_2.ToTable();
  613. //循环每一行图片
  614. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  615. {
  616. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  617. DataTable data = new DataTable();
  618. data.Columns.Add("mat", typeof(Bitmap));
  619. data.Columns.Add("X", typeof(double));
  620. //循环每行图片进行拼接
  621. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  622. {
  623. DataRow dr2 = data.NewRow();
  624. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].OriginalImage.Width, (int)m_list_allDfield[0].OriginalImage.Height);
  625. //Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].GetShowRect().Width, (int)m_list_allDfield[0].GetShowRect().Height);
  626. Graphics g = Graphics.FromImage(bitmap);
  627. g.Clear(Color.White);
  628. g.Dispose();
  629. dr2["mat"] = bitmap;
  630. dr2["X"] = total_dt_X.Rows[a]["X"];
  631. data.Rows.Add(dr2);
  632. }
  633. //循环所有图片
  634. foreach (var f in m_list_allDfield)
  635. {
  636. if (total_dt_Y.Rows[i]["Y"].ToString() == f.OTSCoordinatePos.Y.ToString())
  637. {
  638. //循环图片的行数
  639. for (int c = 0; c < data.Rows.Count; c++)
  640. {
  641. if (data.Rows[c]["X"].ToString() == f.OTSCoordinatePos.X.ToString())
  642. {
  643. Bitmap image = new Bitmap(f.OriginalImage.Width, f.OriginalImage.Height);
  644. Graphics g2 = Graphics.FromImage(image);
  645. g2.DrawImage(f.OriginalImage, 0, 0, f.OriginalImage.Width, f.OriginalImage.Height);
  646. Graphics graph_2 = Graphics.FromImage(image);
  647. for (int a = 0; a < fieldlist.Count; a++)
  648. {
  649. if (fieldlist[a].FieldID.ToString() == f.FieldID.ToString())
  650. {
  651. //先获取该Field中的所有Particle
  652. List<Particle> list_particle;
  653. list_particle = fieldlist[a].ParticleList;
  654. //再循环计算所有的Particle对象
  655. foreach (Particle particle in list_particle)
  656. {
  657. List<Segment> list_seg;
  658. list_seg = particle.SegmentList;
  659. //创建颗粒分布图对应的类对象
  660. List<DisplaySegment> list_dsegment = new List<DisplaySegment>();
  661. //再循环取出里面所有的segment
  662. foreach (Segment seg in list_seg)
  663. {
  664. #region 创建DSegment对象,并将STD分析出的化合物颜色保存到DSegment对象中
  665. System.Drawing.Point on_p = new System.Drawing.Point() { X = seg.Start, Y = seg.Height };
  666. System.Drawing.Point off_p = new System.Drawing.Point() { X = seg.Start + seg.Length, Y = seg.Height };
  667. var color = DrawFunction.GetColorBySTDTypeIDForBSEAndSorImage(particle.TypeColor, particle.TypeId);
  668. Pen npen = new Pen(color);
  669. graph_2.DrawLine(npen, on_p, off_p);
  670. #endregion
  671. }
  672. }
  673. }
  674. }
  675. data.Rows[c]["mat"] = image;
  676. data.Rows[c]["X"] = f.OTSCoordinatePos.X;
  677. }
  678. }
  679. }
  680. }
  681. DataView dataView1 = data.DefaultView;
  682. dataView1.Sort = "X ASC";
  683. data = dataView1.ToTable();
  684. list_dt_picdata.Add(data);
  685. }
  686. return list_dt_picdata;
  687. }
  688. #region 合并天宇颗粒融合新增函数
  689. public void opencv_outpic2(/*int type*/)
  690. {
  691. List<DataTable> list_dt_picdata = new List<DataTable>();
  692. if (type == (int)Outpic_enum.pic || type == (int)Outpic_enum.Combin)
  693. {
  694. list_dt_picdata = opencv_piclist2();
  695. }
  696. else if (type == (int)Outpic_enum.Render_pic || type == (int)Outpic_enum.Render_Combin)
  697. {
  698. list_dt_picdata = opencv_piclist_Render2();
  699. }
  700. OpenCvSharp.Mat save_pano = new OpenCvSharp.Mat();
  701. OpenCvSharp.Mat[] list_mats = new OpenCvSharp.Mat[list_dt_picdata.Count];
  702. if (type == (int)Outpic_enum.Combin || type == (int)Outpic_enum.Render_Combin)
  703. {
  704. CImageHandler cImageHandler = new CImageHandler();
  705. Dictionary<string, object> sampleMembers = ((Dictionary<string, object>)((Dictionary<string, object>)resultFile.ResultInfo["Sample"])["Members"]);
  706. Dictionary<string, object> imageProcessParam = (Dictionary<string, object>)((Dictionary<string, object>)((Dictionary<string, object>)sampleMembers["MsrParams"])["Members"])["ImageProcessParam"];
  707. object strOverlapParam = "";
  708. imageProcessParam.TryGetValue("OverlapParam", out strOverlapParam);
  709. if (strOverlapParam == null)
  710. {
  711. NLog.LogManager.GetCurrentClassLogger().Info("There are no overlapping dimensions");
  712. return;
  713. }
  714. int OverlapParam = int.Parse(strOverlapParam.ToString());
  715. List<OpenCvSharp.Mat> maxXList = new List<OpenCvSharp.Mat>();
  716. for (int i = 0; i < list_dt_picdata.Count; i++)
  717. {
  718. OpenCvSharp.Mat[] mats = new OpenCvSharp.Mat[list_dt_picdata[i].Rows.Count];
  719. for (int a = 0; a < list_dt_picdata[i].Rows.Count; a++)
  720. {
  721. mats[a] = OpenCvSharp.Extensions.BitmapConverter.ToMat((Bitmap)list_dt_picdata[i].Rows[a]["mat"]);
  722. }
  723. //横向拼接
  724. maxXList.Add(cImageHandler.CombinImageX(mats, OverlapParam, type));
  725. }
  726. save_pano = cImageHandler.CombinImageY(maxXList.ToArray(), OverlapParam, type);
  727. OpenCvSharp.Cv2.ImWrite(sfd.FileName, save_pano);
  728. NLog.LogManager.GetCurrentClassLogger().Info("Save complete.");
  729. }
  730. else
  731. {
  732. NLog.LogManager.GetCurrentClassLogger().Info("Organize and splice all pictures......");
  733. for (int i = 0; i < list_dt_picdata.Count; i++)
  734. {
  735. OpenCvSharp.Mat[] mats = new OpenCvSharp.Mat[list_dt_picdata[i].Rows.Count];
  736. for (int a = 0; a < list_dt_picdata[i].Rows.Count; a++)
  737. {
  738. mats[a] = OpenCvSharp.Extensions.BitmapConverter.ToMat((Bitmap)list_dt_picdata[i].Rows[a]["mat"]);
  739. }
  740. OpenCvSharp.Mat pano = new OpenCvSharp.Mat();
  741. OpenCvSharp.Cv2.HConcat(mats, pano);
  742. list_mats[i] = pano;
  743. }
  744. NLog.LogManager.GetCurrentClassLogger().Info("Picture splicing completed.");
  745. NLog.LogManager.GetCurrentClassLogger().Info("Save to disk......");
  746. OpenCvSharp.Cv2.VConcat(list_mats, save_pano);
  747. OpenCvSharp.Cv2.ImWrite(sfd.FileName, save_pano);
  748. NLog.LogManager.GetCurrentClassLogger().Info("Save complete.");
  749. }
  750. }
  751. private List<DataTable> opencv_piclist_Render2()
  752. {
  753. List<DataTable> list_dt_picdata = new List<DataTable>();
  754. DataTable picDatat = new DataTable();
  755. List<Field> fieldlist = resultFile.List_OTSField;
  756. picDatat.Columns.Add("X", typeof(double));
  757. picDatat.Columns.Add("Y", typeof(double));
  758. foreach (var f in m_list_allDfield)
  759. {
  760. DataRow dr = picDatat.NewRow();
  761. dr["X"] = f.GetShowRect().X;
  762. dr["Y"] = f.GetShowRect().Y;
  763. picDatat.Rows.Add(dr);
  764. }
  765. int y_max = Convert.ToInt32(picDatat.Compute("Max(Y)", "true"));
  766. int y_min = Convert.ToInt32(picDatat.Compute("Min(Y)", "true"));
  767. DataTable total_dt_X = picDatat.Copy();
  768. DataView dv_x = total_dt_X.DefaultView;
  769. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  770. dv_x_2.Sort = "X ASC";
  771. total_dt_X = dv_x_2.ToTable();
  772. DataTable total_dt_Y = picDatat.Copy();
  773. DataView dv_Y = total_dt_Y.DefaultView;
  774. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  775. dv_Y_2.Sort = "Y ASC";
  776. total_dt_Y = dv_Y_2.ToTable();
  777. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  778. {
  779. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  780. DataTable data = new DataTable();
  781. data.Columns.Add("mat", typeof(Bitmap));
  782. data.Columns.Add("X", typeof(double));
  783. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  784. {
  785. DataRow dr2 = data.NewRow();
  786. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].GetShowRect().Width, (int)m_list_allDfield[0].GetShowRect().Height);
  787. Graphics g = Graphics.FromImage(bitmap);
  788. g.Clear(Color.White);
  789. g.Dispose();
  790. dr2["mat"] = bitmap;
  791. dr2["X"] = total_dt_X.Rows[a]["X"];
  792. data.Rows.Add(dr2);
  793. }
  794. foreach (var f in m_list_allDfield)
  795. {
  796. if (total_dt_Y.Rows[i]["Y"].ToString() == f.GetShowRect().Y.ToString())
  797. {
  798. for (int c = 0; c < data.Rows.Count; c++)
  799. {
  800. if (data.Rows[c]["X"].ToString() == f.GetShowRect().X.ToString())
  801. {
  802. Bitmap image = new Bitmap(f.OriginalImage.Width, f.OriginalImage.Height);
  803. Graphics g2 = Graphics.FromImage(image);
  804. g2.DrawImage(f.OriginalImage, 0, 0, f.OriginalImage.Width, f.OriginalImage.Height);
  805. Graphics graph_2 = Graphics.FromImage(image);
  806. for (int a = 0; a < fieldlist.Count; a++)
  807. {
  808. if (fieldlist[a].FieldID.ToString() == f.FieldID.ToString())
  809. {
  810. //先获取该Field中的所有Particle
  811. List<Particle> list_particle;
  812. list_particle = fieldlist[a].ParticleList;
  813. //再循环计算所有的Particle对象
  814. foreach (Particle particle in list_particle)
  815. {
  816. //创建DParticle颗粒
  817. DisplayParticle dp = new DisplayParticle(particle);
  818. List<Segment> list_seg;
  819. list_seg = particle.SegmentList;
  820. //创建颗粒分布图对应的类对象
  821. List<DisplaySegment> list_dsegment = new List<DisplaySegment>();
  822. //再循环取出里面所有的segment
  823. foreach (Segment seg in list_seg)
  824. {
  825. #region 创建DSegment对象,并将STD分析出的化合物颜色保存到DSegment对象中
  826. System.Drawing.Point on_p = new System.Drawing.Point() { X = seg.Start, Y = seg.Height };
  827. System.Drawing.Point off_p = new System.Drawing.Point() { X = seg.Start + seg.Length, Y = seg.Height };
  828. Pen npen = new Pen(dp.Color);
  829. graph_2.DrawLine(npen, on_p, off_p);
  830. #endregion
  831. }
  832. }
  833. }
  834. }
  835. data.Rows[c]["mat"] = image;
  836. data.Rows[c]["X"] = f.GetShowRect().X;
  837. }
  838. }
  839. }
  840. }
  841. DataView dataView1 = data.DefaultView;
  842. dataView1.Sort = "X ASC";
  843. data = dataView1.ToTable();
  844. list_dt_picdata.Add(data);
  845. }
  846. return list_dt_picdata;
  847. }
  848. /// <summary>
  849. /// 获取每行图片的位置配合opencv方法使用
  850. /// </summary>
  851. /// <returns></returns>
  852. private List<DataTable> opencv_piclist2()
  853. {
  854. List<DataTable> list_dt_picdata = new List<DataTable>();
  855. DataTable picDatat = new DataTable();
  856. picDatat.Columns.Add("X", typeof(double));
  857. picDatat.Columns.Add("Y", typeof(double));
  858. foreach (var f in m_list_allDfield)
  859. {
  860. DataRow dr = picDatat.NewRow();
  861. dr["X"] = f.GetShowRect().X;
  862. dr["Y"] = f.GetShowRect().Y;
  863. picDatat.Rows.Add(dr);
  864. }
  865. int y_max = Convert.ToInt32(picDatat.Compute("Max(Y)", "true"));
  866. int y_min = Convert.ToInt32(picDatat.Compute("Min(Y)", "true"));
  867. DataTable total_dt_X = picDatat.Copy();
  868. DataView dv_x = total_dt_X.DefaultView;
  869. DataView dv_x_2 = dv_x.ToTable(true, "X").DefaultView;
  870. dv_x_2.Sort = "X ASC";
  871. total_dt_X = dv_x_2.ToTable();
  872. DataTable total_dt_Y = picDatat.Copy();
  873. DataView dv_Y = total_dt_Y.DefaultView;
  874. DataView dv_Y_2 = dv_Y.ToTable(true, "Y").DefaultView;
  875. dv_Y_2.Sort = "Y ASC";
  876. total_dt_Y = dv_Y_2.ToTable();
  877. for (int i = 0; i < total_dt_Y.Rows.Count; i++)
  878. {
  879. NLog.LogManager.GetCurrentClassLogger().Info("Splice line" + i + 1.ToString() + "of" + total_dt_Y.Rows.Count.ToString() + ".....");
  880. DataTable data = new DataTable();
  881. data.Columns.Add("mat", typeof(Bitmap));
  882. data.Columns.Add("X", typeof(double));
  883. for (int a = 0; a < total_dt_X.Rows.Count; a++)
  884. {
  885. DataRow dr2 = data.NewRow();
  886. Bitmap bitmap = new Bitmap((int)m_list_allDfield[0].GetShowRect().Width, (int)m_list_allDfield[0].GetShowRect().Height);
  887. Graphics g = Graphics.FromImage(bitmap);
  888. g.Clear(Color.White);
  889. g.Dispose();
  890. dr2["mat"] = bitmap;
  891. dr2["X"] = total_dt_X.Rows[a]["X"];
  892. data.Rows.Add(dr2);
  893. }
  894. foreach (var f in m_list_allDfield)
  895. {
  896. if (total_dt_Y.Rows[i]["Y"].ToString() == f.GetShowRect().Y.ToString())
  897. {
  898. for (int c = 0; c < data.Rows.Count; c++)
  899. {
  900. if (data.Rows[c]["X"].ToString() == f.GetShowRect().X.ToString())
  901. {
  902. data.Rows[c]["mat"] = f.OriginalImage;
  903. data.Rows[c]["X"] = f.GetShowRect().X;
  904. }
  905. }
  906. }
  907. }
  908. DataView dataView1 = data.DefaultView;
  909. dataView1.Sort = "X ASC";
  910. data = dataView1.ToTable();
  911. list_dt_picdata.Add(data);
  912. }
  913. return list_dt_picdata;
  914. }
  915. #endregion
  916. public delegate void MyEntrust();
  917. public event MyEntrust MyEvent;
  918. }
  919. }