版博士V2.0程序
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
 
 
 
 

492 Zeilen
20 KiB

  1. using CCWin.Win32;
  2. using CCWin.Win32.Const;
  3. using ImageToolKits;
  4. using MaiMuAOI.SysCtrl;
  5. using MaiMuAOI.SysUI;
  6. using Models;
  7. using Newtonsoft.Json;
  8. using OpenCvSharp;
  9. using OpenCvSharp.Flann;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.ComponentModel;
  13. using System.Data;
  14. using System.Drawing;
  15. using System.IO;
  16. using System.Linq;
  17. using System.Reflection;
  18. using System.Text;
  19. using System.Threading.Tasks;
  20. using System.Windows.Forms;
  21. using static ImageToolKits.ImageBox;
  22. using static System.Windows.Forms.VisualStyles.VisualStyleElement.Header;
  23. namespace ProductionControl.UI
  24. {
  25. public partial class FrmGetPosByPic : Form
  26. {
  27. List<ImageBox.BaseDrawParam> pickARoi = new List<ImageBox.BaseDrawParam>();
  28. Mat Img;
  29. string _Path;
  30. double[] _Points;
  31. Service.ProductService service = new Service.ProductService();
  32. Models.Product model = new Models.Product();
  33. List<TestDefectPoints> DefectPoints = new List<TestDefectPoints>();
  34. //测试项名称
  35. List<string> ItemName = new List<string>();
  36. public FrmGetPosByPic(Models.Product m, string map, double[] pointlist)
  37. {
  38. _Path = map;
  39. _Points = pointlist;
  40. pickARoi.Clear();
  41. InitializeComponent();
  42. UIStyle.SetUIStyle(this);
  43. this.uiTitel1.FatherForm = this;
  44. //lbPoslist.Items.Clear();
  45. //this.imageBox1.SetLowLevelMode(14);
  46. this.imageBox1.SetPointsLevelMode();
  47. imageBox1.DrawOverAllEventHandler += imgBox_DrawOverAllEventHandler;
  48. //显示行号与列宽度自动调整
  49. dgvPointTable.DefaultCellStyle.ForeColor = Color.Black;
  50. dgvPointTable.RowHeadersVisible = true;
  51. dgvPointTable.RowHeadersWidthSizeMode = DataGridViewRowHeadersWidthSizeMode.AutoSizeToAllHeaders;
  52. dgvPointTable.RowPostPaint += (sender, e) =>
  53. {
  54. SysMgr.showRowNum_onDataGrid_RowPostPaint(this.dgvPointTable, sender, e);
  55. };
  56. model = m;
  57. if((model != null )&&(model.TestDefectPointsList != null))
  58. {
  59. DefectPoints = model.TestDefectPointsList;
  60. }
  61. else if((model != null) && (model.TestDefectPointsList == null))
  62. {
  63. model.TestDefectPointsList = new List<TestDefectPoints>();
  64. }
  65. cbPointName.SelectedIndex = 0;
  66. //加载
  67. cbPointName.Items.Clear();
  68. //反射 循环 获取数据
  69. //Type t = typeof(PointTestType);
  70. //FieldInfo[] fieldInfos = t.GetFields();
  71. //foreach (var item in fieldInfos)
  72. //{
  73. // //不是枚举字段不处理
  74. // if (item.FieldType.IsEnum)
  75. // {
  76. // //名称可以直接获取
  77. // ItemName.Add(item.Name);
  78. // cbPointName.Items.Add(item.Name);
  79. // }
  80. //}
  81. foreach (var item in ConfMgr.Instance.SizeItemParamsList)
  82. {
  83. ItemName.Add(item.Name);
  84. cbPointName.Items.Add(item.Name);
  85. }
  86. //cbPointName.Items.AddRange(fieldInfos);
  87. }
  88. public string GetMapPath()
  89. { return _Path; }
  90. public double[] GetPoints()
  91. {
  92. return _Points;
  93. }
  94. void imgBox_DrawOverAllEventHandler(object sender, List<ImageBox.BaseDrawParam> e)
  95. {
  96. if (e.Count > 0)
  97. {
  98. imageBox1.RefreshWindow(imageBox1.Image, e, ImageBox.ImageModeEnum.Part);
  99. }
  100. }
  101. private void FrmGetPosByPic_Load(object sender, EventArgs e)
  102. {
  103. imageBox1.Select();
  104. if (File.Exists(_Path))
  105. {
  106. Img = new Mat(_Path);
  107. imageBox1.RefreshWindow(Img);
  108. InitViewPoints();
  109. ShowPointCount();
  110. }
  111. else
  112. {
  113. string maop_path = ConfMgr.SelectFile();
  114. if (File.Exists(maop_path))
  115. {
  116. _Path = maop_path;
  117. Img = new Mat(maop_path);
  118. this.imageBox1.RefreshWindow(Img);
  119. }
  120. else
  121. {
  122. MessageBox.Show("无图纸图片加载!", "警告", MessageBoxButtons.OK, MessageBoxIcon.Error);
  123. return;
  124. }
  125. }
  126. //imageBox1.Refresh();
  127. //imageBox1.DisplayROIs(roi);
  128. //this.Refresh();
  129. }
  130. void InitViewPoints()
  131. {
  132. List<ImageBox.ColorDrawParam> lROI = new List<ImageBox.ColorDrawParam>();
  133. //按点位类型
  134. var tempStuList = model.TestDefectPointsList.GroupBy(q => q.PointCode);
  135. foreach ( var tempPoint in tempStuList )
  136. {
  137. //一个点位类型所有点位数据
  138. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == tempPoint.Key).ToList();
  139. for (int i = 0; i < t.Count; i++)
  140. {
  141. ColorDrawParam param = new ColorDrawParam();
  142. param.baseDraw = new ImageBox.Point((float)t[i].Y, (float)t[i].X);
  143. int index = 0;
  144. for (int j = 0; j < this.cbPointName.Items.Count; j++)
  145. {
  146. if (this.cbPointName.Items[j].ToString() == tempPoint.Key)
  147. {
  148. index = j;
  149. break;
  150. }
  151. }
  152. param.color = Color.FromArgb(ConfMgr.Instance.SizeItemParamsList[index].RGBcolor[0],
  153. ConfMgr.Instance.SizeItemParamsList[index].RGBcolor[1],
  154. ConfMgr.Instance.SizeItemParamsList[index].RGBcolor[2]);
  155. lROI.Add(param);
  156. }
  157. }
  158. imageBox1.RefreshWindow(imageBox1.Image, lROI);
  159. }
  160. void ShowPointCount()
  161. {
  162. //按点位类型
  163. var tempStuList = model.TestDefectPointsList.GroupBy(q => q.PointCode);
  164. int[] count = new int[ItemName.Count];
  165. foreach (var tempPoint in tempStuList)
  166. {
  167. //一个点位类型所有点位数据
  168. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == tempPoint.Key).ToList();
  169. for (int j = 0; j < this.cbPointName.Items.Count; j++)
  170. {
  171. if (this.cbPointName.Items[j].ToString() == tempPoint.Key)
  172. {
  173. count[j] = t.Count;
  174. break;
  175. }
  176. }
  177. }
  178. //stLabel.Text = $"Y轴方向PT值检测({count[0]}),线宽正面({count[1]}),反面检测({count[2]}),X轴方向PT值检测({count[3]})," +
  179. // $"主栅连接线检测(主栅间隔)({count[4]}),主栅宽度检测({count[5]}),主栅间距({count[6]}),细栅间距检测({count[7]}),\r\n背极宽度({count[8]}),"+
  180. // $"主栅长度检测({count[9]}),Mark点横向间距({count[10]}),Mark点竖向间距({count[11]}),鱼叉口长({count[12]}),鱼叉口宽({count[13]}),鱼叉口间距({count[14]})" +
  181. // $",蜈蚣角长({count[15]}),蜈蚣角宽({count[16]})";
  182. string showPointNum = "";
  183. for (int i = 0; i < ItemName.Count; i++)
  184. {
  185. showPointNum += $"{ItemName[i]}({count[i]}),";
  186. if ((i+1) % 8 == 0)
  187. showPointNum += "\r\n";
  188. }
  189. stLabel.Text = showPointNum.Remove(showPointNum.Length - 1);
  190. }
  191. #region 工具栏
  192. private void tsbtnClear_Click(object sender, EventArgs e)
  193. {
  194. if (MessageBox.Show("是否清空所有点位?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Information) == DialogResult.OK)
  195. {
  196. pickARoi.Clear();
  197. DefectPoints.Clear();
  198. this.imageBox1.ClearColorPoints();
  199. this.imageBox1.RefreshWindow(Img);
  200. ShowPointCount();
  201. ShowPoints();
  202. ReflashTable();
  203. this.Refresh();
  204. }
  205. }
  206. private void tsbtnShowAll_Click(object sender, EventArgs e)
  207. {
  208. InitViewPoints();
  209. ShowPointCount();
  210. }
  211. private void tsbtnClose_Click(object sender, EventArgs e)
  212. {
  213. this.Close();
  214. }
  215. private void tsbtnSave_Click(object sender, EventArgs e)
  216. {
  217. //pickARoi = this.imageBox1.GetLowPoints();
  218. //if (pickARoi.Count == 14)
  219. //{
  220. // _Points = new double[14 * 2];
  221. // for (int i = 0; i < 14; i++)
  222. // {
  223. // _Points[2 * i] = Math.Round((pickARoi[i] as ImageBox.Point).Column, 3);
  224. // _Points[2 * i + 1] = Math.Round((pickARoi[i] as ImageBox.Point).Row, 3);
  225. // }
  226. // this.DialogResult = DialogResult.OK;
  227. //}
  228. //else if (pickARoi.Count >0)
  229. // MessageBox.Show("点位设置错误,点数不对!", "警告", MessageBoxButtons.OK, MessageBoxIcon.Error);
  230. //else
  231. //{
  232. // _Points = new double[14 * 2];
  233. // for (int i = 0; i < 14; i++)
  234. // {
  235. // _Points[2 * i] = 0;
  236. // _Points[2 * i + 1] = 0;
  237. // }
  238. //}
  239. try
  240. {
  241. //老点位使用
  242. bool result;
  243. if (model.Id == 0)
  244. {
  245. model.TestDefectPointsList = DefectPoints;
  246. result = service.InsertNav(model);
  247. }
  248. else
  249. {
  250. model.TestDefectPointsList = DefectPoints;
  251. result = service.UpdateNav(model);
  252. }
  253. if (!result)
  254. throw new Exception("保存失败!");
  255. MessageBox.Show("保存成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  256. this.DialogResult = DialogResult.OK;
  257. SysMgr.Instance.WriteSysEditLog("图纸抓取点位修改", JsonConvert.SerializeObject(DefectPoints));
  258. }
  259. catch (Exception ex)
  260. {
  261. MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
  262. }
  263. }
  264. #endregion
  265. #region 工具按钮
  266. private void btnAdd_Click(object sender, EventArgs e)
  267. {
  268. try
  269. {
  270. //List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == this.cbPointName.Text).ToList();
  271. //DefectPoints.Add(point);
  272. DefectPoints.Add(
  273. new Models.TestDefectPoints()
  274. {
  275. PointCode = this.cbPointName.Text,
  276. X = Math.Round((imageBox1.GetPoints()[0] as ImageBox.Point).Column, 3),
  277. Y = Math.Round((imageBox1.GetPoints()[0] as ImageBox.Point).Row,3),
  278. ModifyUserCode = SysMgr.Instance.UserMgr.LoginUser.Code,
  279. CreateUserCode = SysMgr.Instance.UserMgr.LoginUser.Code
  280. });
  281. ShowPoints();
  282. ReflashTable();
  283. ShowPointCount();
  284. }
  285. catch (Exception ex)
  286. {
  287. MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
  288. }
  289. }
  290. private void ShowPoints()
  291. {
  292. List<ImageBox.ColorDrawParam> lROI = new List<ImageBox.ColorDrawParam>();
  293. //按点位类型
  294. //一个点位类型所有点位数据
  295. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == this.cbPointName.Text).ToList();
  296. for (int i = 0; i < t.Count; i++)
  297. {
  298. ColorDrawParam param = new ColorDrawParam();
  299. param.baseDraw = new ImageBox.Point((float)t[i].Y, (float)t[i].X);
  300. param.color = Color.FromArgb(ConfMgr.Instance.SizeItemParamsList[cbPointName.SelectedIndex].RGBcolor[0],
  301. ConfMgr.Instance.SizeItemParamsList[cbPointName.SelectedIndex].RGBcolor[1],
  302. ConfMgr.Instance.SizeItemParamsList[cbPointName.SelectedIndex].RGBcolor[2]);
  303. lROI.Add(param);
  304. }
  305. if(imageBox1.Image == null)
  306. imageBox1.RefreshWindow(imageBox1.Image, lROI);
  307. else
  308. imageBox1.RefreshWindow(imageBox1.Image, lROI, ImageModeEnum.Part);
  309. }
  310. private void cbPointName_SelectedIndexChanged(object sender, EventArgs e)
  311. {
  312. ShowPoints();
  313. ReflashTable();
  314. }
  315. private void ReflashTable()
  316. {
  317. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == this.cbPointName.Text).ToList();
  318. dgvPointTable.Rows.Clear();
  319. for (int i = 0; i < t.Count; i++)
  320. {
  321. ColorDrawParam param = new ColorDrawParam();
  322. param.baseDraw = new ImageBox.Point((float)t[i].Y, (float)t[i].X);
  323. param.color = Color.FromArgb(ConfMgr.Instance.SizeItemParamsList[cbPointName.SelectedIndex].RGBcolor[0],
  324. ConfMgr.Instance.SizeItemParamsList[cbPointName.SelectedIndex].RGBcolor[1],
  325. ConfMgr.Instance.SizeItemParamsList[cbPointName.SelectedIndex].RGBcolor[2]);
  326. int index = dgvPointTable.Rows.Add();
  327. dgvPointTable.Rows[index].Cells[0].Value = t[i].PointCode;
  328. dgvPointTable.Rows[index].Cells[1].Value = t[i].X;
  329. dgvPointTable.Rows[index].Cells[2].Value = t[i].Y;
  330. }
  331. }
  332. private void btnInsert_Click(object sender, EventArgs e)
  333. {
  334. try {
  335. if (this.dgvPointTable.SelectedRows.Count != 1)
  336. throw new Exception("请选择要插入的位置!");
  337. int liInsertIndex = this.dgvPointTable.Rows.Count;
  338. if (this.dgvPointTable.SelectedRows.Count > 0)
  339. liInsertIndex = this.dgvPointTable.SelectedRows[0].Index;
  340. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == this.cbPointName.Text).ToList();
  341. int findIndex = DefectPoints.FindIndex(temp => (temp.X == t[liInsertIndex].X && temp.Y == t[liInsertIndex].Y) );
  342. //DefectPoints.Add(point);
  343. DefectPoints.Insert(findIndex,
  344. new Models.TestDefectPoints()
  345. {
  346. PointCode = this.cbPointName.Text,
  347. X = Math.Round((imageBox1.GetPoints()[0] as ImageBox.Point).Column, 3),
  348. Y = Math.Round((imageBox1.GetPoints()[0] as ImageBox.Point).Row, 3),
  349. ModifyUserCode = SysMgr.Instance.UserMgr.LoginUser.Code,
  350. CreateUserCode = SysMgr.Instance.UserMgr.LoginUser.Code
  351. });
  352. ShowPoints();
  353. ReflashTable();
  354. ShowPointCount();
  355. }
  356. catch (Exception ex)
  357. {
  358. MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
  359. }
  360. }
  361. private void btnDel_Click(object sender, EventArgs e)
  362. {
  363. try
  364. {
  365. if (this.dgvPointTable.SelectedRows.Count != 1)
  366. throw new Exception("请选择要删除的位置!");
  367. int liRowIndex = this.dgvPointTable.SelectedRows[0].Index;
  368. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == this.cbPointName.Text).ToList();
  369. int findIndex = DefectPoints.FindIndex(temp => (temp.X == t[liRowIndex].X && temp.Y == t[liRowIndex].Y));
  370. DefectPoints.RemoveAt(findIndex);
  371. ReflashTable();
  372. if (liRowIndex >= dgvPointTable.Rows.Count - 1)
  373. liRowIndex = dgvPointTable.Rows.Count - 1;
  374. dgvPointTable.CurrentCell = dgvPointTable.Rows[liRowIndex].Cells[1];
  375. if (dgvPointTable.Rows.Count < 1)
  376. return;
  377. if (liRowIndex >= dgvPointTable.Rows.Count)
  378. liRowIndex = dgvPointTable.Rows.Count - 1;
  379. dgvPointTable.CurrentCell = dgvPointTable.Rows[liRowIndex].Cells[1];
  380. ShowPoints();
  381. ShowPointCount();
  382. }
  383. catch (Exception ex)
  384. {
  385. MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
  386. }
  387. }
  388. private void btnUp_Click(object sender, EventArgs e)
  389. {
  390. try
  391. {
  392. if (this.dgvPointTable.SelectedRows.Count != 1)
  393. throw new Exception("请选择要调整顺序的位置!");
  394. int liSelIndex = this.dgvPointTable.SelectedRows[0].Index;
  395. if (liSelIndex == 0)
  396. return;
  397. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == this.cbPointName.Text).ToList();
  398. int findIndex = DefectPoints.FindIndex(temp => (temp.X == t[liSelIndex].X && temp.Y == t[liSelIndex].Y));
  399. int findIndexPre = DefectPoints.FindIndex(temp => (temp.X == t[liSelIndex - 1].X && temp.Y == t[liSelIndex - 1].Y));
  400. DefectPoints.Insert(findIndexPre, DefectPoints[findIndex]);
  401. DefectPoints.RemoveAt(findIndex + 1);
  402. ReflashTable();
  403. this.dgvPointTable.Rows[liSelIndex - 1].Selected = true;
  404. dgvPointTable.CurrentCell = dgvPointTable.Rows[liSelIndex - 1].Cells[1];
  405. ShowPoints();
  406. }
  407. catch (Exception ex)
  408. {
  409. MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
  410. }
  411. }
  412. private void btnDown_Click(object sender, EventArgs e)
  413. {
  414. try
  415. {
  416. if (this.dgvPointTable.SelectedRows.Count != 1)
  417. throw new Exception("请选择要调整顺序的位置!");
  418. int liSelIndex = this.dgvPointTable.SelectedRows[0].Index;
  419. if (liSelIndex == this.dgvPointTable.Rows.Count - 1)
  420. return;
  421. List<TestDefectPoints> t = model.TestDefectPointsList.Where(q => q.PointCode == this.cbPointName.Text).ToList();
  422. int findIndex = DefectPoints.FindIndex(temp => (temp.X == t[liSelIndex].X && temp.Y == t[liSelIndex].Y));
  423. int findIndexAft = DefectPoints.FindIndex(temp => (temp.X == t[liSelIndex + 1].X && temp.Y == t[liSelIndex + 1].Y));
  424. DefectPoints.Insert(findIndexAft + 1, DefectPoints[findIndex]);
  425. DefectPoints.RemoveAt(findIndex);
  426. ReflashTable();
  427. this.dgvPointTable.Rows[liSelIndex + 1].Selected = true;
  428. dgvPointTable.CurrentCell = dgvPointTable.Rows[liSelIndex + 1].Cells[1];
  429. ShowPoints();
  430. }
  431. catch (Exception ex)
  432. {
  433. MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
  434. }
  435. }
  436. #endregion
  437. }
  438. }