using OpenCvSharp; using PaintDotNet.Annotation; using PaintDotNet.Annotation.Enum; using PaintDotNet.Base.CommTool; using PaintDotNet.Base.Functionodel; using PaintDotNet.Base.SettingModel; using PaintDotNet.CustomControl; using PaintDotNet.DbOpreate.DbBll; using PaintDotNet.DbOpreate.DbModel; using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Configuration; using System.Data; using System.Drawing; using System.Drawing.Drawing2D; using System.IO; using System.Linq; using System.Text; using System.Windows.Forms; namespace PaintDotNet.DedicatedAnalysis.Battery { internal partial class BatteryCrystalDialog : PdnBaseForm { #region 属性 //二值化集成1 BinaryClassForB binaryClass; private int menuId; /// /// 选中图片的bitmap /// private Bitmap bitmap; /// /// 存在视场标记 /// private bool existViewFlag = false; private int changeCount; /// /// 主空间 /// private AppWorkspace appWorkspace; /// /// 图像面板 /// private DocumentWorkspaceWindow documentWorkspace; /// /// 公共控件 /// private GeneralAnalysisCommonControlButtons commonControlButtons; /// /// 图片测量记录 /// private List pictureDataTables = new List(); /// /// 网格Xml /// private GrainSizePointCountingMethodModel grainSizePointCountingMethodModel; /// /// 数据变化 /// private bool saveSuccess = false; private BinaryControlSmaller bc; #endregion 属性 #region 数据属性 /// /// 折线点的集合 /// public List pointArray = new List(); /// /// 存储所有轮廓线的点集合 /// private List pointList = new List(); /// /// 存储所有轮廓线集合 /// private List> lineList = new List>(); /// /// 存储所有增加颗粒的点集合 /// private List kongPointList = new List(); /// /// 存储所有孔隙线集合 /// private List> kongLineList = new List>(); /// /// 存储所有删除孔隙线的点集合 /// private List delPointList = new List(); /// /// 存储所有删除孔隙线集合 /// private List> delLineList = new List>(); //轮廓修改状态 bool isLunKuo = false; //添加孔隙状态 bool isAddKong = false; //删除孔隙状态 bool isDelKong = false; /// /// 0:添加 1:选择 2:删除 /// private int operationK = -1; /// /// 被选择的线 /// private int selected = -1; /// /// 起止点 /// private System.Drawing.PointF startPoint, endPoint; /// /// 存储所有线的点集合 /// private List pointList1 = new List(); /// /// 存储当前线的点集合 /// private PointF[] nowLine; /// /// 辅助计算偏移量-移动线两端的点 /// private PointF lastPoint = new PointF(0, 0); /// /// 辅助计算偏移量-移动线中间的点 /// private PointF tempPoint = new PointF(0, 0); /// /// 判断图形是否可移动 /// private bool canMove = false; /// /// 测量点 /// public List rectangleFList = new List(); /// /// 移动线上的哪一个点 /// private int movePointIndex = -1; /// /// 线的总数 /// private int lineCount = 0; /// /// 单位标尺 /// private double unitLength = 1; string unString = "纳米"; string unStringE = "nm"; #endregion System.Windows.Forms.DataVisualization.Charting.Chart chart1 = new System.Windows.Forms.DataVisualization.Charting.Chart(); /// /// /// /// public BatteryCrystalDialog(AppWorkspace appWorkspace, int menuId) { this.KeyPreview = true; this.KeyDown += OnKeyDown; this.menuId = menuId; binaryClass = new BinaryClassForB(menuId); InitializeComponent(); InitializeLanguageText(); ColumnHeader header0 = new ColumnHeader(); header0.Text = ""; header0.Width = 180; this.appWorkspace = appWorkspace; this.documentWorkspace = new DocumentWorkspaceWindow(appWorkspace); this.documentWorkspace.Dock = DockStyle.Fill; this.documentWorkspace.HookMouseEvents(); this.documentWorkspace.AuxiliaryLineEnabled = false; this.documentWorkspace.Visible = false; this.documentWorkspace.panel.Paint += Panel_Paint; this.documentWorkspace.panel.MouseDown += OnMouseDown; this.documentWorkspace.panel.MouseUp += OnMouseUp; this.documentWorkspace.panel.Paint += Panel_Paint; this.documentWorkspace.panel.MouseMove += onMouseMove; this.documentWorkspace.activeTool = DrawToolType.Pointer; this.groupBox7.Controls.Add(this.documentWorkspace); this.commonControlButtons = new GeneralAnalysisCommonControlButtons(); this.commonControlButtons.Dock = DockStyle.Top; this.commonControlButtons.Height = 30; this.commonControlButtons.HideZoomToWindowAndActualSize(); this.commonControlButtons.trackLabel.Text = "单击开始画线,右键停止。"; this.commonControlButtons.trackLabel.Visible = true; this.commonControlButtons.trackLabel.Width = 300; this.commonControlButtons.Visible = false; this.groupBox7.Controls.Add(commonControlButtons); //获取 //Startup.instance.rules.TryGetValue(MeasurementUnit.Micron, out ruleValue); //double ruleValue = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GetRuler(MeasurementUnit.Micron); ////double physical_area_length_Micron = getCurrentWorkspace().GetRuler(MeasurementUnit.Micron); chart1.Size = new System.Drawing.Size(1150, 180); chart1.Location = new System.Drawing.Point(5, 15); //二值化集成2 bc.OriginCheckedChangedAction += new EventHandler(this.bcOriginCheckedChanged);//初始化原图勾选改变事件 binaryClass.imageType = 2; binaryClass.createDocumentItemsSmaller(new string[] { "bp1" } , this.bc, this.appWorkspace, this.documentWorkspace, this.listView1);//初始化相的工作结构 //binaryClass.BinaryImplFinishAction += new EventHandler(this.bClassBinaryImplFinishAction);//二值化后续处理事件(参数改变时,重新处理图像) binaryClass.parentSinglCrystal = this; this.ckChanged.CheckedChanged += new EventHandler(this.CheckedChanged); this.ckDis.CheckedChanged += new EventHandler(this.IsDisChanged); this.ckJu.CheckedChanged += new EventHandler(this.IsDisChanged); numericUpDown11.Value=Convert.ToDecimal( binaryClass.pointsize); numericMax.Value = binaryClass.border; numericHW.Value = Convert.ToDecimal(binaryClass.HW); numericArea.Value = Convert.ToDecimal(binaryClass.AreaRatio); numericBottom.Value = binaryClass.borderBottom; numericNum.Value = binaryClass.numDecimals; string checkstate = binaryClass.CheckState.ToString(); if (checkstate.Length == 5) { ckMin.Checked = checkstate.Substring(1, 1) == "1" ? true : false; ckMax.Checked = checkstate.Substring(2, 1) == "1" ? true : false; ckHW.Checked = checkstate.Substring(3, 1) == "1" ? true : false; ckArea.Checked = checkstate.Substring(4, 1) == "1" ? true : false; } else if (checkstate.Length == 7) { ckMin.Checked = checkstate.Substring(1, 1) == "1" ? true : false; ckMax.Checked = checkstate.Substring(2, 1) == "1" ? true : false; ckHW.Checked = checkstate.Substring(3, 1) == "1" ? true : false; ckArea.Checked = checkstate.Substring(4, 1) == "1" ? true : false; ckBottom.Checked = checkstate.Substring(5, 1) == "1" ? true : false; ckNum.Checked = checkstate.Substring(6, 1) == "1" ? true : false; } InitCommonButtonEvent(); InitGridStyle(); InitPicList(); // SetAnalyzeModelFromXml(getModelName()); } private void CkDis_CheckedChanged(object sender, EventArgs e) { throw new NotImplementedException(); } private void ShowImgEvent(object sender, EventArgs e) { if (this.listView1.Items.Count == 0) { return; } listView1.Focus(); this.listView1.Items[0].Focused = true; this.listView1.Items[0].Selected = true; } #region 二值化相关方法 private void InclusionsStandardDialog_FormClosing(object sender, FormClosingEventArgs e) { int check = 1000000; double minpoint = Convert.ToDouble(numericUpDown11.Value); int minpointInt = ckMin.Checked ? 1 : 0; int border = Convert.ToInt32(numericMax.Value); int borderInt = ckMax.Checked ? 1 : 0; double HW = Convert.ToDouble(numericHW.Value); int HWInt = ckHW.Checked ? 1 : 0; double AreaRatio = Convert.ToDouble(numericArea.Value); int AreaRatioInt = ckArea.Checked ? 1 : 0; int bottom = Convert.ToInt32(numericBottom.Value); int bottomInt = ckBottom.Checked ? 1 : 0; int size = Convert.ToInt32(numericNum.Value); int sizeInt = ckNum.Checked ? 1 : 0; check = check + minpointInt * 100000 + borderInt * 10000 + HWInt * 1000 + AreaRatioInt * 100 + bottomInt * 10 + sizeInt; List paramsList = new List() { Convert.ToInt32(minpoint * 100) , Convert.ToInt32(border * 100) , Convert.ToInt32(HW * 100) , Convert.ToInt32(AreaRatio * 100) , Convert.ToInt32(bottom * 100) , Convert.ToInt32(size),check }; binaryClass.saveParams(paramsList); } private void ShownChoiseItemAndInitData(object sender, EventArgs e) { binaryClass.RefreshHistogramControl1Values(); } /// /// 添加参数改变的监听 /// /// /// private void GrainSizePointCountingMethodDialog_Load(object sender, EventArgs e) { this.dataGridView1.SortCompare += DataGridView4_SortCompare; this.binaryClass.loadParams(); } private bool bcBinaryChecked() { return bc != null && bc.BinaryChecked; } private bool bcOriginChecked() { return bc != null && bc.OriginChecked; } /// /// 显示原图/原图+二值图 /// /// /// private void bcOriginCheckedChanged(object sender, EventArgs e) { if (!bcOriginChecked()) { if (bcBinaryChecked()) this.documentWorkspace.PhaseModels[0].choise = true; } else this.documentWorkspace.PhaseModels[0].choise = false; this.documentWorkspace.Refresh(); } /// /// 显示原图/原图+二值图 /// /// /// private void CheckedChanged(object sender, EventArgs e) { if (!ckChanged.Checked) { this.documentWorkspace.PhaseModels[0].choise = true; } else this.documentWorkspace.PhaseModels[0].choise = false; this.documentWorkspace.Refresh(); } #endregion /// /// 初始化画面数据 /// private void InitGridStyle() { grainSizePointCountingMethodModel = XmlSerializeHelper.DESerializer(FileOperationHelper.ReadStringFromFile(Application.StartupPath + "\\Config\\" + Startup.instance.SettingPrefix + "\\GrainSizePointCountingMethodModel.xml", FileMode.Open)); if (grainSizePointCountingMethodModel.GridStyleList != null) { ArrayList arrayList = new ArrayList(); foreach (var GridStyle in grainSizePointCountingMethodModel.GridStyleList) { arrayList.Add(GridStyle.gridName); } if (grainSizePointCountingMethodModel.GridStyleList.Count == 0) { } } } /// /// 初始化图片列表数据 /// public void InitPicList() { //初始化图片列表 for (int i = 0; i < this.appWorkspace.DocumentWorkspaces.Length; i++) { this.imageList1.Images.Add("img" + i, this.appWorkspace.DocumentWorkspaces[i].BinarizationThumbnail); this.listView1.Items.Add("", i); this.listView1.Items[i].ImageIndex = i; this.listView1.Items[i].Text = this.appWorkspace.DocumentWorkspaces[i].GetFriendlyName(); this.listView1.Items[i].Name = this.appWorkspace.DocumentWorkspaces[i].GetFriendlyName(); } if (listView1.Items.Count > 0) { //标尺 微米/像素 MeasurementUnit unit = this.appWorkspace.DocumentWorkspaces[0].GetMeasurementUnit(); if (unit == MeasurementUnit.Micron) { unString = "微米"; unStringE = "μm"; ColumnVal.HeaderText = "值/微米"; groupBox9.Text = "颗粒信息-单位:微米"; groupBoxGrid2.Text = "统计结果-单位:微米"; } //标尺 纳米/像素 unitLength = this.appWorkspace.DocumentWorkspaces[0].GetRuler(unit); binaryClass.unitLength = unitLength; } this.Shown += ShowImgEvent; } #region 初始化 private void InitializeLanguageText() { this.bc = new PaintDotNet.CustomControl.BinaryControlSmaller(); // // bc // this.bc.BinaryBackColor = System.Drawing.Color.Red; this.bc.BinaryChecked = false; this.bc.BinaryStyle = 1; this.bc.Location = new System.Drawing.Point(152, 7); this.bc.Name = "bc"; this.bc.OriginChecked = false; this.bc.scope1End = 170D; this.bc.scope1Start = 80D; this.bc.scope2End = 0D; this.bc.scope2Start = 0D; this.bc.scope3End = 0D; this.bc.scope3Start = 0D; this.bc.Size = new System.Drawing.Size(360, 247); this.bc.TabIndex = 3; // this.Controls.Add(this.bc); // this.Controls.SetChildIndex(this.bc, 0); //this.groupBox9.Controls.Add(chart1); this.groupBox8.Controls.Add(chart1); chart1.Visible = false; //this.label10.Visible = true; //this.label10.Text = "【" + tn.Name + "】图"; chart1.Titles.Add("单晶尺寸分布图"); } #endregion #region 公共按钮 private void InitCommonButtonEvent() { this.commonControlButtons.zoomInButton.Click += new EventHandler(zoomInButton_Click); this.commonControlButtons.zoomOutButton.Click += new EventHandler(zoomOutButton_Click); this.commonControlButtons.zoomToWindowButton.Click += new EventHandler(zoomToWindowButton_Click); this.commonControlButtons.actualSizeButton.Click += new EventHandler(actualSizeButton_Click); this.commonControlButtons.pointerButton.Click += new EventHandler(pointerButton_Click); this.commonControlButtons.mobileModeButton.Click += new EventHandler(mobileModeButton_Click); } private void zoomInButton_Click(object sender, EventArgs e) { this.documentWorkspace.ZoomIn(); } private void zoomOutButton_Click(object sender, EventArgs e) { this.documentWorkspace.ZoomOut(); } private void zoomToWindowButton_Click(object sender, EventArgs e) { this.documentWorkspace.ZoomBasis = ZoomBasis.FitToWindow; } private void actualSizeButton_Click(object sender, EventArgs e) { this.documentWorkspace.ZoomBasis = ZoomBasis.ScaleFactor; this.documentWorkspace.ScaleFactor = ScaleFactor.OneToOne; } private void pointerButton_Click(object sender, EventArgs e) { this.documentWorkspace.ActiveTool = Annotation.Enum.DrawToolType.Pointer; } private void mobileModeButton_Click(object sender, EventArgs e) { this.documentWorkspace.ActiveTool = Annotation.Enum.DrawToolType.MoveMode; } #endregion private void listView1_MouseDown(object sender, MouseEventArgs e) { this.changeCount = 0; } private void DataGridView4_SortCompare(object sender, DataGridViewSortCompareEventArgs e) { // 如果是数据的列,则按浮点数处理 //if (e.Column.Index > 1)//###20186 //{ e.SortResult = (Convert.ToDouble(e.CellValue1) - Convert.ToDouble(e.CellValue2) > 0) ? 1 : (Convert.ToDouble(e.CellValue1) - Convert.ToDouble(e.CellValue2) < 0) ? -1 : 0; // } ////否则,按字符串比较 //else //{ // e.SortResult = System.String.Compare(Convert.ToString(e.CellValue1), Convert.ToString(e.CellValue2)); //} e.Handled = true;//不能省掉,不然没效果 } private void listView1_ItemSelectionChanged(object sender, ListViewItemSelectionChangedEventArgs e) { this.changeCount++; } /// /// 切换图片 /// /// /// private void listView1_SelectedIndexChanged(object sender, EventArgs e) { SelectedIndexChanged(); } /// /// 显示矩形测距 /// /// /// private void IsDisChanged(object sender, EventArgs e) { binaryClass.isDis = ckDis.Checked; binaryClass.isJu = ckJu.Checked; btnReDrw_Click(null, null); // SelectedIndexChanged(); } List list = new List(); /// /// 切换图片 /// private void SelectedIndexChanged() { if (this.listView1.FocusedItem != null && this.listView1.FocusedItem.Selected) { existViewFlag = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GraphicsList.IsExsitView(); this.bitmap = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].CompositionSurface.CreateAliasedBitmap(); lineList.Clear(); pointList.Clear(); kongLineList.Clear(); kongPointList.Clear(); delLineList.Clear(); delPointList.Clear(); pointList1.Clear(); isLunKuo = false; isAddKong = false; isDelKong = false; this.documentWorkspace.Refresh(); this.dataGridView1.Rows.Clear(); this.dataGridView2.Rows.Clear(); chart1.Series.Clear(); chart1.ChartAreas.Clear(); chart1.Legends.Clear(); Init(); this.documentWorkspace.GridRectangleEnabled = false; //getimage(); //getbian(bitmap); double minpoint = Convert.ToDouble(numericUpDown11.Value); if (!ckMin.Checked) minpoint = 0.01; binaryClass.pointsize = Convert.ToDouble(minpoint); int border = Convert.ToInt32(numericMax.Value); if (!ckMax.Checked) border = 0; binaryClass.border = border; double HW = Convert.ToDouble(numericHW.Value); if (!ckHW.Checked) HW = 100; binaryClass.HW = HW; double AreaRatio = Convert.ToDouble(numericArea.Value); if (!ckArea.Checked) AreaRatio = 0.01; binaryClass.AreaRatio = AreaRatio; int bottom = Convert.ToInt32(numericBottom.Value); if (!ckBottom.Checked) bottom = 0; binaryClass.borderBottom = bottom; //二值化集成4 binaryClass.listView1_SelectedIndexChanged(this.bitmap); // binaryClass.bcDefault(); this.documentWorkspace.Refresh(); } } #region 原始事件 private void Init() { this.commonControlButtons.Visible = true; this.dataGridView1.Rows.Clear(); this.documentWorkspace.phaseModels.Clear(); } /// /// 画布绘制 /// /// /// private void Panel_Paint(object sender, PaintEventArgs e) { if (this.documentWorkspace.CompositionSurface != null) { // // 以下是计算绘制图片的位置和大小并绘制图片 // Rectangle rc = this.documentWorkspace.panel.ClientRectangle; int width = (int)(this.documentWorkspace.CompositionSurface.Width * this.documentWorkspace.ScaleFactor.Ratio); int height = (int)(this.documentWorkspace.CompositionSurface.Height * this.documentWorkspace.ScaleFactor.Ratio); int x = (rc.Width < width) ? this.documentWorkspace.panel.AutoScrollPosition.X : (rc.Width - width) / 2; int y = (rc.Height < height) ? this.documentWorkspace.panel.AutoScrollPosition.Y : (rc.Height - height) / 2; //if (pointArray.Count > 1) //{ // e.Graphics.DrawLines(new Pen(Color.FromArgb(0, 0, 0), 2), pointArray.ToArray()); //} // // 以下是绘制网格、标注、测量、视场等开始 // e.Graphics.TranslateTransform(x, y); e.Graphics.ScaleTransform((float)this.documentWorkspace.ScaleFactor.Ratio, (float)this.documentWorkspace.ScaleFactor.Ratio); Draw(e.Graphics); //e.Graphics.DrawLines(new Pen(this.panel1.BackColor, Convert.ToInt32(this.txt_LeftLineWeight.Text)), list.ToArray()); e.Graphics.ScaleTransform(1 / (float)this.documentWorkspace.ScaleFactor.Ratio, 1 / (float)this.documentWorkspace.ScaleFactor.Ratio); e.Graphics.TranslateTransform(-x, -y); } if (bc.isedit) { bc.isedit = false; List> CircleDate = bc.data; bindGrid(CircleDate); } } // /// 存储字号与颜色字典 /// public Dictionary colourFont = new Dictionary() { { "20", Color.White } }; /// /// 绘制 /// private void Draw(Graphics graphics) { //轮廓手动干预线 if (lineList.Count > 0) { for (int i = 0; i < lineList.Count; i++) { graphics.DrawLines(new Pen(Color.FromArgb(255, 0, 255), 2), lineList[i].ToArray()); } } if (pointList.Count > 1) { graphics.DrawLines(new Pen(Color.FromArgb(255, 0, 255), 2), pointList.ToArray()); } //添加颗粒 Color color = Color.FromArgb(255,0, 0,255); if (kongLineList.Count > 0) { for (int i = 0; i < kongLineList.Count; i++) { if (kongLineList[i].Count > 1) { graphics.DrawLines(new Pen(color, 2), kongLineList[i].ToArray()); } } } graphics.SmoothingMode = SmoothingMode.AntiAlias; Pen standardPen = new Pen(Color.FromArgb(0, 255, 0), 4);//基准线画笔 Pen surfacePen = new Pen(Color.FromArgb(255, 0, 0), 4);//钢样表面画笔 Pen completePen = new Pen(Color.FromArgb(0, 0, 255), 4);//完全脱碳层画笔 Pen validPen = new Pen(Color.FromArgb(255, 255, 255), 4);//有效脱碳层画笔 Pen partPen = new Pen(Color.FromArgb(0, 0, 0), 2);//部分脱碳层画笔 Pen borderPen = new Pen(Color.Black);//填充点外圈 SolidBrush insideBrush = new SolidBrush(Color.White);//填充点内圈 Pen rectPen = new Pen(Color.Black); rectPen.DashStyle = DashStyle.Custom; float[] dashArray = { 2.0f, 3.0f }; rectPen.DashPattern = dashArray; if (pointList1.Count > 0) { foreach (PointF[] pointFs in pointList1) { PointF[] pf = pointFs; if (pointFs.Count() > 1 && pointFs[0] != pointFs[1]) { float lineLength = 12; double angle = Math.Round(BasicCalculationHelper.AngleText(pointFs[0], pointFs[1], new PointF(pointFs[0].X + lineLength, pointFs[0].Y)), 10); //判断第二个点相对于第一个点的象限 int x2 = (int)(pointFs[1].X - pointFs[0].X); if (x2 == 0) x2 = 1; int y2 = (int)(pointFs[1].Y - pointFs[0].Y); if (y2 == 0) y2 = 1; int i2 = 0; if (x2 > 0 && y2 > 0) //第4象限 { i2 = 4; } else if (x2 > 0 && y2 < 0) //第1象限 { i2 = 1; } else if (x2 < 0 && y2 < 0) //第2象限 { i2 = 2; } else if (x2 < 0 && y2 > 0) //第3象限 { i2 = 3; } double sAngle1; double eAngle1; double sAngle2; double eAngle2; if (i2 == 1 || i2 == 2) { sAngle1 = 360 - angle; eAngle1 = 180 - angle; sAngle2 = 270 - angle; eAngle2 = 90 - angle; } else { sAngle1 = angle; eAngle1 = 180 + angle; sAngle2 = 270 + angle; eAngle2 = 90 + angle; } graphics.DrawLine(standardPen, pointFs[0], pointFs[1]); if (!double.IsNaN(sAngle1) && !double.IsNaN(eAngle1) && !double.IsNaN(sAngle2) && !double.IsNaN(eAngle2)) { PointF assistPoint1 = BasicCalculationHelper.GetAnglePoint(new PointF((pointFs[0].X + lineLength), pointFs[0].Y), pointFs[0], sAngle2); PointF assistPoint2 = BasicCalculationHelper.GetAnglePoint(new PointF((pointFs[0].X + lineLength), pointFs[0].Y), pointFs[0], eAngle2); PointF assistPoint3 = BasicCalculationHelper.GetAnglePoint(new PointF((pointFs[1].X + lineLength), pointFs[1].Y), pointFs[1], sAngle2); PointF assistPoint4 = BasicCalculationHelper.GetAnglePoint(new PointF((pointFs[1].X + lineLength), pointFs[1].Y), pointFs[1], eAngle2); graphics.DrawLine(surfacePen, assistPoint1, assistPoint2); graphics.DrawLine(partPen, assistPoint3, assistPoint4); //PointF[] pf = pointFs; if (i2 == 1 || i2 == 2) { graphics.DrawString(Math.Round((BasicCalculationHelper.GetDistance(pf[1], pf[0], 4) * unitLength),2).ToString(), new Font("宋体", float.Parse(colourFont.Keys.First()), System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))), new SolidBrush(colourFont.Values.First()), assistPoint4.X, assistPoint4.Y - 10); } else { graphics.DrawString(Math.Round((BasicCalculationHelper.GetDistance(pf[1], pf[0], 4) * unitLength), 2).ToString(), new Font("宋体", float.Parse(colourFont.Keys.First()), System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))), new SolidBrush(colourFont.Values.First()), assistPoint3.X, assistPoint3.Y - 10); } } } } if (selected > -1) { int tempLess = (int)(InvariantData.rectless * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)); int tempPlus = (int)(InvariantData.rectplus * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)); graphics.DrawRectangle(borderPen, new Rectangle((int)(pointList1[selected][0].X - tempLess), (int)(pointList1[selected][0].Y - tempLess), tempPlus, tempPlus)); graphics.FillRectangle(insideBrush, new RectangleF(pointList1[selected][0].X - tempLess, pointList1[selected][0].Y - tempLess, tempPlus, tempPlus)); graphics.DrawRectangle(borderPen, new Rectangle((int)(pointList1[selected][1].X - tempLess), (int)(pointList1[selected][1].Y - tempLess), tempPlus, tempPlus)); graphics.FillRectangle(insideBrush, new RectangleF(pointList1[selected][1].X - tempLess, pointList1[selected][1].Y - tempLess, tempPlus, tempPlus)); graphics.DrawRectangle(rectPen, rectangleFList[selected].X, rectangleFList[selected].Y, rectangleFList[selected].Width, rectangleFList[selected].Height); } } standardPen.Dispose(); surfacePen.Dispose(); completePen.Dispose(); validPen.Dispose(); partPen.Dispose(); borderPen.Dispose(); insideBrush.Dispose(); rectPen.Dispose(); } //最长直径 double MaxM = 0; double MinM = 0; double MeanM = 0; DataTable dtChart = new DataTable(); private void bindGrid(List> dataList) { if (dataList.Count < 1) { return; } chart1.Visible = true; List CircleDate = dataList[0]; dataGridView1.Rows.Clear(); dataGridView2.Rows.Clear(); chart1.Series.Clear(); chart1.ChartAreas.Clear(); List colorList = new List() { Color.FromArgb(255, 0, 0), Color.FromArgb(0, 255, 0), Color.FromArgb(139, 0, 0), Color.FromArgb(128, 0, 128), Color.FromArgb(122, 160, 255) }; List diameterPI = new List() { }; List diameter = new List(){ }; List diameterMax = new List() { }; //保留小数位数 int numDec =Convert.ToInt32( numericNum.Value); for (int i = 0; i < dataList.Count; i++) { int newPo = dataGridView1.Rows.Add(); //序号 dataGridView1.Rows[newPo].Cells[0].Value = (newPo + 1).ToString(); //XY dataGridView1.Rows[newPo].Cells[1].Value ="X:"+ dataList[i][0].ToString()+",Y:"+ dataList[i][1].ToString(); //直径 double w = Convert.ToDouble(dataList[i][6]); double h = Convert.ToDouble(dataList[i][7]) ; double dd = (w + h)*0.5 * unitLength; double area= Convert.ToDouble(dataList[i][4]) * unitLength * unitLength; double r = Math.Sqrt(area / Math.PI) * 2; diameterPI.Add(r); diameter.Add(dd); double maxD = w > h ? w : h; double minD = w < h ? w : h; diameterMax.Add(maxD * unitLength); double circle= Convert.ToDouble(dataList[i][8])*0.001; dataGridView1.Rows[newPo].Cells[2].Value= Math.Round(dd, numDec).ToString(); dataGridView1.Rows[newPo].Cells[3].Value = dataList[i][5]; dataGridView1.Rows[newPo].Cells[4].Value = Math.Round(maxD * unitLength, numDec).ToString(); dataGridView1.Rows[newPo].Cells[5].Value = Math.Round(minD * unitLength, numDec).ToString(); dataGridView1.Rows[newPo].Cells[6].Value = Math.Round(r, numDec).ToString(); } diameterMax.Sort(); MinM = diameterMax[0]; MaxM = diameterMax[diameterMax.Count - 1]; foreach (var item in diameterMax) { MeanM += Math.Round(item, 1); } MeanM = MeanM / diameterMax.Count; dtChart = CreatTable(diameter, diameterPI); CreatChart(dtChart); diameter.Sort(); double total = 0; foreach (var item in diameter) { total += item; } total = total / diameter.Count; double advR = diameterPI.Average(); int ind = 1; int newRow = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow].Cells[1].Value = "平均值"; dataGridView2.Rows[newRow].Cells[2].Value = Math.Round(total, numDec).ToString(); //int newRow1 = dataGridView2.Rows.Add(); //dataGridView2.Rows[newRow1].Cells[0].Value = (ind++).ToString(); //dataGridView2.Rows[newRow1].Cells[1].Value = "最大值"; //dataGridView2.Rows[newRow1].Cells[2].Value = Math.Round(diameter[diameter.Count-1], 2).ToString(); //int newRow2 = dataGridView2.Rows.Add(); //dataGridView2.Rows[newRow2].Cells[0].Value = (ind++).ToString(); //dataGridView2.Rows[newRow2].Cells[1].Value = "最小值"; //dataGridView2.Rows[newRow2].Cells[2].Value = Math.Round(diameter[0], 2).ToString(); int newRow2 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow2].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow2].Cells[1].Value = "颗粒数量"; dataGridView2.Rows[newRow2].Cells[2].Value = diameter.Count.ToString(); int newRow7 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow7].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow7].Cells[1].Value = "拟圆直径"; dataGridView2.Rows[newRow7].Cells[2].Value = Math.Round(advR, numDec).ToString(); int count = diameter.Count; int d1= Convert.ToInt32(count * 0.01); int d5 = Convert.ToInt32(count * 0.05); int d10 = Convert.ToInt32(count * 0.1); int d50 = Convert.ToInt32(count * 0.5); int d90 = Convert.ToInt32(count * 0.9); int d95 = Convert.ToInt32(count * 0.95); int d99 = Convert.ToInt32(count * 0.99); d1 = d1 >= count ? count - 1 : d1; d5 = d5 >= count ? count - 1 : d5; d10 = d10 >= count ? count - 1 : d10; d50 = d50 >= count ? count - 1 : d50; d90 = d90 >= count ? count - 1 : d90; d95 = d95 >= count ? count - 1 : d95; d99 = d99 >= count ? count - 1 : d99; int newRowMin = dataGridView2.Rows.Add(); dataGridView2.Rows[newRowMin].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRowMin].Cells[1].Value = "Dmin"; dataGridView2.Rows[newRowMin].Cells[2].Value = Math.Round(diameter[0], numDec).ToString(); int newRowd1 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRowd1].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRowd1].Cells[1].Value = "D1"; dataGridView2.Rows[newRowd1].Cells[2].Value = Math.Round(diameter[d1], numDec).ToString(); int newRow25 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow25].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow25].Cells[1].Value = "D5"; dataGridView2.Rows[newRow25].Cells[2].Value = Math.Round(diameter[d5], numDec).ToString(); int newRow3 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow3].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow3].Cells[1].Value = "D10"; dataGridView2.Rows[newRow3].Cells[2].Value = Math.Round(diameter[d10], numDec).ToString(); int newRow4 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow4].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow4].Cells[1].Value = "D50"; dataGridView2.Rows[newRow4].Cells[2].Value = Math.Round(diameter[d50], numDec).ToString(); int newRow5 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow5].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow5].Cells[1].Value = "D90"; dataGridView2.Rows[newRow5].Cells[2].Value = Math.Round(diameter[d90], numDec).ToString(); int newRow6 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRow6].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRow6].Cells[1].Value = "D95"; dataGridView2.Rows[newRow6].Cells[2].Value = Math.Round(diameter[d95], numDec).ToString(); int newRowd99 = dataGridView2.Rows.Add(); dataGridView2.Rows[newRowd99].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRowd99].Cells[1].Value = "D99"; dataGridView2.Rows[newRowd99].Cells[2].Value = Math.Round(diameter[d99], numDec).ToString(); int newRowMax = dataGridView2.Rows.Add(); dataGridView2.Rows[newRowMax].Cells[0].Value = (ind++).ToString(); dataGridView2.Rows[newRowMax].Cells[1].Value = "Dmax"; dataGridView2.Rows[newRowMax].Cells[2].Value = Math.Round(diameter[diameter.Count - 1], numDec).ToString(); } /// /// 准备用来处理单个颗粒的选中事件 /// /// /// private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e) { //当点击表头部的列时,e.RowIndex==-1 if (e.RowIndex > -1) { string selectrow = dataGridView1.Rows[e.RowIndex].Cells[3].Value.ToString(); int x = Convert.ToInt32(selectrow); binaryClass.DrwCrystalSelected(x); this.documentWorkspace.Refresh(); } } //外接矩形 double MaxP = 0; double Minp = 0; double MeanP = 0; //拟圆直径 double MaxP2 = 0; double Minp2 = 0; double MeanP2 = 0; private DataTable CreatTable(List diameter, List diameterPI) { diameter.Sort(); double max = diameter[diameter.Count - 1]; double total = max*2; double min = 0; Minp = diameter[0]; MaxP= diameter[diameter.Count - 1]; diameterPI.Sort(); Minp2 = diameterPI[0]; MaxP2 = diameterPI[diameterPI.Count - 1]; foreach (var item in diameter) { MeanP += Math.Round(item, 2) ; } foreach (var item in diameterPI) { MeanP2 += Math.Round(item, 2); } MeanP = MeanP / diameter.Count; MeanP2 = MeanP2 / diameterPI.Count; //int eval =Convert.ToInt32( (max - min) / 20); double eval =0.3; // double eval = max / 15; List vs = new List(); double rightmax = 5.7; for (int i = 0; eval * i < rightmax; i++) { vs.Add(new double[] { eval*i, eval*(i+1) }); } DataTable dt = new DataTable(); dt.Columns.Add("diameter"); dt.Columns.Add("sum"); dt.Columns.Add("sum1"); for (int i = 0; i < vs.Count; i++) { DataRow dr; dr = dt.NewRow(); double low = Math.Round(eval * i, 1); double hight = Math.Round(eval * (i + 1), 1) ; dr["diameter"] =string.Format("{0}", hight) ; var emp = diameter.FindAll(e => e > low && e <= hight); dr["sum"] = emp.Count; var emp1 = diameterPI.FindAll(e => e > low && e <= hight); dr["sum1"] = emp1.Count; dt.Rows.Add(dr); } DataRow drMax; drMax = dt.NewRow(); double lowMax = Math.Round(5.7, 1); drMax["diameter"] =">5.7"; var empMax = diameter.FindAll(e => e > lowMax); drMax["sum"] = empMax.Count; var emp1Max = diameterPI.FindAll(e => e > lowMax); drMax["sum1"] = emp1Max.Count; dt.Rows.Add(drMax); return dt; } private void CreatChart(DataTable dt) { if (dt == null || dt.Rows.Count == 0) { return; } chart1.Series.Clear(); chart1.ChartAreas.Clear(); chart1.Legends.Clear(); //定义一个chart System.Windows.Forms.DataVisualization.Charting.ChartArea chartArea1 = new System.Windows.Forms.DataVisualization.Charting.ChartArea(); //定义一个绘图区域 System.Windows.Forms.DataVisualization.Charting.Series series1 = new System.Windows.Forms.DataVisualization.Charting.Series(); System.Windows.Forms.DataVisualization.Charting.Legend legend1 = new System.Windows.Forms.DataVisualization.Charting.Legend(); //定义一个绘图区域 System.Windows.Forms.DataVisualization.Charting.Series series2 = new System.Windows.Forms.DataVisualization.Charting.Series(); chartArea1.Name = "ChartArea1"; chart1.Series.Add(series1); //chart1.Series.Add(series2); chart1.ChartAreas.Add(chartArea1); chart1.Legends.Add(legend1); series1.ChartType = System.Windows.Forms.DataVisualization.Charting.SeriesChartType.Spline; chart1.Series[0].LegendText = ""; chart1.Series[0].Label = "#VALY"; chart1.Series[0].LabelBackColor = Color.Transparent; chart1.Series[0].ToolTip = "#VALY"; chart1.Series[0]["PointWidth"] = "0.5"; chart1.Series[0].XValueMember = "diameter"; chart1.Series[0].YValueMembers = "sum"; chart1.Series[0].LegendText = "卡规直径"; //chart1.Series[1].LegendText = ""; //chart1.Series[1].Label = "#VALY"; //chart1.Series[1].LabelBackColor = Color.Transparent; //chart1.Series[1].ToolTip = "#VALY"; //chart1.Series[1]["PointWidth"] = "0.5"; //chart1.Series[1].XValueMember = "diameter"; //chart1.Series[1].YValueMembers = "sum1"; //chart1.Series[1].LegendText = "拟圆直径"; chart1.ChartAreas[0].AxisX.Interval = 1; chart1.ChartAreas[0].AxisX.Title = "尺寸("+unStringE+")"; chart1.ChartAreas[0].Axes[0].MajorGrid.Enabled = false; //X轴上网格 chart1.ChartAreas[0].Axes[1].MajorGrid.Enabled = false; //y轴上网格 series1.Color = Color.DarkSeaGreen; series2.Color = Color.PaleTurquoise; chart1.DataSource = dt; chart1.DataBind(); } #region 手动干预 /// /// 修改轮廓 /// /// /// private void btnLunkuo_Click(object sender, EventArgs e) { isLunKuo = true; isAddKong = false; isDelKong = false; operationK = -1; } /// /// 添加孔隙 /// /// /// private void btnAddKong_Click(object sender, EventArgs e) { isLunKuo = false; isAddKong = true; isDelKong = false; operationK = -1; } /// /// 删除孔隙 /// /// /// private void btnDelKong_Click(object sender, EventArgs e) { isLunKuo = false; isAddKong = false; isDelKong = true; operationK = -1; } /// /// 重新统计 /// /// /// private void btnReDrw_Click(object sender, EventArgs e) { if (this.listView1.Items.Count == 0) { return; } double minpoint = Convert.ToDouble(numericUpDown11.Value); if (!ckMin.Checked) minpoint = 0.01; binaryClass.pointsize =minpoint; int border = Convert.ToInt32(numericMax.Value); if (!ckMax.Checked) border = 0; binaryClass.border = border; double HW = Convert.ToDouble(numericHW.Value); if (!ckHW.Checked) HW = 100; binaryClass.HW = HW; double AreaRatio = Convert.ToDouble(numericArea.Value); if (!ckArea.Checked) AreaRatio = 0.01; binaryClass.AreaRatio = AreaRatio; int bottom = Convert.ToInt32(numericBottom.Value); if (!ckBottom.Checked) bottom = 0; binaryClass.borderBottom = bottom; List> CircleDate = binaryClass.ForgetCrystal(minpoint); bindGrid(CircleDate); } /// /// 计算外接矩形 /// private RectangleF CalcOtherRectangle(PointF p1, PointF p2) { RectangleF rectangleF = new RectangleF(); if (p1.X > p2.X) rectangleF.X = p2.X; else rectangleF.X = p1.X; if (p1.Y > p2.Y) rectangleF.Y = p2.Y; else rectangleF.Y = p1.Y; rectangleF.Width = Math.Abs(p2.X - p1.X); rectangleF.Height = Math.Abs(p2.Y - p1.Y); int tempLess = (int)(InvariantData.rectless * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)) * 5; int tempPlus = (int)(InvariantData.rectplus * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)) * 5; return new RectangleF(rectangleF.X - tempLess, rectangleF.Y - tempLess, rectangleF.Width + tempPlus, rectangleF.Height + tempPlus); } /// /// 移动 /// /// /// private void onMouseMove(object sender, MouseEventArgs e) { //if (e.Button == MouseButtons.Left) //{ if (isLunKuo) { int cou = pointList.Count; if (cou > 0) { // 换算后的点 PointF movePoint = this.documentWorkspace.GetScalePoint(e.Location); pointList[cou - 1] = movePoint; } } if (isAddKong && e.Button == MouseButtons.Left) { if (kongLineList.Count > 0) { // 换算后的点 PointF movePoint = this.documentWorkspace.GetScalePoint(e.Location); //kongPointList[kongPointList.Count - 1] = movePoint; kongLineList[kongLineList.Count - 1].Add(movePoint); } } if (isDelKong) { //if (delPointList.Count > 0) //{ // 换算后的点 // PointF movePoint = this.documentWorkspace.GetScalePoint(e.Location); // delPointList[delPointList.Count - 1] = movePoint; //} } if (operationK >= 0 && e.Button == MouseButtons.Left) { PointF movePoint = this.documentWorkspace.GetScalePoint(e.Location); if (operationK == 0) { this.endPoint = movePoint; pointList1[lineCount][1] = endPoint; } else if (operationK == 1 && selected > -1 && canMove) { float dx = movePoint.X - lastPoint.X; float dy = movePoint.Y - lastPoint.Y; float dxTemp = movePoint.X - tempPoint.X; float dyTemp = movePoint.Y - tempPoint.Y; lastPoint.X = movePoint.X; lastPoint.Y = movePoint.Y; if (movePointIndex == -1) { RectangleF rectangleF = new RectangleF(); rectangleF = rectangleFList[selected]; if (rectangleF.Contains(movePoint)) this.documentWorkspace.panel.Cursor = Cursors.SizeAll; rectangleF.X += dx; rectangleF.Y += dy; rectangleFList[selected] = rectangleF; for (int i = 0; i < pointList1[selected].Count(); i++) { if (pointList1[selected][i] == PointF.Empty) continue; pointList1[selected][i].X += dx; pointList1[selected][i].Y += dy; } } else if (movePointIndex == 0) { pointList1[selected][0].X += dx; pointList1[selected][0].Y += dy; rectangleFList[selected] = CalcOtherRectangle(pointList1[selected][0], pointList1[selected][1]); } else if (movePointIndex == 1) { pointList1[selected][1].X += dx; pointList1[selected][1].Y += dy; rectangleFList[selected] = CalcOtherRectangle(pointList1[selected][0], pointList1[selected][1]); } } this.documentWorkspace.Refresh(); } this.documentWorkspace.Refresh(); // } } /// /// 鼠标抬起 /// /// /// private void OnMouseUp(object sender, MouseEventArgs e) { if (e.Button == MouseButtons.Left) { if (operationK == 0) { if (startPoint != null && endPoint != null && startPoint != endPoint) { RectangleF rectangleF = CalcOtherRectangle(pointList1[lineCount][0], pointList1[lineCount][1]); rectangleFList.Add(rectangleF); lineCount++; // AddContentToDataGridView(); } else { if (pointList1.Count > 0) { pointList1.RemoveAt(pointList1.Count - 1); this.documentWorkspace.Refresh(); return; } } this.documentWorkspace.Refresh(); } else if (operationK == 1) { canMove = false; movePointIndex = -1; // RefreshDataGridView1(); } else if (isAddKong) { if (kongLineList[kongLineList.Count - 1].Count > 3) { isAddKong = false; List> CircleDate = binaryClass.DeleteCrystal(delPointList, kongLineList); bindGrid(CircleDate); } else { kongLineList.RemoveAt(kongLineList.Count - 1); } } } if (operationK >= 0 && e.Button == MouseButtons.Left) { PointF downPoint = this.documentWorkspace.GetScalePoint(e.Location); if (operationK == 0) { pointList1[lineCount - 1][1] = downPoint; } else if (operationK == 1) { lastPoint.X = downPoint.X; lastPoint.Y = downPoint.Y; tempPoint.X = downPoint.X; tempPoint.Y = downPoint.Y; for (int i = rectangleFList.Count - 1; i >= 0; i--) { if (rectangleFList[i].Contains(downPoint)) { selected = i; canMove = true; } } if (selected > -1 && pointList1 != null && pointList1.Count > 0) { int tempLess = (int)(InvariantData.rectless * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)) * 5; int tempPlus = (int)(InvariantData.rectplus * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)) * 5; if (new RectangleF(pointList1[selected][0].X - tempLess, pointList1[selected][0].Y - tempLess, tempPlus, tempPlus).Contains(downPoint)) movePointIndex = 0; else if (new RectangleF(pointList1[selected][1].X - tempLess, pointList1[selected][1].Y - tempLess, tempPlus, tempPlus).Contains(downPoint)) movePointIndex = 1; else movePointIndex = -1; this.documentWorkspace.Refresh(); } if (canMove) return; selected = -1; } } } /// /// 鼠标按下 /// /// /// private void OnMouseDown(object sender, MouseEventArgs e) { //禁止画黑色矩形 this.documentWorkspace.DrawRectangleFlag = false; PointF downPoint = this.documentWorkspace.GetScalePoint(e.Location); if (operationK >= 0 && e.Button == MouseButtons.Left) { if (operationK == 0) { startPoint = endPoint = downPoint; nowLine = new PointF[4]; nowLine[0] = startPoint; nowLine[1] = endPoint; pointList1.Add(nowLine); } else if (operationK == 1) { lastPoint.X = downPoint.X; lastPoint.Y = downPoint.Y; tempPoint.X = downPoint.X; tempPoint.Y = downPoint.Y; for (int i = rectangleFList.Count - 1; i >= 0; i--) { if (rectangleFList[i].Contains(downPoint)) { selected = i; canMove = true; } } if (selected > -1 && pointList1 != null && pointList1.Count > 0) { int tempLess = (int)(InvariantData.rectless * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)) * 5; int tempPlus = (int)(InvariantData.rectplus * (this.documentWorkspace.ScaleFactor.Ratio < 1 ? 1 / this.documentWorkspace.ScaleFactor.Ratio : 1)) * 5; if (new RectangleF(pointList1[selected][0].X - tempLess, pointList1[selected][0].Y - tempLess, tempPlus, tempPlus).Contains(downPoint)) movePointIndex = 0; else if (new RectangleF(pointList1[selected][1].X - tempLess, pointList1[selected][1].Y - tempLess, tempPlus, tempPlus).Contains(downPoint)) movePointIndex = 1; else movePointIndex = -1; this.documentWorkspace.Refresh(); } if (canMove) return; selected = -1; } } else if (e.Button == MouseButtons.Left) { if (isLunKuo) { if (pointList.Count == 0) { pointList.Add(downPoint); pointList.Add(downPoint); } else { pointList.Add(downPoint); } } if (isAddKong) { List pl = new List(); pl.Add(downPoint); kongLineList.Add(pl); //if (kongPointList.Count == 0) //{ // kongPointList.Add(downPoint); // kongPointList.Add(downPoint); //} //else //{ // kongPointList.Add(downPoint); //} } if (isDelKong) { delPointList.Add(downPoint); List> CircleDate = binaryClass.DeleteCrystal( delPointList, kongLineList); bindGrid(CircleDate); } } if (e.Button == MouseButtons.Right) { if (isLunKuo) { if (pointList.Count > 2) { pointList.RemoveAt(pointList.Count - 1); List pointFs = new List(pointList.ToArray()); lineList.Add(pointFs); } pointList.Clear(); } if (isAddKong) { if (kongPointList.Count > 2) { kongPointList.RemoveAt(kongPointList.Count - 1); List pointFs = new List(kongPointList.ToArray()); kongLineList.Add(pointFs); List> CircleDate = binaryClass.DeleteCrystal(delPointList, kongLineList); bindGrid(CircleDate); } kongPointList.Clear(); } if (isDelKong) { //if (delPointList.Count > 2) //{ // delPointList.RemoveAt(delPointList.Count - 1); // List pointFs = new List(delPointList.ToArray()); // delLineList.Add(pointFs); //} //delPointList.Clear(); } isLunKuo = false; isAddKong = false; isDelKong = false; } } /// /// Ctrl+z /// private void OnKeyDown(object sender, KeyEventArgs e) { if (e.Control && e.KeyCode == Keys.Z) { if (isLunKuo) { int cou = pointList.Count; if (cou > 1) { if (cou == 2) { pointList.Clear(); } else { pointList.RemoveAt(cou - 1); } } else if (lineList.Count > 0) { pointList = lineList[lineList.Count - 1]; lineList.RemoveAt(lineList.Count - 1); pointList.RemoveAt(pointList.Count - 1); } } if (isAddKong) { if (kongLineList.Count > 0) { kongLineList.RemoveAt(kongLineList.Count - 1); List> CircleDate = binaryClass.DeleteCrystal(delPointList, kongLineList); bindGrid(CircleDate); } } if (isDelKong) { int cou = delPointList.Count; if (cou > 0) { delPointList.RemoveAt(cou - 1); List> CircleDate = binaryClass.DeleteCrystal(delPointList, kongLineList); bindGrid(CircleDate); } } this.documentWorkspace.Refresh(); } } #endregion /// /// 统计导出 /// /// /// private void button14_Click(object sender, EventArgs e) { if (this.listView1.Items.Count == 0) { return; } //保留小数位数 int numDec = Convert.ToInt32(numericNum.Value); string name = this.listView1.FocusedItem.Name.Substring(0, this.listView1.FocusedItem.Name.LastIndexOf('.')) ; SaveFileDialog exe = new SaveFileDialog(); exe.Filter = "Execl files (*.xlsx)|*.xlsx"; exe.FilterIndex = 0; exe.RestoreDirectory = true; //exe.CreatePrompt = true; exe.Title = "Export Excel File"; // exe.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory); exe.FileName = name + "-"; String str = System.Configuration.ConfigurationManager.AppSettings["FolderSelectedPath"]; DialogResult dr = exe.ShowDialog(); if (dr != DialogResult.OK) { return; } DataTable dtb = new DataTable(); dtb.Columns.Add("序号"); dtb.Columns.Add("位置"); dtb.Columns.Add("卡规直径/"+ unString); dtb.Columns.Add("长径/" + unString); dtb.Columns.Add("短径/" + unString); dtb.Columns.Add("拟圆直径/" + unString); List diameter = new List() { }; List diameterPi = new List() { }; int inde = 1; int current = 1; foreach (ListViewItem item in listView1.Items) { binaryClass.tipString = "正在处理" + (current++).ToString() + "/" + listView1.Items.Count.ToString() + "," + item.Name + "。"; listView1.FocusedItem = item; this.listView1.FocusedItem.Selected = true; for (int r = 0; r < this.dataGridView1.Rows.Count; r++) { DataRow dataRow = dtb.NewRow(); dataRow[0] = (inde++).ToString(); dataRow[1] = dataGridView1.Rows[r].Cells[1].Value.ToString(); dataRow[2] = dataGridView1.Rows[r].Cells[2].Value.ToString(); dataRow[3] = dataGridView1.Rows[r].Cells[4].Value.ToString(); dataRow[4] = dataGridView1.Rows[r].Cells[5].Value.ToString(); dataRow[5] = dataGridView1.Rows[r].Cells[6].Value.ToString(); dtb.Rows.Add(dataRow); diameter.Add(Convert.ToDouble(dataRow[2])); diameterPi.Add(Convert.ToDouble(dataRow[5])); } } DataTable dt = new DataTable(); dt = CreatTable(diameter, diameter); CreatChart(dt); #region 统计表 int count = diameter.Count; if (count == 0) { MessageBox.Show("数据为空,请设置好筛选条件!"); return; } diameter.Sort(); diameterPi.Sort(); List valueList = new List(); int d1 = Convert.ToInt32(count * 0.01); int d5 = Convert.ToInt32(count * 0.05); int d10 = Convert.ToInt32(count * 0.1); int d50 = Convert.ToInt32(count * 0.5); int d90 = Convert.ToInt32(count * 0.9); int d95 = Convert.ToInt32(count * 0.95); int d99 = Convert.ToInt32(count * 0.99); d1 = d1 >= count ? count - 1 : d1; d5 = d5 >= count ? count - 1 : d5; d10 = d10 >= count ? count - 1 : d10; d50 = d50 >= count ? count - 1 : d50; d90 = d90 >= count ? count - 1 : d90; d95 = d95 >= count ? count - 1 : d95; d99 = d99 >= count ? count - 1 : d99; double[] values = new double[] { diameter.Average(), diameter.Count, diameterPi.Average(), diameter.Min(), diameter[d1], diameter[d5], diameter[d10], diameter[d50], diameter[d90], diameter[d95], diameter[d99], diameter.Max() }; string[] names = new string[] { "卡规直径", "颗粒数量", "拟圆直径", "Dmin", "D1", "D5", "D10", "D50", "D90", "D95", "D99", "Dmax"}; #endregion #region 前4行批号加统计 DataTable dtb0 = new DataTable(); dtb0.Columns.Add("批号"); dtb0.Columns.Add(name); DataRow dataRuler = dtb0.NewRow(); dataRuler[0] = "标尺"; dataRuler[1] = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].xmlSaveModel.ruler_name; dtb0.Rows.Add(dataRuler); if (ckMin.Checked) { DataRow dataMin = dtb0.NewRow(); dataMin[0] = "最小尺寸"; dataMin[1] = numericUpDown11.Value.ToString() + unString; dtb0.Rows.Add(dataMin); } if (ckMax.Checked) { DataRow dataBorder = dtb0.NewRow(); dataBorder[0] = "边界尺寸"; dataBorder[1] = numericMax.Value.ToString() + "像素"; dtb0.Rows.Add(dataBorder); } if (ckHW.Checked) { DataRow dataHw = dtb0.NewRow(); dataHw[0] = "长宽比例"; dataHw[1] = numericHW.Value.ToString(); dtb0.Rows.Add(dataHw); } if (ckArea.Checked) { DataRow dataArea = dtb0.NewRow(); dataArea[0] = "面积率"; dataArea[1] = numericArea.Value.ToString(); dtb0.Rows.Add(dataArea); } DataRow dataNone = dtb0.NewRow(); dataNone[0] = ""; dataNone[1] = ""; dtb0.Rows.Add(dataNone); DataTable dtb1 = new DataTable(); dtb1.Columns.Add("序号"); for (int i = 1; i < 13; i++) { dtb1.Columns.Add(i.ToString()); } DataRow dataRowName = dtb1.NewRow(); dataRowName[0] = "名称"; DataRow dataRowValue = dtb1.NewRow(); dataRowValue[0] = "值/"+ unString; DataRow dataRowNone = dtb1.NewRow(); dataRowNone[0] = ""; for (int r = 0; r < this.dataGridView2.Rows.Count; r++) { dataRowName[r + 1] = names[r]; dataRowValue[r + 1] = Math.Round(values[r], numDec).ToString(); dataRowNone[r + 1] = ""; } dtb1.Rows.Add(dataRowName); dtb1.Rows.Add(dataRowValue); dtb1.Rows.Add(dataRowNone); #endregion #region 分布统计 DataTable dtb2 = new DataTable(); dtb2.Columns.Add("序号"); dtb2.Columns.Add("颗粒尺寸x"); dtb2.Columns.Add("数量"); double eval = 0.3; for (int i = 0; i < dt.Rows.Count; i++) { DataRow dtChartRow = dtb2.NewRow(); dtChartRow[0] = (i + 1).ToString(); double low = eval * i; double high = eval * i + eval; if (i == dt.Rows.Count - 1) { dtChartRow[1] = ("x>5.7"); } else { dtChartRow[1] = string.Format("{0}<x≤{1}", low, high); } dtChartRow[2] = (dt.Rows[i]["sum"]).ToString(); dtb2.Rows.Add(dtChartRow); } #endregion int index = exe.FileName.LastIndexOf('\\'); string GR_Path = exe.FileName.Remove(index) + "\\" + name + ".jpg"; chart1.SaveImage(GR_Path, System.Windows.Forms.DataVisualization.Charting.ChartImageFormat.Jpeg); List list = new List(); list.Add(dtb0); list.Add(dtb1); list.Add(dtb2); list.Add(dtb); List pics = new List() { GR_Path + ",400,200," + chart1.Width + "," + chart1.Height }; this.appWorkspace.ExportDataToExcelWithProgress(list, exe.FileName, true, false, true, null, null, pics); } /// /// 批量导出 /// /// /// private void btnAll_Click(object sender, EventArgs e) { if (this.listView1.Items.Count == 0) { return; } string name = this.listView1.FocusedItem.Name.Substring(0, this.listView1.FocusedItem.Name.LastIndexOf('.')); SaveFileDialog exe = new SaveFileDialog(); exe.Filter = "Execl files (*.xlsx)|*.xlsx"; exe.FilterIndex = 0; exe.RestoreDirectory = true; //exe.CreatePrompt = true; exe.Title = "Export Excel File"; // exe.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory); exe.FileName = name + "-"; String str = System.Configuration.ConfigurationManager.AppSettings["FolderSelectedPath"]; DialogResult dr = exe.ShowDialog(); if (dr != DialogResult.OK) { return; } DataTable totla = new DataTable(); totla.Columns.Add("序号"); for (int i = 1; i < 13; i++) { totla.Columns.Add(i.ToString()); } DataRow totlaRowName = totla.NewRow(); totlaRowName[0] = "名称"; for (int r = 0; r < this.dataGridView2.Rows.Count; r++) { totlaRowName[r + 1] = dataGridView2.Rows[r].Cells[1].Value.ToString(); } totla.Rows.Add(totlaRowName); List> datasMore = new List>(); List> bitmapListMore = new List>(); int current = 1; foreach (ListViewItem item in listView1.Items) { binaryClass.tipString = "正在处理" + (current++).ToString() + "/" + listView1.Items.Count.ToString() + "," + item.Name + "。"; listView1.FocusedItem = item; this.listView1.FocusedItem.Selected = true; name = this.listView1.FocusedItem.Name.Substring(0, this.listView1.FocusedItem.Name.LastIndexOf('.')); #region 颗粒信息 DataTable dtb = new DataTable(); dtb.Columns.Add("序号"); dtb.Columns.Add("位置"); dtb.Columns.Add("卡规直径/"+unString); dtb.Columns.Add("长径/" + unString); dtb.Columns.Add("短径/" + unString); dtb.Columns.Add("拟圆直径/" + unString); for (int r = 0; r < this.dataGridView1.Rows.Count; r++) { DataRow dataRow = dtb.NewRow(); dataRow[0] = dataGridView1.Rows[r].Cells[0].Value.ToString(); dataRow[1] = dataGridView1.Rows[r].Cells[1].Value.ToString(); dataRow[2] = dataGridView1.Rows[r].Cells[2].Value.ToString(); dataRow[3] = dataGridView1.Rows[r].Cells[4].Value.ToString(); dataRow[4] = dataGridView1.Rows[r].Cells[5].Value.ToString(); dataRow[5] = dataGridView1.Rows[r].Cells[6].Value.ToString(); dtb.Rows.Add(dataRow); } #endregion #region 前4行批号加统计 DataRow totlaRowValue = totla.NewRow();//统计显示 DataTable dtb0 = new DataTable(); dtb0.Columns.Add("批号"); dtb0.Columns.Add(name); DataRow dataRuler = dtb0.NewRow(); dataRuler[0] = "标尺"; dataRuler[1] = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].xmlSaveModel.ruler_name; dtb0.Rows.Add(dataRuler); if (ckMin.Checked) { DataRow dataMin = dtb0.NewRow(); dataMin[0] = "最小尺寸"; dataMin[1] = numericUpDown11.Value.ToString() + unString; dtb0.Rows.Add(dataMin); } if (ckMax.Checked) { DataRow dataBorder = dtb0.NewRow(); dataBorder[0] = "边界尺寸"; dataBorder[1] = numericMax.Value.ToString() + "像素"; dtb0.Rows.Add(dataBorder); } if (ckHW.Checked) { DataRow dataHw = dtb0.NewRow(); dataHw[0] = "长宽比例"; dataHw[1] = numericHW.Value.ToString(); dtb0.Rows.Add(dataHw); } if (ckArea.Checked) { DataRow dataArea = dtb0.NewRow(); dataArea[0] = "面积率"; dataArea[1] = numericArea.Value.ToString(); dtb0.Rows.Add(dataArea); } DataRow dataNone = dtb0.NewRow(); dataNone[0] = ""; dataNone[1] = ""; dtb0.Rows.Add(dataNone); totlaRowValue[0] = name; DataTable dtb1 = new DataTable(); dtb1.Columns.Add("序号"); for (int i = 1; i < 13; i++) { dtb1.Columns.Add(i.ToString()); } DataRow dataRowName = dtb1.NewRow(); dataRowName[0] = "名称"; DataRow dataRowValue = dtb1.NewRow(); dataRowValue[0] = "值/" + unString; DataRow dataRowNone = dtb1.NewRow(); dataRowNone[0] = ""; for (int r = 0; r < this.dataGridView2.Rows.Count; r++) { dataRowName[r + 1] = dataGridView2.Rows[r].Cells[1].Value.ToString(); dataRowValue[r + 1] = dataGridView2.Rows[r].Cells[2].Value.ToString(); totlaRowValue[r + 1] = dataGridView2.Rows[r].Cells[2].Value.ToString(); dataRowNone[r + 1] = ""; } dtb1.Rows.Add(dataRowName); dtb1.Rows.Add(dataRowValue); dtb1.Rows.Add(dataRowNone); totla.Rows.Add(totlaRowValue); #endregion #region 分布统计 DataTable dtb2 = new DataTable(); dtb2.Columns.Add("序号"); dtb2.Columns.Add("颗粒尺寸x"); dtb2.Columns.Add("数量"); double eval = 0.3; for (int i = 0; i < dtChart.Rows.Count; i++) { DataRow dtChartRow = dtb2.NewRow(); dtChartRow[0] = (i + 1).ToString(); double low = eval * i; double high = eval * i + eval; if (i == dtChart.Rows.Count - 1) { dtChartRow[1] = ("x>5.7"); } else { dtChartRow[1] = string.Format("{0}<x≤{1}", low, high); } dtChartRow[2] = (dtChart.Rows[i]["sum"]).ToString(); dtb2.Rows.Add(dtChartRow); } #endregion #region 图片导出 int index = exe.FileName.LastIndexOf('\\'); string GR_Path = exe.FileName.Remove(index) + "\\" + name + "-.jpg"; chart1.SaveImage(GR_Path, System.Windows.Forms.DataVisualization.Charting.ChartImageFormat.Jpeg); //保存处理后的图片 double pantographRatio = (double)this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GetRulerMultiple(MeasurementUnit.Micron);//标尺*放大倍数 List tempBit = new List(); Bitmap originalBit = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].CompositionSurface.CreateAliasedBitmap(); originalBit.Tag = pantographRatio; tempBit.Add(originalBit); Bitmap processedBit = OpenCvSharp.Extensions.BitmapConverter.ToBitmap(this.documentWorkspace.PhaseModels[0].mat); Bitmap newBit = originalBit.Clone(new Rectangle(0, 0, originalBit.Width, originalBit.Height), originalBit.PixelFormat); Graphics graphics = Graphics.FromImage(newBit); graphics.DrawImage(processedBit, new PointF(0, 0)); Draw(graphics); newBit.Tag = pantographRatio; tempBit.Add(newBit); string GR_Path1 = exe.FileName.Remove(index) + "\\" + name + "-1.jpg"; newBit.Save(GR_Path1); #endregion List list = new List(); list.Add(dtb0); list.Add(dtb1); list.Add(dtb2); list.Add(dtb); List pics = new List() { GR_Path + ",150,150," + chart1.Width / 3 + "," + chart1.Height / 3, GR_Path1 + ",10,450," + newBit.Width / 3 + "," + newBit.Height / 3 }; datasMore.Add(list); bitmapListMore.Add(pics); } List listmore = new List() { totla }; datasMore.Insert(0, listmore); this.appWorkspace.ExportDataToExcelWithProgressForCrystal(datasMore, bitmapListMore, exe.FileName, null); } /// /// 不可点击空白区域 /// /// /// private void listView1_MouseUp(object sender, MouseEventArgs e) { if (e.Button == MouseButtons.Left) { if (listView1.SelectedItems.Count > 0) { } else if (listView1.SelectedItems.Count <= 0)//点击空白区 { if (this.listView1.FocusedItem != null) { ListViewItem item = this.listView1.GetItemAt(e.X, e.Y); if (item == null) { this.listView1.FocusedItem.Selected = true; } } } } } /// /// 导出 /// /// /// private void button13_Click(object sender, EventArgs e) { if (this.listView1.Items.Count == 0) { return; } string name = this.listView1.FocusedItem.Name.Substring(0, this.listView1.FocusedItem.Name.LastIndexOf('.')); SaveFileDialog exe = new SaveFileDialog(); exe.Filter = "Execl files (*.xlsx)|*.xlsx"; exe.FilterIndex = 0; exe.RestoreDirectory = true; //exe.CreatePrompt = true; exe.Title = "Export Excel File"; // exe.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory); exe.FileName = name+"-"; String str = System.Configuration.ConfigurationManager.AppSettings["FolderSelectedPath"]; DialogResult dr = exe.ShowDialog(); if (dr != DialogResult.OK) { return; } #region 颗粒信息 DataTable dtb = new DataTable(); dtb.Columns.Add("序号"); dtb.Columns.Add("位置"); dtb.Columns.Add("卡规直径/" + unString); dtb.Columns.Add("长径/" + unString); dtb.Columns.Add("短径/" + unString); dtb.Columns.Add("拟圆直径/" + unString); for (int r = 0; r < this.dataGridView1.Rows.Count; r++) { DataRow dataRow = dtb.NewRow(); dataRow[0] = dataGridView1.Rows[r].Cells[0].Value.ToString(); dataRow[1] = dataGridView1.Rows[r].Cells[1].Value.ToString(); dataRow[2] = dataGridView1.Rows[r].Cells[2].Value.ToString(); dataRow[3] = dataGridView1.Rows[r].Cells[4].Value.ToString(); dataRow[4] = dataGridView1.Rows[r].Cells[5].Value.ToString(); dataRow[5] = dataGridView1.Rows[r].Cells[6].Value.ToString(); dtb.Rows.Add(dataRow); } #endregion #region 前4行批号加统计 DataTable dtb0 = new DataTable(); dtb0.Columns.Add("批号"); dtb0.Columns.Add(name); DataRow dataRuler = dtb0.NewRow(); dataRuler[0] = "标尺"; dataRuler[1] = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].xmlSaveModel.ruler_name; dtb0.Rows.Add(dataRuler); if (ckMin.Checked) { DataRow dataMin = dtb0.NewRow(); dataMin[0] = "最小尺寸"; dataMin[1] = numericUpDown11.Value.ToString() + unString; dtb0.Rows.Add(dataMin); } if (ckMax.Checked) { DataRow dataBorder = dtb0.NewRow(); dataBorder[0] = "边界尺寸"; dataBorder[1] = numericMax.Value.ToString() + "像素"; dtb0.Rows.Add(dataBorder); } if (ckHW.Checked) { DataRow dataHw = dtb0.NewRow(); dataHw[0] = "长宽比例"; dataHw[1] = numericHW.Value.ToString(); dtb0.Rows.Add(dataHw); } if (ckArea.Checked) { DataRow dataArea = dtb0.NewRow(); dataArea[0] = "面积率"; dataArea[1] = numericArea.Value.ToString(); dtb0.Rows.Add(dataArea); } DataRow dataNone = dtb0.NewRow(); dataNone[0] = ""; dataNone[1] = ""; dtb0.Rows.Add(dataNone); DataTable dtb1 = new DataTable(); dtb1.Columns.Add("序号"); for (int i = 1; i < 13; i++) { dtb1.Columns.Add(i.ToString()); } DataRow dataRowName = dtb1.NewRow(); dataRowName[0] = "名称"; DataRow dataRowValue = dtb1.NewRow(); dataRowValue[0] = "值/" + unString; DataRow dataRowNone = dtb1.NewRow(); dataRowNone[0] = ""; for (int r = 0; r < this.dataGridView2.Rows.Count; r++) { dataRowName[r+1]= dataGridView2.Rows[r].Cells[1].Value.ToString(); dataRowValue[r + 1] = dataGridView2.Rows[r].Cells[2].Value.ToString(); dataRowNone[r + 1] = ""; } dtb1.Rows.Add(dataRowName); dtb1.Rows.Add(dataRowValue); dtb1.Rows.Add(dataRowNone); #endregion #region 分布统计 DataTable dtb2 = new DataTable(); dtb2.Columns.Add("序号"); dtb2.Columns.Add("颗粒尺寸x"); dtb2.Columns.Add("数量"); double eval = 0.3; for (int i = 0; i < dtChart.Rows.Count; i++) { DataRow dtChartRow = dtb2.NewRow(); dtChartRow[0] = (i + 1).ToString(); double low = eval * i; double high = eval * i + eval; if (i == dtChart.Rows.Count - 1) { dtChartRow[1] = ("x>5.7"); } else { dtChartRow[1] = string.Format("{0}<x≤{1}", low, high); } dtChartRow[2] = (dtChart.Rows[i]["sum"]).ToString(); dtb2.Rows.Add(dtChartRow); } #endregion #region 图片导出 int index = exe.FileName.LastIndexOf('\\'); string GR_Path = exe.FileName.Remove(index)+"\\"+ name + "-.jpg"; chart1.SaveImage(GR_Path, System.Windows.Forms.DataVisualization.Charting.ChartImageFormat.Jpeg); //保存处理后的图片 double pantographRatio = (double)this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GetRulerMultiple(MeasurementUnit.Micron);//标尺*放大倍数 List tempBit = new List(); Bitmap originalBit = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].CompositionSurface.CreateAliasedBitmap(); originalBit.Tag = pantographRatio; tempBit.Add(originalBit); Bitmap processedBit = OpenCvSharp.Extensions.BitmapConverter.ToBitmap(this.documentWorkspace.PhaseModels[0].mat); Bitmap newBit = originalBit.Clone(new Rectangle(0, 0, originalBit.Width, originalBit.Height), originalBit.PixelFormat); Graphics graphics = Graphics.FromImage(newBit); graphics.DrawImage(processedBit, new PointF(0, 0)); Draw(graphics); newBit.Tag = pantographRatio; tempBit.Add(newBit); string GR_Path1 = exe.FileName.Remove(index) + "\\" + name + "-1.jpg"; newBit.Save(GR_Path1); #endregion List list = new List(); list.Add(dtb0); list.Add(dtb1); list.Add(dtb2); list.Add(dtb); List pics = new List() { GR_Path + ",150,150," + chart1.Width/3 + "," + chart1.Height/3, GR_Path1 + ",10,450," + newBit.Width/3 + "," + newBit.Height/3 }; this.appWorkspace.ExportDataToExcelWithProgress(list, exe.FileName, true, false, true, null, null,pics); } #region 辅助测量 /// /// 添加测量线 /// /// /// private void btnAddCeliang_Click(object sender, EventArgs e) { operationK = 0; selected = -1; this.documentWorkspace.Refresh(); } /// /// 选择测量线 /// /// /// private void btnSelCeliang_Click(object sender, EventArgs e) { operationK = 1; } /// /// 删除测量线 /// /// /// private void btnDelCeliang_Click(object sender, EventArgs e) { if (selected > -1) { DialogResult dr = MessageBox.Show(PdnResources.GetString("Menu.Areyousuretodmeasurementline.text") + "?", PdnResources.GetString("Menu.alert.text"), MessageBoxButtons.OKCancel, MessageBoxIcon.Question); if (dr == DialogResult.OK) { this.pointList1.Remove(this.pointList1[selected]); this.rectangleFList.Remove(this.rectangleFList[selected]); selected = -1; lineCount--; this.documentWorkspace.Refresh(); } } else MessageBox.Show("请先选择测量线"); } /// /// 添加测量线按钮失去焦点 /// /// /// private void btnAddCeliang_LostFocus(object sender, EventArgs e) { operationK = -1; selected = -1; this.documentWorkspace.Refresh(); } #endregion #region 内部类 internal class LocalListViewItem { public DocumentWorkspace Value { get; } public string Display { get; } public LocalListViewItem(DocumentWorkspace Value, string Display) { this.Value = Value; this.Display = Display; } } internal class DocumentItem { public Bitmap bitmap; public GraphicsList graphicsList; public List phaseModels; //public AnalysisResult analysisResult; public DocumentItem(Bitmap bitmap, GraphicsList graphicsList, List phaseModels) { this.bitmap = bitmap; this.graphicsList = graphicsList; this.phaseModels = phaseModels; } } #endregion #endregion } }