1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392 |
- 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;
- /// <summary>
- /// 选中图片的bitmap
- /// </summary>
- private Bitmap bitmap;
- /// <summary>
- /// 存在视场标记
- /// </summary>
- private bool existViewFlag = false;
- private int changeCount;
- /// <summary>
- /// 主空间
- /// </summary>
- private AppWorkspace appWorkspace;
- /// <summary>
- /// 图像面板
- /// </summary>
- private DocumentWorkspaceWindow documentWorkspace;
- /// <summary>
- /// 公共控件
- /// </summary>
- private GeneralAnalysisCommonControlButtons commonControlButtons;
- /// <summary>
- /// 图片测量记录
- /// </summary>
- private List<DataTable> pictureDataTables = new List<DataTable>();
- /// <summary>
- /// 网格Xml
- /// </summary>
- private GrainSizePointCountingMethodModel grainSizePointCountingMethodModel;
- /// <summary>
- /// 数据变化
- /// </summary>
- private bool saveSuccess = false;
- private BinaryControlSmaller bc;
- #endregion 属性
- #region 数据属性
- /// <summary>
- /// 折线点的集合
- /// </summary>
- public List<System.Drawing.Point> pointArray = new List<System.Drawing.Point>();
- /// <summary>
- /// 存储所有轮廓线的点集合
- /// </summary>
- private List<PointF> pointList = new List<PointF>();
- /// <summary>
- /// 存储所有轮廓线集合
- /// </summary>
- private List<List<PointF>> lineList = new List<List<PointF>>();
- /// <summary>
- /// 存储所有增加颗粒的点集合
- /// </summary>
- private List<PointF> kongPointList = new List<PointF>();
- /// <summary>
- /// 存储所有孔隙线集合
- /// </summary>
- private List<List<PointF>> kongLineList = new List<List<PointF>>();
- /// <summary>
- /// 存储所有删除孔隙线的点集合
- /// </summary>
- private List<PointF> delPointList = new List<PointF>();
- /// <summary>
- /// 存储所有删除孔隙线集合
- /// </summary>
- private List<List<PointF>> delLineList = new List<List<PointF>>();
- //轮廓修改状态
- bool isLunKuo = false;
- //添加孔隙状态
- bool isAddKong = false;
- //删除孔隙状态
- bool isDelKong = false;
- /// <summary>
- /// 0:添加 1:选择 2:删除
- /// </summary>
- private int operationK = -1;
- /// <summary>
- /// 被选择的线
- /// </summary>
- private int selected = -1;
- /// <summary>
- /// 起止点
- /// </summary>
- private System.Drawing.PointF startPoint, endPoint;
- /// <summary>
- /// 存储所有线的点集合
- /// </summary>
- private List<PointF[]> pointList1 = new List<PointF[]>();
- /// <summary>
- /// 存储当前线的点集合
- /// </summary>
- private PointF[] nowLine;
- /// <summary>
- /// 辅助计算偏移量-移动线两端的点
- /// </summary>
- private PointF lastPoint = new PointF(0, 0);
- /// <summary>
- /// 辅助计算偏移量-移动线中间的点
- /// </summary>
- private PointF tempPoint = new PointF(0, 0);
- /// <summary>
- /// 判断图形是否可移动
- /// </summary>
- private bool canMove = false;
- /// <summary>
- /// 测量点
- /// </summary>
- public List<RectangleF> rectangleFList = new List<RectangleF>();
- /// <summary>
- /// 移动线上的哪一个点
- /// </summary>
- private int movePointIndex = -1;
- /// <summary>
- /// 线的总数
- /// </summary>
- private int lineCount = 0;
- /// <summary>
- /// 单位标尺
- /// </summary>
- private double unitLength = 1;
- string unString = "纳米";
- string unStringE = "nm";
- #endregion
- System.Windows.Forms.DataVisualization.Charting.Chart chart1 = new System.Windows.Forms.DataVisualization.Charting.Chart();
- /// <summary>
- ///
- /// </summary>
- /// <param name="appWorkspace"></param>
- 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<int> paramsList = new List<int>() {
- 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();
- }
- /// <summary>
- /// 添加参数改变的监听
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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;
- }
- /// <summary>
- /// 显示原图/原图+二值图
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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();
- }
- /// <summary>
- /// 显示原图/原图+二值图
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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
- /// <summary>
- /// 初始化画面数据
- /// </summary>
- private void InitGridStyle()
- {
- grainSizePointCountingMethodModel = XmlSerializeHelper.DESerializer<GrainSizePointCountingMethodModel>(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)
- {
- }
- }
- }
- /// <summary>
- /// 初始化图片列表数据
- /// </summary>
- 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++;
- }
- /// <summary>
- /// 切换图片
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void listView1_SelectedIndexChanged(object sender, EventArgs e)
- {
-
- SelectedIndexChanged();
- }
- /// <summary>
- /// 显示矩形测距
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void IsDisChanged(object sender, EventArgs e)
- {
- binaryClass.isDis = ckDis.Checked;
- binaryClass.isJu = ckJu.Checked;
- btnReDrw_Click(null, null);
- // SelectedIndexChanged();
- }
- List<PointF> list = new List<PointF>();
- /// <summary>
- /// 切换图片
- /// </summary>
- 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();
- }
- /// <summary>
- /// 画布绘制
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<List<int>> CircleDate = bc.data;
- bindGrid(CircleDate);
- }
- }
- // <summary>
- /// 存储字号与颜色字典
- /// </summary>
- public Dictionary<string, Color> colourFont = new Dictionary<string, Color>() { { "20", Color.White } };
- /// <summary>
- /// 绘制
- /// </summary>
- 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<List<int>> dataList)
- {
- if (dataList.Count < 1)
- {
- return;
- }
- chart1.Visible = true;
- List<int> CircleDate = dataList[0];
-
- dataGridView1.Rows.Clear();
- dataGridView2.Rows.Clear();
- chart1.Series.Clear();
- chart1.ChartAreas.Clear();
- List<Color> colorList = new List<Color>() { 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<double> diameterPI = new List<double>() { };
- List<double> diameter = new List<double>(){ };
- List<double> diameterMax = new List<double>() { };
- //保留小数位数
- 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();
- }
- /// <summary>
- /// 准备用来处理单个颗粒的选中事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<double> diameter, List<double> 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<double[]> vs = new List<double[]>();
- 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 手动干预
- /// <summary>
- /// 修改轮廓
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnLunkuo_Click(object sender, EventArgs e)
- {
- isLunKuo = true;
- isAddKong = false;
- isDelKong = false;
- operationK = -1;
- }
- /// <summary>
- /// 添加孔隙
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnAddKong_Click(object sender, EventArgs e)
- {
- isLunKuo = false;
- isAddKong = true;
- isDelKong = false;
- operationK = -1;
- }
- /// <summary>
- /// 删除孔隙
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnDelKong_Click(object sender, EventArgs e)
- {
- isLunKuo = false;
- isAddKong = false;
- isDelKong = true;
- operationK = -1;
- }
- /// <summary>
- /// 重新统计
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<List<int>> CircleDate = binaryClass.ForgetCrystal(minpoint);
- bindGrid(CircleDate);
- }
- /// <summary>
- /// 计算外接矩形
- /// </summary>
- 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);
- }
- /// <summary>
- /// 移动
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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();
- // }
- }
- /// <summary>
- /// 鼠标抬起
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<List<int>> 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;
- }
- }
-
- }
- /// <summary>
- /// 鼠标按下
- /// </summary>
- /// <param name="drawArea"></param>
- /// <param name="e"></param>
- 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<PointF> pl = new List<PointF>();
- 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<List<int>> CircleDate = binaryClass.DeleteCrystal( delPointList, kongLineList);
- bindGrid(CircleDate);
- }
- }
- if (e.Button == MouseButtons.Right)
- {
- if (isLunKuo)
- {
- if (pointList.Count > 2)
- {
- pointList.RemoveAt(pointList.Count - 1);
- List<PointF> pointFs = new List<PointF>(pointList.ToArray());
- lineList.Add(pointFs);
- }
- pointList.Clear();
- }
- if (isAddKong)
- {
- if (kongPointList.Count > 2)
- {
- kongPointList.RemoveAt(kongPointList.Count - 1);
- List<PointF> pointFs = new List<PointF>(kongPointList.ToArray());
- kongLineList.Add(pointFs);
- List<List<int>> CircleDate = binaryClass.DeleteCrystal(delPointList, kongLineList);
- bindGrid(CircleDate);
- }
- kongPointList.Clear();
- }
- if (isDelKong)
- {
- //if (delPointList.Count > 2)
- //{
- // delPointList.RemoveAt(delPointList.Count - 1);
- // List<PointF> pointFs = new List<PointF>(delPointList.ToArray());
- // delLineList.Add(pointFs);
- //}
- //delPointList.Clear();
- }
- isLunKuo = false;
- isAddKong = false;
- isDelKong = false;
- }
-
- }
- /// <summary>
- /// Ctrl+z
- /// </summary>
- 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<List<int>> CircleDate = binaryClass.DeleteCrystal(delPointList, kongLineList);
- bindGrid(CircleDate);
- }
- }
- if (isDelKong)
- {
- int cou = delPointList.Count;
- if (cou > 0)
- {
- delPointList.RemoveAt(cou - 1);
- List<List<int>> CircleDate = binaryClass.DeleteCrystal(delPointList, kongLineList);
- bindGrid(CircleDate);
- }
-
- }
- this.documentWorkspace.Refresh();
- }
- }
- #endregion
- /// <summary>
- /// 统计导出
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<double> diameter = new List<double>() { };
- List<double> diameterPi = new List<double>() { };
- 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<double> valueList = new List<double>();
-
- 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<DataTable> list = new List<DataTable>();
- list.Add(dtb0);
- list.Add(dtb1);
- list.Add(dtb2);
- list.Add(dtb);
- List<string> pics = new List<string>() { GR_Path + ",400,200," + chart1.Width + "," + chart1.Height };
- this.appWorkspace.ExportDataToExcelWithProgress(list, exe.FileName, true, false, true, null, null, pics);
- }
- /// <summary>
- /// 批量导出
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<List<System.Data.DataTable>> datasMore = new List<List<DataTable>>();
- List<List<string>> bitmapListMore = new List<List<string>>();
- 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<Bitmap> tempBit = new List<Bitmap>();
- 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<DataTable> list = new List<DataTable>();
- list.Add(dtb0);
- list.Add(dtb1);
- list.Add(dtb2);
- list.Add(dtb);
- List<string> pics = new List<string>() { 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<DataTable> listmore = new List<DataTable>() { totla };
- datasMore.Insert(0, listmore);
- this.appWorkspace.ExportDataToExcelWithProgressForCrystal(datasMore, bitmapListMore, exe.FileName, null);
- }
- /// <summary>
- /// 不可点击空白区域
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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;
- }
- }
- }
- }
- }
- /// <summary>
- /// 导出
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<Bitmap> tempBit = new List<Bitmap>();
- 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<DataTable> list = new List<DataTable>();
- list.Add(dtb0);
- list.Add(dtb1);
- list.Add(dtb2);
- list.Add(dtb);
- List<string> pics = new List<string>() { 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 辅助测量
- /// <summary>
- /// 添加测量线
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnAddCeliang_Click(object sender, EventArgs e)
- {
- operationK = 0;
- selected = -1;
- this.documentWorkspace.Refresh();
- }
- /// <summary>
- /// 选择测量线
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnSelCeliang_Click(object sender, EventArgs e)
- {
- operationK = 1;
- }
- /// <summary>
- /// 删除测量线
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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("请先选择测量线");
- }
- /// <summary>
- /// 添加测量线按钮失去焦点
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- 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<PhaseModel> phaseModels;
- //public AnalysisResult analysisResult;
- public DocumentItem(Bitmap bitmap, GraphicsList graphicsList, List<PhaseModel> phaseModels)
- {
- this.bitmap = bitmap;
- this.graphicsList = graphicsList;
- this.phaseModels = phaseModels;
- }
- }
- #endregion
- #endregion
- }
- }
|