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
}
}