|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553 |
- using MaiMuAOI.SysCtrl;
- using MaiMuControl.Utils;
- using OpenCvSharp;
- using ProductionControl.UI;
- using ProductionControl.UIExtend;
- using System;
- using System.Collections;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.Diagnostics;
- using System.Drawing;
- using System.Drawing.Imaging;
- using System.IO;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Windows.Forms;
- using ToolKits.EnumTool;
- using ToolKits.mAPI;
-
- namespace MaiMuAOI.SysUI.ProductAndStep
- {
- public partial class ProductInfoFrm : Form
- {
- Service.ClassesService svcClasses = new Service.ClassesService();
- Service.ProductService service = new Service.ProductService();
- Models.Product model = new Models.Product();
-
- public ProductInfoFrm(Models.Product m = null)
- {
- InitializeComponent();
- UIStyle.SetUIStyle(this);
- this.uiTitel1.FatherForm = this;
-
- this.dgvBatchList.AutoGenerateColumns = false;
-
- this.Cursor = Cursors.WaitCursor;
- //去除PT线宽等
- //tabControl1.TabPages.RemoveAt(2);
- //this.cbMarkType.SelectedIndex = -1;
- if (m != null)
- {
- model = m;
- this.Text += $" (ID:{m.Id})";
- this.txtCode.Text = m.Code;
- this.txtName.Text = m.Name;
- this.txtSpec.Text = m.Spec;
-
- this.cmbHoleCount.Text = m.HoleCount.ToString();
-
- this.txtBatchId.Text = m.BatchId;
- this.numTargetCount.Value = m.TargetCount;
- this.toolTip1.SetToolTip(this.numTargetCount, "已完成:" + m.CompleteCount);
-
- this.numTensionBaseValue.Value = (decimal)m.TensionBaseValue;
- this.numTensionUpFloatValue.Value = (decimal)m.TensionUpFloatValue;
- this.numTensionDownFloatValue.Value = (decimal)m.TensionDownFloatValue;
- this.numHeightBaseValue.Value = (decimal)m.HeightBaseValue;
- this.numHeightUpFloatValue.Value = (decimal)m.HeightUpFloatValue;
- this.numHeightDownFloatValue.Value = (decimal)m.HeightDownFloatValue;
- this.txtHeightBaseDec.Text = m.HeightBaseDec;
- this.numLineWidthBaseValue.Value = (decimal)m.LineWidthBaseValue;
- this.numLineWidthUpFloatValue.Value = (decimal)m.LineWidthUpFloatValue;
- this.numLineWidthDownFloatValue.Value = (decimal)m.LineWidthDownFloatValue;
- this.numPTBaseValue.Value = (decimal)m.PTBaseValue;
- this.numPTUpFloatValue.Value = (decimal)m.PTUpFloatValue;
- this.numPTDownFloatValue.Value = (decimal)m.PTDownFloatValue;
-
- this.numPTXBaseValue.Value = (decimal)m.PTXBaseValue;
- this.numPTXUpFloatValue.Value = (decimal)m.PTXUpFloatValue;
- this.numPTXDownFloatValue.Value = (decimal)m.PTXDownFloatValue;
- //if (m.Type > 0)
- //{
- // this.txtCode.Enabled = false;
- // this.txtName.Width = this.txtCode.Width;
- // this.txtSpec.Enabled = false;
- //}
-
- this.tsbtnAddFile.Enabled = true;
- this.tsbtnNewBatchId.Enabled = true;
- this.dgvBatchList.DataSource = new BindingSource(m.BatchHistoryList, null);
- //2023-11-2 mark
- this.cbMarkType.SelectedIndex = m.MarkType;
- this.numMarkSize.Value = (decimal)m.MarkSize;
- //2023-12-18 主栅
- this.cbMarkDisturb.Checked = (m.MarkDisturb == 1);
- this.cbMainGrid.Checked = (m.MainGrid == 1);
-
- Models.Attachment attachmentFile = model.AttachmentList.FirstOrDefault(x => x.Type == 0);
- if (attachmentFile != null)
- {
- this.btnOpenFile.Text = attachmentFile.Name;
- this.btnOpenFile.Visible = true;
-
- if ((this.groupBox5.Width - this.btnOpenFile.Width) > 0)
- {
- this.btnOpenFile.Left = (this.groupBox5.Width - this.btnOpenFile.Width) / 2;
- }
- else
- this.btnOpenFile.Left = 20;
-
- this.textBoxPath.Text = ConfMgr.Instance.ProjectDir+ $"\\{model.Id}\\" + attachmentFile.Name;
- }
-
- }
- else
- {
- cbMarkType.SelectedIndex = 2;
- numMarkSize.Value = (decimal)0.5;
- this.textBoxPath.Text = "";
- }
- InitDataView();
- this.Cursor = Cursors.Default;
- }
- ArrayList GetArrayList<T>()
- {
- ArrayList list = new ArrayList();
- Type type = typeof(T);
- //list.Add(new DictionaryEntry("start", "启动按钮"));
- foreach (int value in Enum.GetValues(type))
- {
- string strName = Enum.GetName(type, value);//获取名称
- list.Add(new DictionaryEntry(value, strName));
- }
-
- return list;
- }
-
- private void InitDataView()
- {
- try
- {
- //显示的数据
- this.cmbClasses.DisplayMember = "Name";
- this.cmbClasses.ValueMember = "Id";
- var list = svcClasses.GetListNav(0);
- this.cmbClasses.DataSource = list;
- if (model.ClassesId > 0)
- this.cmbClasses.SelectedValue = model.ClassesId;
-
- //缺陷项
- //ArrayList lstDefect = new ArrayList();
- //List<string> DefectNames = new List<string>();
- //foreach (var item in Enum.GetValues(typeof(DefectCodeEnum)))
- //{
- // DefectCountOfSizeControl userCon = new DefectCountOfSizeControl();
- // userCon.Code = item.ToString();
- // userCon.Title = EnumExtension.GetEnumDescription((DefectCodeEnum)item);
-
- // if (model != null && model.QualifiedCriterionList != null)
- // {
- // var qalifiedItem = model.QualifiedCriterionList.FirstOrDefault(m => m.DefectCode == userCon.Code);
- // if (qalifiedItem != null)
- // {
- // userCon.Checked = true;
- // userCon.SizeValue = (decimal)qalifiedItem.Size;
- // userCon.MaxDefectCount = qalifiedItem.MaxDefectCount;
- // }
- // }
-
- // this.flpQualifiedPannel.Controls.Add(userCon);
- //}
- var lstDefect = GetArrayList<DefectCodeEnum>();
- foreach (DictionaryEntry item in lstDefect)
- {
- DefectCountOfSizeControl userCon = new DefectCountOfSizeControl();
- userCon.Code = item.Value.ToString();
- userCon.Title = ((DefectNameEnum)(int)item.Key).ToString();
- if (model != null && model.QualifiedCriterionList != null)
- {
- var qalifiedItem = model.QualifiedCriterionList.FirstOrDefault(m => m.DefectCode == userCon.Code);
- if (qalifiedItem != null)
- {
- userCon.Checked = true;
- userCon.SizeValue = (decimal)qalifiedItem.Size;
- userCon.MaxDefectCount = qalifiedItem.MaxDefectCount;
- }
- }
-
- this.flpQualifiedPannel.Controls.Add(userCon);
- }
-
-
- //模型文件
- string strDefectModelFile = ConfMgr.Instance.SysConfigParams.AIModelPath;
- string[] onnxFiles = Directory.GetFiles(strDefectModelFile, "*.onnx");
- string onlyName;
- foreach (string onnxFile in onnxFiles)
- {
- onlyName = Path.GetFileName(onnxFile);
- cmbDefectModelFile.Items.Add(onlyName);
- if (!string.IsNullOrWhiteSpace(model.DefectModelFile) && onlyName.ToLower() == model.DefectModelFile.ToLower())
- this.cmbDefectModelFile.SelectedItem = model.DefectModelFile;
- }
- }
- catch(Exception e)
- {
- MessageBox.Show("数据&模型载入出错:"+ e.Message,"报警", MessageBoxButtons.OK,MessageBoxIcon.Error);
- }
- }
-
- private void ProductInfoFrm_Load(object sender, EventArgs e)
- {
-
- }
-
- private void tsbtnSave_Click(object sender, EventArgs e)
- {
- try
- {
- string szCode = this.txtCode.Text.Trim();
- string szName = this.txtName.Text.Trim();
- string szSpec = this.txtSpec.Text.Trim();
- string szHoleCount = this.cmbHoleCount.Text.Trim();
- string szBatchId = this.txtBatchId.Text.Trim();
- int liTargetCount = (int)this.numTargetCount.Value;
- string szHeightBaseDec = this.txtHeightBaseDec.Text.Trim().Trim(new char[] { ';', ',' });
- if (szCode == "" || szName == "")
- throw new Exception("请填写料号和名称!");
- if (this.cmbClasses.SelectedIndex < 0)
- throw new Exception("请选择产品类型!");
- if (szHoleCount == "" || !Util.IsNumber(szHoleCount))
- throw new Exception("请正确填写产品目数!");
- if (this.cmbDefectModelFile.SelectedIndex < 0)
- throw new Exception("请选择检测模型文件!");
-
- if (this.cbMarkType.SelectedIndex < 0)
- throw new Exception("请选择Mark!");
- //if (szBatchId == "")// || liTargetCount < 1
- // throw new Exception("请填写批次号");// 和批次目标数量!");
- if (szHeightBaseDec != "")
- {
- double num;
- string[] szs = szHeightBaseDec.Split(new char[] { ';', ',' });
- foreach (string s in szs)
- {
- if (!double.TryParse(s, out num))
- throw new Exception(s + " 非数值!");
- }
- }
-
- model.Code = szCode;
- model.Name = szName;
- model.Spec = szSpec;
- model.ClassesId = (int)this.cmbClasses.SelectedValue;
- model.HoleCount = Convert.ToInt32(szHoleCount);
- model.DefectModelFile = this.cmbDefectModelFile.Text.Trim();
-
- model.TensionBaseValue = (double)this.numTensionBaseValue.Value;
- model.TensionUpFloatValue = (double)this.numTensionUpFloatValue.Value;
- model.TensionDownFloatValue = (double)this.numTensionDownFloatValue.Value;
- model.HeightBaseValue = (double)this.numHeightBaseValue.Value;
- model.HeightUpFloatValue = (double)this.numHeightUpFloatValue.Value;
- model.HeightDownFloatValue = (double)this.numHeightDownFloatValue.Value;
- model.HeightBaseDec = szHeightBaseDec;
- model.LineWidthBaseValue = (double)this.numLineWidthBaseValue.Value;
- model.LineWidthUpFloatValue = (double)this.numLineWidthUpFloatValue.Value;
- model.LineWidthDownFloatValue = (double)this.numLineWidthDownFloatValue.Value;
- model.PTBaseValue = (double)this.numPTBaseValue.Value;
- model.PTUpFloatValue = (double)this.numPTUpFloatValue.Value;
- model.PTDownFloatValue = (double)this.numPTDownFloatValue.Value;
-
- model.PTXBaseValue = (double)this.numPTXBaseValue.Value;
- model.PTXUpFloatValue = (double)this.numPTXUpFloatValue.Value;
- model.PTXDownFloatValue = (double)this.numPTXDownFloatValue.Value;
-
- if (model.QualifiedCriterionList == null)
- model.QualifiedCriterionList = new List<Models.QualifiedCriterion>();
- else
- model.QualifiedCriterionList.Clear();
- foreach (DefectCountOfSizeControl defectControl in this.flpQualifiedPannel.Controls)
- {
- if (defectControl.Checked)
- {
- model.QualifiedCriterionList.Add(
- new Models.QualifiedCriterion()
- {
- DefectCode = defectControl.Code,
- Size = (float)defectControl.SizeValue,
- MaxDefectCount = (int)defectControl.MaxDefectCount,
- ModifyUserCode = SysMgr.Instance.UserMgr.LoginUser.Code,
- CreateUserCode = SysMgr.Instance.UserMgr.LoginUser.Code
- });
- }
- }
- model.ModifyUserCode = SysMgr.Instance.UserMgr.LoginUser.Code;
-
- //2023-11-2 mark
- model.MarkType = this.cbMarkType.SelectedIndex;
- model.MarkSize = (double)this.numMarkSize.Value;
- //2023-12-18 主栅
- model.MarkDisturb = this.cbMarkDisturb.Checked ? 1 : 0;
- model.MainGrid = this.cbMainGrid.Checked ? 1 : 0;
-
- bool result;
- if (model.Id == 0)
- {
- model.BatchId = szBatchId;
- model.TargetCount = liTargetCount;
- model.CompleteCount = 0;
- model.CreateUserCode = SysMgr.Instance.UserMgr.LoginUser.Code;
- result = service.InsertNav(model);
- }
- else
- {
- if (model.BatchId != szBatchId && !string.IsNullOrWhiteSpace(model.BatchId))
- {
- if (model.CompleteCount < model.TargetCount
- && MessageBox.Show($"本批次完成数量未达到目标数量,确定更换批次号?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
- return;
- if (model.BatchHistoryList.FirstOrDefault(m => m.BatchId == szBatchId) != null)
- throw new Exception("当前批次号与历史中所用批次号重复,请重新填写!");
-
- model.BatchHistoryList.Add(new Models.BatchHistory()
- {
- BatchId = model.BatchId,
- TargetCount = model.TargetCount,
- CompleteCount = model.CompleteCount,
- CreateUserCode = SysMgr.Instance.UserMgr.LoginUser.Code,
- ModifyUserCode = SysMgr.Instance.UserMgr.LoginUser.Code
- });
- model.CompleteCount = 0;
- }
-
- model.BatchId = szBatchId;
- model.TargetCount = liTargetCount;
- result = service.UpdateNav(model);
- }
- if (!result)
- throw new Exception("保存失败!");
-
- this.tsbtnAddFile.Enabled = true;
- this.tsbtnNewBatchId.Enabled = true;
- MessageBox.Show("保存成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
- this.DialogResult = DialogResult.OK;
- this.Close();
- }
- catch (Exception ex)
- {
- MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
- }
- }
-
- private void tsbtnExit_Click(object sender, EventArgs e)
- {
- this.Close();
- }
-
- private void tsbtnNewBatchId_Click(object sender, EventArgs e)
- {
-
- }
-
- private void tsbtnAddFile_Click(object sender, EventArgs e)
- {
- this.Cursor = Cursors.WaitCursor;
- try
- {
- if (this.cbMarkType.SelectedIndex < 0)
- throw new Exception("请选择Mark!");
- //.dwg /.dxf /.dws /.dwt
- string filePath = ConfMgr.SelectFile("gbx,gbr文件|*.gb?");
- if (string.IsNullOrWhiteSpace(filePath))
- return;
-
- string fileName = Path.GetFileName(filePath);
- string fileExtend = Path.GetExtension(filePath);
- string fileOnlyName = fileName.Substring(0, fileName.Length - fileExtend.Length);
-
- //
- string targFilePath = ConfMgr.Instance.ProjectDir + $"\\{model.Id}\\";
- if (!Directory.Exists(targFilePath))
- Directory.CreateDirectory(targFilePath);
- else//删除原文件
- ConfMgr.DelFilesInFolder(targFilePath);
-
- targFilePath += fileName;
- //File.Copy(res.file_path, defectFileName + ".bmp", true);
- bool result = API.CopyFile(filePath, targFilePath, false);//更快 //false-覆盖
- if (!result)
- throw new Exception("移动文件失败!");
-
- //后台线程转BMP与JPG
- string tempClass = this.cmbClasses.Text;
- int tempIndex = this.cbMarkType.SelectedIndex;
- double tempSize = (double)this.numMarkSize.Value;
-
- //2023-12-18
- int tMarkDistrub = this.cbMarkDisturb.Checked ? 1 : 0;
- int tMainGrid = this.cbMainGrid.Checked ? 1 : 0;
-
- //Task.Run(() =>
- {
- Yolo5.Yolo_Class yolo = new Yolo5.Yolo_Class();
- string bmpPath = targFilePath.Substring(0, targFilePath.Length - 4) + ".bmp";
- //2023-11-3 mark
- //yolo.gerber2image(targFilePath, bmpPath);
- double[] markParam = new double[6];
- if (tempClass.Contains("乳剂"))
- markParam[0] = 2;
- else if (tempClass.Contains("PI"))
- markParam[0] = 1;
- else
- markParam[0] = 0;
- if (tempIndex == 0)
- {
- //默认情况 实心圆,0.5mm
- markParam[1] = 2;
- markParam[2] = 0.5;
- markParam[3] = 1;
- markParam[4] = 0;
- markParam[5] = 0;
- }
- else
- {
- markParam[1] = tempIndex - 1;
- markParam[2] = tempSize;
- markParam[3] = tempIndex == 1 ? 0 : 1;
- markParam[4] = tMarkDistrub;
- markParam[5] = tMainGrid;
- }
- yolo.gerber2image(targFilePath, bmpPath, markParam);
-
- //换背景JPG
- Mat mat = Cv2.ImRead(bmpPath);
- Cv2.CvtColor(mat, mat, ColorConversionCodes.RGB2GRAY);//转灰度图
- for (int i = 0; i < mat.Height; i++)
- {
- for (int j = 0; j < mat.Width; j++)
- {
- if (mat.At<byte>(i, j) == 255)//白色
- mat.Set<byte>(i, j, 0);
- else
- mat.Set<byte>(i, j, 255);
- }
- }
- model.MapPath = bmpPath;
- //灰转彩
- //Cv2.CvtColor(mat, mat, ColorConversionCodes.GRAY2RGB);
- //for (int i = 0; i < mat.Height; i++)
- //{
- // for (int j = 0; j < mat.Width; j++)
- // {
- // if (mat.At<byte>(i, j) == 255)//白色
- // mat.Set<byte>(i, j, 0); //黄色
- // }
- //}
- bmpPath = targFilePath.Substring(0, targFilePath.Length - 4) + ".jpg";
- OpenCvSharp.Extensions.BitmapConverter.ToBitmap(mat).Save(bmpPath, ImageFormat.Jpeg);
- //});//不能加.Start();
- }
- Models.Attachment attachmentFile = model.AttachmentList.FirstOrDefault(m => m.Type == 0);
- if (attachmentFile != null)
- {
- attachmentFile.Type = 0;//图纸
- attachmentFile.NameTimestamp = $"{model.Id}\\{fileOnlyName}";
- attachmentFile.Name = fileName;
- attachmentFile.ExtendName = fileExtend;
- }
- else
- {
- model.AttachmentList.Add(new Models.Attachment()
- {
- TBName = "product",
- Type = 0,
- NameTimestamp = $"{model.Id}\\{fileOnlyName}",
- Name = fileName,
- ExtendName = fileExtend,
- CreateUserCode = SysMgr.Instance.UserMgr.LoginUser.Code,
- ModifyUserCode = SysMgr.Instance.UserMgr.LoginUser.Code
- });
- }
- if (!service.UpdateNav(model))
- throw new Exception("保存文件失败!");
-
- model = service.GetModelNav(model.Code);
- this.btnOpenFile.Text = fileName;
- this.btnOpenFile.Visible = true;
- }
- catch (Exception ex)
- {
- MessageBox.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
- }
- finally
- {
- this.Cursor = Cursors.Default;
- }
- }
-
- private void btnOpenFile_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
- {
- Models.Attachment attachmentFile = model.AttachmentList.FirstOrDefault(m => m.Type == 0);
- if (attachmentFile == null)
- MessageBox.Show("还未上传!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
- string filePath = ConfMgr.Instance.ProjectDir + $"\\{model.Id}\\" + attachmentFile.Name;
- if (File.Exists(filePath))
- Process.Start(filePath);
- }
-
- private void tbtnGetPos_Click(object sender, EventArgs e)
- {
- if ((model.MapPath == null) || (string.IsNullOrEmpty(model.MapPath)))
- {
- MessageBox.Show("还未上传图纸!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
- return;
- }
- List<double> dList = new List<double>();
- if (model.GetPointList != null)
- {
- var list = model.GetPointList.Split(',');
- dList = new List<double>();
- if (list.Length < 28)
- {
- for (int i = 0; i < 28; i++)
- {
- dList.Add(0);
- }
- }
- else
- {
- for (int i = 0; i < list.Length; i++)
- {
- dList.Add(double.Parse(list[i]));
- }
- }
- }
- FrmGetPosByPic frm = new FrmGetPosByPic(model, model.MapPath, dList.ToArray());
- frm.ShowDialog();
- model.GetPointList = string.Join(",", frm.GetPoints()); ;
- model.MapPath = frm.GetMapPath();
-
- if (!service.UpdateNav(model))
- throw new Exception("保存文件失败!");
-
- model = service.GetModelNav(model.Code);
- }
-
- private void textBoxPath_DoubleClick(object sender, EventArgs e)
- {
- if (File.Exists(this.textBoxPath.Text))
- {
- Models.Attachment attachmentFile = model.AttachmentList.FirstOrDefault(x => x.Type == 0);
- if (attachmentFile != null)
- {
- System.Diagnostics.ProcessStartInfo psi = new System.Diagnostics.ProcessStartInfo("Explorer.exe");
- psi.Arguments = "/e,/select," + ConfMgr.Instance.ProjectDir + $"\\{model.Id}\\";
- System.Diagnostics.Process.Start(psi);
- }
- }
- }
- }
- }
|