OutPIC.cs 48 KB

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