OutPIC.cs 48 KB

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