using OpenCvSharp;
using OpenCvSharp.Extensions;
using PaintDotNet.Annotation;
using PaintDotNet.Annotation.Enum;
using PaintDotNet.Base.Functionodel;
using PaintDotNet.CustomControl;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using PaintDotNet.DbOpreate.DbBll;
using PaintDotNet.DbOpreate.DbModel;
using PaintDotNet.Base.CommTool;
using System.IO;
using PaintDotNet.Base.SettingModel;
using PaintDotNet.Data.Param;
using PaintDotNet.Base;
using PaintDotNet.GeneralAnalysis;
using PaintDotNet.DedicatedAnalysis.DuctileIron.Common;
using PaintDotNet;
using Metis.ParameterSet;
namespace Metis.DedicatedAnalysis.DuctileIron.GBT9441_2009.PearliteNumber
{
internal partial class PearliteNumberDialog : PdnBaseForm
{
#region
///
/// Required designer variable.
///
private System.ComponentModel.IContainer components = null;
///
/// Clean up any resources being used.
///
/// true if managed resources should be disposed; otherwise, false.
protected override void Dispose(bool disposing)
{
if (disposing && (components != null))
{
components.Dispose();
}
base.Dispose(disposing);
}
#region Windows Form Designer generated code
private void InitializeLanguageText()
{
this.bc = new PaintDotNet.CustomControl.BinaryControl();
//
// bc
//
this.bc.BinaryBackColor = System.Drawing.Color.Red;
this.bc.BinaryChecked = false;
this.bc.BinaryStyle = 1;
this.bc.Location = new System.Drawing.Point(151, 56);
this.bc.Name = "bc";
this.bc.OriginChecked = false;
this.bc.scope1End = 0D;
this.bc.scope1Start = 0D;
this.bc.scope2End = 0D;
this.bc.scope2Start = 0D;
this.bc.scope3End = 0D;
this.bc.scope3Start = 0D;
this.bc.Size = new System.Drawing.Size(360, 292);
this.bc.TabIndex = 28;
this.Controls.Add(this.bc);
this.Controls.SetChildIndex(this.bc, 0);
this.Text = "GBT9441-2009(" + PdnResources.GetString("Menu.Numberofpearlite.Text") + ")";
this.btnSetUp.Text = PdnResources.GetString("Menu.Setting.Text");
this.checkBox1.Text = PdnResources.GetString("Menu.Opensettingsatingreport.text");
this.button2.Text = PdnResources.GetString("Menu.Saveresult.text");
this.groupBox1.Text = PdnResources.GetString("Menu.operation.text");
this.groupBox2.Text = PdnResources.GetString("Menu.Tools.ImageIndex.Text");
this.groupBox3.Text = PdnResources.GetString("Menu.Preview.text");
this.checkBox3.Text = PdnResources.GetString("Menu.filter.text");
this.label3.Text = PdnResources.GetString("Menu.range.text") + ":";
this.groupBox5.Text = PdnResources.GetString("Menu.Particlescreening.text");
this.checkBox4.Text = PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Showdifofcolor.text");
this.checkBox5.Text = PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Displayarearate.text");
this.btnColour.Text = PdnResources.GetString("Menu.Colorsetting.text");
this.btnDisplay.Text = PdnResources.GetString("Menu.Displayparamssettings.text");
this.checkBox6.Text = PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Particleshecalculation.text");
this.groupBox6.Text = PdnResources.GetString("Menu.paramssettings.text");
this.groupBox8.Text = PdnResources.GetString("Menu.Theesultshow.text");
this.button6.Text = PdnResources.GetString("Menu.Showall.text");
this.button7.Text = PdnResources.GetString("Menu.Edit.Delete.Text");
this.button8.Text = PdnResources.GetString("Menu.Tools.CreateReport.Text");
this.button9.Text = PdnResources.GetString("Menu.Exportresults.text");
this.label8.Text = PdnResources.GetString("Menu.Decimal.text") + ":";
this.button1.Text = PdnResources.GetString("Menu.Exportproject.text");
this.groupBox9.Text = PdnResources.GetString("Menu.Analysisresult.text");
this.label4.Text = PdnResources.GetString("Menu.minimum.text");
this.label5.Text = PdnResources.GetString("Menu.max.text");
this.groupBox7.Text = PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Graphitearearaterange.text") + "(%)";
this.button3.Text = PdnResources.GetString("Menu.File.SaveAll.Text");
this.button4.Text = PdnResources.GetString("Menu.Applyall.text");
}
///
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
///
private void InitializeComponent()
{
this.components = new System.ComponentModel.Container();
this.groupBox7 = new System.Windows.Forms.GroupBox();
this.trackBar6 = new System.Windows.Forms.TrackBar();
this.trackBar5 = new System.Windows.Forms.TrackBar();
this.numericUpDown7 = new System.Windows.Forms.NumericUpDown();
this.numericUpDown6 = new System.Windows.Forms.NumericUpDown();
this.label5 = new System.Windows.Forms.Label();
this.label4 = new System.Windows.Forms.Label();
this.groupBox9 = new System.Windows.Forms.GroupBox();
this.dataGridView3 = new System.Windows.Forms.DataGridView();
this.button1 = new System.Windows.Forms.Button();
this.label10 = new System.Windows.Forms.Label();
this.label9 = new System.Windows.Forms.Label();
this.numericUpDown1 = new System.Windows.Forms.NumericUpDown();
this.label8 = new System.Windows.Forms.Label();
this.button9 = new System.Windows.Forms.Button();
this.button8 = new System.Windows.Forms.Button();
this.dataGridView2 = new System.Windows.Forms.DataGridView();
this.listView2 = new System.Windows.Forms.ListView();
this.button7 = new System.Windows.Forms.Button();
this.button6 = new System.Windows.Forms.Button();
this.groupBox8 = new System.Windows.Forms.GroupBox();
this.dataGridView1 = new System.Windows.Forms.DataGridView();
this.groupBox6 = new System.Windows.Forms.GroupBox();
this.checkBox6 = new System.Windows.Forms.CheckBox();
this.btnDisplay = new System.Windows.Forms.Button();
this.btnColour = new System.Windows.Forms.Button();
this.checkBox5 = new System.Windows.Forms.CheckBox();
this.checkBox4 = new System.Windows.Forms.CheckBox();
this.groupBox5 = new System.Windows.Forms.GroupBox();
this.trackBar4 = new System.Windows.Forms.TrackBar();
this.trackBar2 = new System.Windows.Forms.TrackBar();
this.numericUpDown5 = new System.Windows.Forms.NumericUpDown();
this.numericUpDown4 = new System.Windows.Forms.NumericUpDown();
this.label3 = new System.Windows.Forms.Label();
this.checkBox3 = new System.Windows.Forms.CheckBox();
this.groupBox3 = new System.Windows.Forms.GroupBox();
this.groupBox2 = new System.Windows.Forms.GroupBox();
this.listView1 = new System.Windows.Forms.ListView();
this.imageList1 = new System.Windows.Forms.ImageList(this.components);
this.groupBox1 = new System.Windows.Forms.GroupBox();
this.button2 = new System.Windows.Forms.Button();
this.checkBox1 = new System.Windows.Forms.CheckBox();
this.btnSetUp = new System.Windows.Forms.Button();
this.button3 = new System.Windows.Forms.Button();
this.button4 = new System.Windows.Forms.Button();
this.groupBox7.SuspendLayout();
((System.ComponentModel.ISupportInitialize)(this.trackBar6)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.trackBar5)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown7)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown6)).BeginInit();
this.groupBox9.SuspendLayout();
((System.ComponentModel.ISupportInitialize)(this.dataGridView3)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown1)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.dataGridView2)).BeginInit();
this.groupBox8.SuspendLayout();
((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).BeginInit();
this.groupBox6.SuspendLayout();
this.groupBox5.SuspendLayout();
((System.ComponentModel.ISupportInitialize)(this.trackBar4)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.trackBar2)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown5)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown4)).BeginInit();
this.groupBox2.SuspendLayout();
this.groupBox1.SuspendLayout();
this.SuspendLayout();
//
// groupBox7
//
this.groupBox7.Controls.Add(this.trackBar6);
this.groupBox7.Controls.Add(this.trackBar5);
this.groupBox7.Controls.Add(this.numericUpDown7);
this.groupBox7.Controls.Add(this.numericUpDown6);
this.groupBox7.Controls.Add(this.label5);
this.groupBox7.Controls.Add(this.label4);
this.groupBox7.Location = new System.Drawing.Point(153, 507);
this.groupBox7.Name = "groupBox7";
this.groupBox7.Size = new System.Drawing.Size(358, 51);
this.groupBox7.TabIndex = 27;
this.groupBox7.TabStop = false;
//
// trackBar6
//
this.trackBar6.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.trackBar6.AutoSize = false;
this.trackBar6.Location = new System.Drawing.Point(181, 21);
this.trackBar6.Maximum = 0;
this.trackBar6.Name = "trackBar6";
this.trackBar6.Size = new System.Drawing.Size(87, 25);
this.trackBar6.TabIndex = 17;
this.trackBar6.TickStyle = System.Windows.Forms.TickStyle.None;
//
// trackBar5
//
this.trackBar5.AutoSize = false;
this.trackBar5.Location = new System.Drawing.Point(88, 21);
this.trackBar5.Maximum = 0;
this.trackBar5.Name = "trackBar5";
this.trackBar5.Size = new System.Drawing.Size(87, 25);
this.trackBar5.TabIndex = 16;
this.trackBar5.TickStyle = System.Windows.Forms.TickStyle.None;
//
// numericUpDown7
//
this.numericUpDown7.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.numericUpDown7.Location = new System.Drawing.Point(278, 20);
this.numericUpDown7.Maximum = new decimal(new int[] {
0,
0,
0,
0});
this.numericUpDown7.Name = "numericUpDown7";
this.numericUpDown7.Size = new System.Drawing.Size(46, 21);
this.numericUpDown7.TabIndex = 15;
//
// numericUpDown6
//
this.numericUpDown6.Location = new System.Drawing.Point(35, 20);
this.numericUpDown6.Maximum = new decimal(new int[] {
0,
0,
0,
0});
this.numericUpDown6.Name = "numericUpDown6";
this.numericUpDown6.Size = new System.Drawing.Size(48, 21);
this.numericUpDown6.TabIndex = 14;
//
// label5
//
this.label5.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.label5.AutoSize = true;
this.label5.Location = new System.Drawing.Point(325, 25);
this.label5.Name = "label5";
this.label5.Size = new System.Drawing.Size(0, 12);
this.label5.TabIndex = 11;
//
// label4
//
this.label4.AutoSize = true;
this.label4.Location = new System.Drawing.Point(5, 25);
this.label4.Name = "label4";
this.label4.Size = new System.Drawing.Size(0, 12);
this.label4.TabIndex = 10;
//
// groupBox9
//
this.groupBox9.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
this.groupBox9.Controls.Add(this.dataGridView3);
this.groupBox9.Controls.Add(this.button1);
this.groupBox9.Controls.Add(this.label10);
this.groupBox9.Controls.Add(this.label9);
this.groupBox9.Controls.Add(this.numericUpDown1);
this.groupBox9.Controls.Add(this.label8);
this.groupBox9.Controls.Add(this.button9);
this.groupBox9.Controls.Add(this.button8);
this.groupBox9.Controls.Add(this.dataGridView2);
this.groupBox9.Controls.Add(this.listView2);
this.groupBox9.Controls.Add(this.button7);
this.groupBox9.Controls.Add(this.button6);
this.groupBox9.Location = new System.Drawing.Point(13, 759);
this.groupBox9.Name = "groupBox9";
this.groupBox9.Size = new System.Drawing.Size(1196, 204);
this.groupBox9.TabIndex = 26;
this.groupBox9.TabStop = false;
//
// dataGridView3
//
this.dataGridView3.AllowUserToAddRows = false;
this.dataGridView3.AllowUserToDeleteRows = false;
this.dataGridView3.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
this.dataGridView3.AutoSizeColumnsMode = System.Windows.Forms.DataGridViewAutoSizeColumnsMode.Fill;
this.dataGridView3.BackgroundColor = System.Drawing.Color.White;
this.dataGridView3.ColumnHeadersBorderStyle = System.Windows.Forms.DataGridViewHeaderBorderStyle.None;
this.dataGridView3.Location = new System.Drawing.Point(227, 122);
this.dataGridView3.MultiSelect = false;
this.dataGridView3.Name = "dataGridView3";
this.dataGridView3.RowHeadersVisible = false;
this.dataGridView3.RowTemplate.Height = 23;
this.dataGridView3.SelectionMode = System.Windows.Forms.DataGridViewSelectionMode.FullRowSelect;
this.dataGridView3.Size = new System.Drawing.Size(796, 76);
this.dataGridView3.TabIndex = 11;
//
// button1
//
this.button1.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.button1.Location = new System.Drawing.Point(1051, 108);
this.button1.Name = "button1";
this.button1.Size = new System.Drawing.Size(128, 26);
this.button1.TabIndex = 10;
this.button1.UseVisualStyleBackColor = true;
this.button1.Click += new System.EventHandler(this.button1_Click);
//
// label10
//
this.label10.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Right)));
this.label10.AutoSize = true;
this.label10.ForeColor = System.Drawing.SystemColors.ScrollBar;
this.label10.Location = new System.Drawing.Point(1029, 9);
this.label10.Name = "label10";
this.label10.Size = new System.Drawing.Size(11, 192);
this.label10.TabIndex = 9;
this.label10.Text = "|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|";
//
// label9
//
this.label9.AutoSize = true;
this.label9.ForeColor = System.Drawing.SystemColors.ScrollBar;
this.label9.Location = new System.Drawing.Point(210, 9);
this.label9.Name = "label9";
this.label9.Size = new System.Drawing.Size(11, 192);
this.label9.TabIndex = 8;
this.label9.Text = "|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|\r\n|";
//
// numericUpDown1
//
this.numericUpDown1.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
this.numericUpDown1.Location = new System.Drawing.Point(1103, 162);
this.numericUpDown1.Maximum = new decimal(new int[] {
10,
0,
0,
0});
this.numericUpDown1.Name = "numericUpDown1";
this.numericUpDown1.Size = new System.Drawing.Size(70, 21);
this.numericUpDown1.TabIndex = 7;
this.numericUpDown1.Value = new decimal(new int[] {
2,
0,
0,
0});
this.numericUpDown1.ValueChanged += new System.EventHandler(this.numericUpDown1_ValueChanged);
//
// label8
//
this.label8.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
this.label8.AutoSize = true;
this.label8.Location = new System.Drawing.Point(1064, 167);
this.label8.Name = "label8";
this.label8.Size = new System.Drawing.Size(0, 12);
this.label8.TabIndex = 6;
//
// button9
//
this.button9.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.button9.Location = new System.Drawing.Point(1051, 71);
this.button9.Name = "button9";
this.button9.Size = new System.Drawing.Size(128, 26);
this.button9.TabIndex = 5;
this.button9.UseVisualStyleBackColor = true;
this.button9.Click += new System.EventHandler(this.button9_Click);
//
// button8
//
this.button8.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.button8.Location = new System.Drawing.Point(1051, 34);
this.button8.Name = "button8";
this.button8.Size = new System.Drawing.Size(128, 26);
this.button8.TabIndex = 4;
this.button8.UseVisualStyleBackColor = true;
this.button8.Click += new System.EventHandler(this.button8_Click);
//
// dataGridView2
//
this.dataGridView2.AllowUserToAddRows = false;
this.dataGridView2.AllowUserToDeleteRows = false;
this.dataGridView2.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
this.dataGridView2.AutoSizeColumnsMode = System.Windows.Forms.DataGridViewAutoSizeColumnsMode.Fill;
this.dataGridView2.BackgroundColor = System.Drawing.Color.White;
this.dataGridView2.ColumnHeadersBorderStyle = System.Windows.Forms.DataGridViewHeaderBorderStyle.None;
this.dataGridView2.Location = new System.Drawing.Point(228, 14);
this.dataGridView2.MultiSelect = false;
this.dataGridView2.Name = "dataGridView2";
this.dataGridView2.RowHeadersVisible = false;
this.dataGridView2.RowTemplate.Height = 23;
this.dataGridView2.SelectionMode = System.Windows.Forms.DataGridViewSelectionMode.FullRowSelect;
this.dataGridView2.Size = new System.Drawing.Size(795, 102);
this.dataGridView2.TabIndex = 3;
//
// listView2
//
this.listView2.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)));
this.listView2.HideSelection = false;
this.listView2.Location = new System.Drawing.Point(16, 56);
this.listView2.Name = "listView2";
this.listView2.Size = new System.Drawing.Size(181, 140);
this.listView2.TabIndex = 2;
this.listView2.UseCompatibleStateImageBehavior = false;
this.listView2.SelectedIndexChanged += new System.EventHandler(this.listView2_SelectedIndexChanged);
//
// button7
//
this.button7.Location = new System.Drawing.Point(145, 20);
this.button7.Name = "button7";
this.button7.Size = new System.Drawing.Size(52, 26);
this.button7.TabIndex = 1;
this.button7.UseVisualStyleBackColor = true;
this.button7.Click += new System.EventHandler(this.button7_Click);
//
// button6
//
this.button6.Location = new System.Drawing.Point(16, 20);
this.button6.Name = "button6";
this.button6.Size = new System.Drawing.Size(93, 26);
this.button6.TabIndex = 0;
this.button6.UseVisualStyleBackColor = true;
this.button6.Click += new System.EventHandler(this.button6_Click);
//
// groupBox8
//
this.groupBox8.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)));
this.groupBox8.Controls.Add(this.dataGridView1);
this.groupBox8.Location = new System.Drawing.Point(153, 562);
this.groupBox8.Name = "groupBox8";
this.groupBox8.Size = new System.Drawing.Size(357, 191);
this.groupBox8.TabIndex = 25;
this.groupBox8.TabStop = false;
//
// dataGridView1
//
this.dataGridView1.AllowUserToAddRows = false;
this.dataGridView1.AllowUserToDeleteRows = false;
this.dataGridView1.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)));
this.dataGridView1.AutoSizeColumnsMode = System.Windows.Forms.DataGridViewAutoSizeColumnsMode.Fill;
this.dataGridView1.BackgroundColor = System.Drawing.Color.White;
this.dataGridView1.ColumnHeadersBorderStyle = System.Windows.Forms.DataGridViewHeaderBorderStyle.None;
this.dataGridView1.Location = new System.Drawing.Point(7, 21);
this.dataGridView1.MultiSelect = false;
this.dataGridView1.Name = "dataGridView1";
this.dataGridView1.RowHeadersVisible = false;
this.dataGridView1.RowTemplate.Height = 23;
this.dataGridView1.SelectionMode = System.Windows.Forms.DataGridViewSelectionMode.FullRowSelect;
this.dataGridView1.Size = new System.Drawing.Size(345, 164);
this.dataGridView1.TabIndex = 0;
//
// groupBox6
//
this.groupBox6.Controls.Add(this.checkBox6);
this.groupBox6.Controls.Add(this.btnDisplay);
this.groupBox6.Controls.Add(this.btnColour);
this.groupBox6.Controls.Add(this.checkBox5);
this.groupBox6.Controls.Add(this.checkBox4);
this.groupBox6.Location = new System.Drawing.Point(152, 417);
this.groupBox6.Name = "groupBox6";
this.groupBox6.Size = new System.Drawing.Size(358, 87);
this.groupBox6.TabIndex = 24;
this.groupBox6.TabStop = false;
//
// checkBox6
//
this.checkBox6.AutoSize = true;
this.checkBox6.Location = new System.Drawing.Point(18, 17);
this.checkBox6.Name = "checkBox6";
this.checkBox6.Size = new System.Drawing.Size(15, 14);
this.checkBox6.TabIndex = 11;
this.checkBox6.UseVisualStyleBackColor = true;
this.checkBox6.CheckedChanged += new System.EventHandler(this.checkBox6_CheckedChanged);
//
// btnDisplay
//
this.btnDisplay.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.btnDisplay.Location = new System.Drawing.Point(250, 59);
this.btnDisplay.Name = "btnDisplay";
this.btnDisplay.Size = new System.Drawing.Size(85, 20);
this.btnDisplay.TabIndex = 10;
this.btnDisplay.UseVisualStyleBackColor = true;
this.btnDisplay.Click += new System.EventHandler(this.btnDisplay_Click);
//
// btnColour
//
this.btnColour.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.btnColour.Location = new System.Drawing.Point(260, 33);
this.btnColour.Name = "btnColour";
this.btnColour.Size = new System.Drawing.Size(75, 20);
this.btnColour.TabIndex = 9;
this.btnColour.UseVisualStyleBackColor = true;
this.btnColour.Click += new System.EventHandler(this.btnColour_Click);
//
// checkBox5
//
this.checkBox5.AutoSize = true;
this.checkBox5.Location = new System.Drawing.Point(18, 63);
this.checkBox5.Name = "checkBox5";
this.checkBox5.Size = new System.Drawing.Size(15, 14);
this.checkBox5.TabIndex = 8;
this.checkBox5.UseVisualStyleBackColor = true;
this.checkBox5.CheckedChanged += new System.EventHandler(this.checkBox5_CheckedChanged);
//
// checkBox4
//
this.checkBox4.AutoSize = true;
this.checkBox4.Location = new System.Drawing.Point(18, 40);
this.checkBox4.Name = "checkBox4";
this.checkBox4.Size = new System.Drawing.Size(15, 14);
this.checkBox4.TabIndex = 7;
this.checkBox4.UseVisualStyleBackColor = true;
this.checkBox4.CheckedChanged += new System.EventHandler(this.checkBox4_CheckedChanged);
//
// groupBox5
//
this.groupBox5.Controls.Add(this.trackBar4);
this.groupBox5.Controls.Add(this.trackBar2);
this.groupBox5.Controls.Add(this.numericUpDown5);
this.groupBox5.Controls.Add(this.numericUpDown4);
this.groupBox5.Controls.Add(this.label3);
this.groupBox5.Controls.Add(this.checkBox3);
this.groupBox5.Location = new System.Drawing.Point(152, 348);
this.groupBox5.Name = "groupBox5";
this.groupBox5.Size = new System.Drawing.Size(358, 65);
this.groupBox5.TabIndex = 23;
this.groupBox5.TabStop = false;
//
// trackBar4
//
this.trackBar4.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.trackBar4.AutoSize = false;
this.trackBar4.Location = new System.Drawing.Point(182, 33);
this.trackBar4.Maximum = 0;
this.trackBar4.Name = "trackBar4";
this.trackBar4.Size = new System.Drawing.Size(87, 25);
this.trackBar4.TabIndex = 15;
this.trackBar4.TickStyle = System.Windows.Forms.TickStyle.None;
//
// trackBar2
//
this.trackBar2.AutoSize = false;
this.trackBar2.Location = new System.Drawing.Point(91, 32);
this.trackBar2.Maximum = 0;
this.trackBar2.Name = "trackBar2";
this.trackBar2.Size = new System.Drawing.Size(87, 25);
this.trackBar2.TabIndex = 14;
this.trackBar2.TickStyle = System.Windows.Forms.TickStyle.None;
//
// numericUpDown5
//
this.numericUpDown5.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.numericUpDown5.Location = new System.Drawing.Point(280, 33);
this.numericUpDown5.Maximum = new decimal(new int[] {
0,
0,
0,
0});
this.numericUpDown5.Name = "numericUpDown5";
this.numericUpDown5.Size = new System.Drawing.Size(62, 21);
this.numericUpDown5.TabIndex = 12;
//
// numericUpDown4
//
this.numericUpDown4.Location = new System.Drawing.Point(27, 33);
this.numericUpDown4.Maximum = new decimal(new int[] {
0,
0,
0,
0});
this.numericUpDown4.Name = "numericUpDown4";
this.numericUpDown4.Size = new System.Drawing.Size(62, 21);
this.numericUpDown4.TabIndex = 10;
//
// label3
//
this.label3.AutoSize = true;
this.label3.Location = new System.Drawing.Point(9, 67);
this.label3.Name = "label3";
this.label3.Size = new System.Drawing.Size(0, 12);
this.label3.TabIndex = 9;
//
// checkBox3
//
this.checkBox3.AutoSize = true;
this.checkBox3.Location = new System.Drawing.Point(18, 14);
this.checkBox3.Name = "checkBox3";
this.checkBox3.Size = new System.Drawing.Size(15, 14);
this.checkBox3.TabIndex = 0;
this.checkBox3.UseVisualStyleBackColor = true;
this.checkBox3.CheckedChanged += new System.EventHandler(this.checkBox3_CheckedChanged);
//
// groupBox3
//
this.groupBox3.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
this.groupBox3.Location = new System.Drawing.Point(517, 61);
this.groupBox3.Name = "groupBox3";
this.groupBox3.Size = new System.Drawing.Size(692, 692);
this.groupBox3.TabIndex = 22;
this.groupBox3.TabStop = false;
//
// groupBox2
//
this.groupBox2.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)));
this.groupBox2.Controls.Add(this.listView1);
this.groupBox2.Location = new System.Drawing.Point(13, 61);
this.groupBox2.Name = "groupBox2";
this.groupBox2.Size = new System.Drawing.Size(135, 693);
this.groupBox2.TabIndex = 21;
this.groupBox2.TabStop = false;
//
// listView1
//
this.listView1.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
this.listView1.HideSelection = false;
this.listView1.LargeImageList = this.imageList1;
this.listView1.Location = new System.Drawing.Point(5, 17);
this.listView1.MultiSelect = false;
this.listView1.Name = "listView1";
this.listView1.Size = new System.Drawing.Size(124, 670);
this.listView1.TabIndex = 0;
this.listView1.UseCompatibleStateImageBehavior = false;
this.listView1.SelectedIndexChanged += new System.EventHandler(this.listView1_SelectedIndexChanged);
this.listView1.MouseDown += new System.Windows.Forms.MouseEventHandler(this.listView1_MouseDown);
//
// imageList1
//
this.imageList1.ColorDepth = System.Windows.Forms.ColorDepth.Depth8Bit;
this.imageList1.ImageSize = new System.Drawing.Size(64, 64);
this.imageList1.TransparentColor = System.Drawing.Color.Transparent;
//
// groupBox1
//
this.groupBox1.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
this.groupBox1.Controls.Add(this.button3);
this.groupBox1.Controls.Add(this.button4);
this.groupBox1.Controls.Add(this.button2);
this.groupBox1.Controls.Add(this.checkBox1);
this.groupBox1.Controls.Add(this.btnSetUp);
this.groupBox1.Location = new System.Drawing.Point(13, 4);
this.groupBox1.Name = "groupBox1";
this.groupBox1.Size = new System.Drawing.Size(1196, 50);
this.groupBox1.TabIndex = 20;
this.groupBox1.TabStop = false;
//
// button2
//
this.button2.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Right)));
this.button2.Location = new System.Drawing.Point(1016, 14);
this.button2.Name = "button2";
this.button2.Size = new System.Drawing.Size(84, 30);
this.button2.TabIndex = 2;
this.button2.UseVisualStyleBackColor = true;
this.button2.Click += new System.EventHandler(this.button2_Click);
//
// checkBox1
//
this.checkBox1.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)));
this.checkBox1.AutoSize = true;
this.checkBox1.Location = new System.Drawing.Point(141, 21);
this.checkBox1.Name = "checkBox1";
this.checkBox1.Size = new System.Drawing.Size(15, 14);
this.checkBox1.TabIndex = 1;
this.checkBox1.UseVisualStyleBackColor = true;
//
// btnSetUp
//
this.btnSetUp.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)));
this.btnSetUp.Location = new System.Drawing.Point(15, 14);
this.btnSetUp.Name = "btnSetUp";
this.btnSetUp.Size = new System.Drawing.Size(84, 30);
this.btnSetUp.TabIndex = 0;
this.btnSetUp.UseVisualStyleBackColor = true;
this.btnSetUp.Click += new System.EventHandler(this.btnSetUp_Click);
//
// button3
//
this.button3.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.button3.Location = new System.Drawing.Point(1106, 14);
this.button3.Name = "button3";
this.button3.Size = new System.Drawing.Size(84, 30);
this.button3.TabIndex = 21;
this.button3.Text = "保存全部";
this.button3.UseVisualStyleBackColor = true;
this.button3.Click += new System.EventHandler(this.button3_Click);
//
// button4
//
this.button4.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
this.button4.Location = new System.Drawing.Point(926, 14);
this.button4.Name = "button4";
this.button4.Size = new System.Drawing.Size(84, 30);
this.button4.TabIndex = 20;
this.button4.Text = "应用全部";
this.button4.UseVisualStyleBackColor = true;
this.button4.Click += new System.EventHandler(this.button4_Click);
//
// PearliteNumberDialog
//
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(1222, 967);
this.Controls.Add(this.groupBox7);
this.Controls.Add(this.groupBox9);
this.Controls.Add(this.groupBox8);
this.Controls.Add(this.groupBox6);
this.Controls.Add(this.groupBox5);
this.Controls.Add(this.groupBox3);
this.Controls.Add(this.groupBox2);
this.Controls.Add(this.groupBox1);
this.Name = "PearliteNumberDialog";
this.FormClosing += new System.Windows.Forms.FormClosingEventHandler(this.InclusionsStandardDialog_FormClosing);
this.Load += new System.EventHandler(this.GrainSizeDialog_Load);
this.Shown += new System.EventHandler(this.ShownChoiseItemAndInitData);
this.Controls.SetChildIndex(this.groupBox1, 0);
this.Controls.SetChildIndex(this.groupBox2, 0);
this.Controls.SetChildIndex(this.groupBox3, 0);
this.Controls.SetChildIndex(this.groupBox5, 0);
this.Controls.SetChildIndex(this.groupBox6, 0);
this.Controls.SetChildIndex(this.groupBox8, 0);
this.Controls.SetChildIndex(this.groupBox9, 0);
this.Controls.SetChildIndex(this.groupBox7, 0);
this.groupBox7.ResumeLayout(false);
this.groupBox7.PerformLayout();
((System.ComponentModel.ISupportInitialize)(this.trackBar6)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.trackBar5)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown7)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown6)).EndInit();
this.groupBox9.ResumeLayout(false);
this.groupBox9.PerformLayout();
((System.ComponentModel.ISupportInitialize)(this.dataGridView3)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown1)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.dataGridView2)).EndInit();
this.groupBox8.ResumeLayout(false);
((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).EndInit();
this.groupBox6.ResumeLayout(false);
this.groupBox6.PerformLayout();
this.groupBox5.ResumeLayout(false);
this.groupBox5.PerformLayout();
((System.ComponentModel.ISupportInitialize)(this.trackBar4)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.trackBar2)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown5)).EndInit();
((System.ComponentModel.ISupportInitialize)(this.numericUpDown4)).EndInit();
this.groupBox2.ResumeLayout(false);
this.groupBox1.ResumeLayout(false);
this.groupBox1.PerformLayout();
this.ResumeLayout(false);
}
#endregion
private PaintDotNet.CustomControl.BinaryControl bc;
private System.Windows.Forms.GroupBox groupBox7;
private System.Windows.Forms.TrackBar trackBar6;
private System.Windows.Forms.TrackBar trackBar5;
private System.Windows.Forms.NumericUpDown numericUpDown7;
private System.Windows.Forms.NumericUpDown numericUpDown6;
private System.Windows.Forms.Label label5;
private System.Windows.Forms.Label label4;
private System.Windows.Forms.GroupBox groupBox9;
private System.Windows.Forms.DataGridView dataGridView3;
private System.Windows.Forms.Button button1;
private System.Windows.Forms.Label label10;
private System.Windows.Forms.Label label9;
private System.Windows.Forms.NumericUpDown numericUpDown1;
private System.Windows.Forms.Label label8;
private System.Windows.Forms.Button button9;
private System.Windows.Forms.Button button8;
private System.Windows.Forms.DataGridView dataGridView2;
private System.Windows.Forms.ListView listView2;
private System.Windows.Forms.Button button7;
private System.Windows.Forms.Button button6;
private System.Windows.Forms.GroupBox groupBox8;
private System.Windows.Forms.DataGridView dataGridView1;
private System.Windows.Forms.GroupBox groupBox6;
private System.Windows.Forms.CheckBox checkBox6;
private System.Windows.Forms.Button btnDisplay;
private System.Windows.Forms.Button btnColour;
public System.Windows.Forms.CheckBox checkBox5;
public System.Windows.Forms.CheckBox checkBox4;
private System.Windows.Forms.GroupBox groupBox5;
private System.Windows.Forms.TrackBar trackBar4;
private System.Windows.Forms.TrackBar trackBar2;
private System.Windows.Forms.NumericUpDown numericUpDown5;
private System.Windows.Forms.NumericUpDown numericUpDown4;
private System.Windows.Forms.Label label3;
private System.Windows.Forms.CheckBox checkBox3;
private System.Windows.Forms.GroupBox groupBox3;
private System.Windows.Forms.GroupBox groupBox2;
private System.Windows.Forms.ListView listView1;
private System.Windows.Forms.GroupBox groupBox1;
private System.Windows.Forms.Button button2;
private System.Windows.Forms.CheckBox checkBox1;
private System.Windows.Forms.Button btnSetUp;
private System.Windows.Forms.ImageList imageList1;
#endregion
public static PearliteNumberDialog pearliteNumberDialog;
///
/// 调色板
///
PaintDotNet.ColorsForm colorsForm1;
PaintDotNet.ColorsForm colorsForm2;
///
/// 主控件
///
private AppWorkspace appWorkspace;
///
/// 图像面板
///
public DocumentWorkspaceWindow documentWorkspace;
///
/// 公共按钮
///
private CommonControlButtons commonControlButtons;
///
/// 选中图片的bitmap
///
private Bitmap bitmap;
///
/// 计算结果的表格集合
///
private List resultTableList = new List();
///
/// 保存用于生成报告的图片
///
private List bitList;
///
/// 储存点击保存结果后的所有原图与分析图
///
private Dictionary> bitDic = new Dictionary>();
///
/// 是否显示全部
///
private bool showAll = false;
///
/// 当前图片是否有视场
///
private bool isHadView = false;
///
/// 原图mat-包括视场
///
private Mat mat;
///
/// 二值处理后的mat
///
private Mat binarizationMat;
///
/// 面积率为0.8-1的mat
///
private Mat binarizationMat08_1;
///
/// 面积率为0.6-0.8的mat
///
private Mat binarizationMat06_08;
///
/// 面积率为0.4-0.6的mat
///
private Mat binarizationMat04_06;
///
/// 面积率为0.2-0.4的mat
///
private Mat binarizationMat02_04;
///
/// 面积率为0.1-0.2的mat
///
private Mat binarizationMat01_02;
///
/// 面积率为0-0.1的mat
///
private Mat binarizationMat0_01;
///
/// 相的集合
///
private PhaseModel phaseModel;
///
/// 相的集合
///
private PhaseModel phaseModel08_1;
///
/// 相的集合
///
private PhaseModel phaseModel06_08;
///
/// 相的集合
///
private PhaseModel phaseModel04_06;
///
/// 相的集合
///
private PhaseModel phaseModel02_04;
///
/// 相的集合
///
private PhaseModel phaseModel01_02;
///
/// 相的集合
///
private PhaseModel phaseModel0_01;
///
/// 单位标尺
///
private double unitLength = 1;
///
/// 放大倍数
///
private double multiple = 1;
///
/// 坐标集合
///
private List pointList = new List();
///
/// 绘制点
///
private List leList = new List();
///
/// 最大点碳化物点集合
///
private List> maxPoint;
///
/// 面积率0.8_1碳化物点集合
///
private List> lstPoint08_1;
///
/// 面积率0.6_0.8化物点集合
///
private List> lstPoint06_08;
///
/// 面积率0.4_0.6化物点集合
///
private List> lstPoint04_06;
///
/// 面积率0.2_0.4化物点集合
///
private List> lstPoint02_04;
///
/// 面积率0.1_0.2化物点集合
///
private List> lstPoint01_02;
///
/// 面积率0_0.1化物点集合
///
private List> lstPoint0_01;
///
/// 钨系A标准
///
private double[] tungstenA = new double[] { 18, 21, 23, 25 };
///
/// 钨系B标准
///
private double[] tungstenB = new double[] { 16, 18, 21, 23 };
///
/// 钼系标准
///
private double[] molybdenum = new double[] { 6.1, 8.3, 12.5, 15.6, 22.1 };
///
/// 面积率
///
private double areaRatio = 0;
///
/// 面积率最大值
///
double maxAreaRatio = 0;
///
/// 面积率最小值
///
double minAreaRatio = 100;
///
/// 存储面积率颜色字典
///
public Dictionary colour = new Dictionary();
//
/// 存储字号与颜色字典
///
public Dictionary colourFont = new Dictionary();
///
/// 碳化物尺寸最大值
///
private double maxSize = 0;
///
/// 是否仅修改相的颜色
///
private bool changeColor = false;
///
/// 是否未对图片做其他操作
///
private bool isFirstSwitch = false;
///
/// 中间数据
///
private List tempDataModel = new List();
private bool needChange = true;
///
/// 类型(球铁-1,蠕铁GBT26656-2,蠕铁JBT3829-3)
///
private int IronType = 0;
private int defaultIndex = -1;
private bool isExportResults = false;
private bool isExportReports = false;
private bool isExportProjects = false;
///
/// 是否脚本运行
///
private Boolean initScriptValues = false;
///
/// 保存窗口参数
///
///
/// 各个图片对应数据
///
private Dictionary eachData = new Dictionary();
private const string ParamKey_Report = "report";//报告设置
private const string ParamKey_Screen = "screen";//筛选
private const string ParamKey_ScreenMin = "screenMin";//面积最小值
private const string ParamKey_ScreenMax = "screenMax";//面积最大值
private const string ParamKey_Diameter = "diameter";//直径小于20um不参与计算
private const string ParamKey_Colour = "colour";//显示不同级别颜色
private const string ParamKey_AreaRatio = "areaRatio";//显示面积率
private const string ParamKey_AreaRatioRangeMin = "areaRatioRangeMin";//面积率区间最小值
private const string ParamKey_AreaRatioRangeMax = "areaRatioRangeMax";//面积率区间最大值
private const string ParamKey_DecimalPlace = "decimalPlace";//保留小数位数
private const string ParamKey_panelColour1_08 = "panelColour1_08";//不同区间颜色
private const string ParamKey_panelColour08_06 = "panelColour08_06";//不同区间颜色
private const string ParamKey_panelColour06_04 = "panelColour06_04";//不同区间颜色
private const string ParamKey_panelColour04_02 = "panelColour04_02";//不同区间颜色
private const string ParamKey_panelColour02_01 = "panelColour02_01";//不同区间颜色
private const string ParamKey_panelColour01_0 = "panelColour01_0";//不同区间颜色
private const string ParamKey_FontSize = "fontSize";//字体大小
private const string ParamKey_FontColour = "fontColour";//字体颜色
private decimal areaRatioRangeMin = -1;
private decimal areaRatioRangeMax = -1;
private decimal areaMin = -1;//面积区间最小
private decimal areaMax = -1;//面积区间最大
private string fontSize = "12";
private Color fontColour = Color.Black;
#region 二值化相关
///
/// 调色板
///
private ColorsForm colorsFormGrid;
//二值化集成1
BinaryClass binaryClass;
private Button button3;
private Button button4;
private int menuId;
private string menuName;
#endregion
public PearliteNumberDialog(AppWorkspace appWorkspace, int type, PdnMenuItem menuItem)
{
this.menuId = menuItem.MenuId;
this.menuName = menuItem.Text;
binaryClass = new BinaryClass(menuId);
IronType = type;
pearliteNumberDialog = this;
this.appWorkspace = appWorkspace;
NullKey();
InitializeComponent();
InitializeLanguageText();
InitColour();
InitPicList();
InitOtherTools();
InitCommonButtonEvent();
InitGridHeader();
if (IronType == 1)
{
SetAnalyzeModelFromXml("Template.Manager.item3.DuctileIronGBT9441Pearlite");
this.Text = "GBT9441-2009("+ PdnResources.GetString("Menu.Numberofpearlite.Text")+ ")";
}
else if (IronType == 2)
{
SetAnalyzeModelFromXml("Template.Manager.item3.VermiculateCastGBT26656PN");
this.Text = "GBT26656-2011("+ PdnResources.GetString("Menu.Numberofpearlite.Text")+ ")";
}
else if (IronType == 3)
{
SetAnalyzeModelFromXml("Template.Manager.item3.VermiculateCastJBT3829PN");
this.Text = "JBT3829_1999("+ PdnResources.GetString("Menu.Numberofpearlite.Text")+ ")";
}
}
//private void ShowImg()
//{
// var chooseImg = this.appWorkspace.DocumentWorkspaces.Where(m => m.Focused == true).FirstOrDefault();
// if (chooseImg != null)
// {
// if (chooseImg.FilePath != null)
// {
// var name = chooseImg.FilePath.Split('\\')[chooseImg.FilePath.Split('\\').Length - 1];
// var index = listView1.Items.IndexOfKey(name);
// if (index != -1)
// {
// this.defaultIndex = index;
// }
// }
// }
// this.Shown += ShowImgEvent;
//}
private void ShowImgEvent(object sender, EventArgs e)
{
listView1.Focus();
if (this.defaultIndex != -1)
{
this.listView1.Items[defaultIndex].Focused = true;
this.listView1.Items[defaultIndex].Selected = true;
//如果是脚本执行,将参数带入
if (appWorkspace.ScriptRunning && appWorkspace.ScriptCurrentParam != null)
{
this.initScriptValues = true;//ScriptAutomatic
//Boolean initScriptValues = true;
////在这里反射出对应功能的参数类
string className = InvariantData.path_Action + ".Action" + menuId;
ParamObject param = (ParamObject)System.Reflection.Assembly.Load(InvariantData.assembly_Data).CreateInstance(className);
foreach (Args arg in param.Lists)
{
Args param1 = appWorkspace.ScriptCurrentParam.Lists.Find(m => m.Key.Equals(arg.Key));
if (param1.value != null)
arg.Value = param1.value;
getValue(arg.key, arg.Value);
}
appWorkspace.ScriptCurrentParam = null;//阻止第二次进入仍然被赋值参数
}
else
{//读取上次关闭窗口时保存的参数
GetXmlParameter();
GetListParamModel();
}
if (this.initScriptValues && this.appWorkspace.ScriptAutomatic)
this.startScriptAutomaticAction();
}
}
///
/// 初始化面积率颜色、字号颜色
///
private void InitColour()
{
colour.Add("panelColour1_08", Color.Orange);
colour.Add("panelColour08_06", Color.Blue);
colour.Add("panelColour06_04", Color.Green);
colour.Add("panelColour04_02", Color.Pink);
colour.Add("panelColour02_01", Color.Violet);
colour.Add("panelColour01_0", Color.Yellow);
colourFont.Add("10", Color.Black);
}
///
/// 初始化表头
///
private void InitGridHeader()
{
//
//结果展示表
//
this.dataGridView1.ColumnHeadersHeight = 30;
DataGridViewTextBoxColumn h1 = new DataGridViewTextBoxColumn();
h1.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h1.Width = 130;
DataGridViewTextBoxColumn h2 = new DataGridViewTextBoxColumn();
h2.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h2.Width = 130;
DataGridViewTextBoxColumn h3 = new DataGridViewTextBoxColumn();
h3.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h3.Width = 130;
this.dataGridView1.Columns.Add(h1);
this.dataGridView1.Columns.Add(h2);
this.dataGridView1.Columns.Add(h3);
DataGridViewHelper helper = new DataGridViewHelper(this.dataGridView1);
helper.Headers.Add(new DataGridViewHelper.TopHeader(0, 1, PdnResources.GetString("Menu.view.text")));
helper.Headers.Add(new DataGridViewHelper.TopHeader(1, 1, PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(2, 1, PdnResources.GetString("Menu.Levelname.text")));
this.dataGridView1.Columns[0].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[0].ReadOnly = true;
this.dataGridView1.Columns[0].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;//文字居中
this.dataGridView1.Columns[1].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[1].ReadOnly = true;
this.dataGridView1.Columns[1].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[2].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[2].ReadOnly = true;
this.dataGridView1.Columns[2].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.AllowUserToResizeRows = false;
this.dataGridView1.AllowUserToResizeColumns = false;
//
//分析结果表
//
this.dataGridView2.ColumnHeadersHeight = 30;
DataGridViewTextBoxColumn h11 = new DataGridViewTextBoxColumn();
//h11.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h11.Width = 187;
DataGridViewTextBoxColumn h12 = new DataGridViewTextBoxColumn();
//h12.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h12.Width = 187;
DataGridViewTextBoxColumn h13 = new DataGridViewTextBoxColumn();
//h13.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h13.Width = 187;
DataGridViewTextBoxColumn h14 = new DataGridViewTextBoxColumn();
//h14.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h14.Width = 187;
this.dataGridView2.Columns.Add(h11);
this.dataGridView2.Columns.Add(h12);
this.dataGridView2.Columns.Add(h13);
this.dataGridView2.Columns.Add(h14);
DataGridViewHelper helper2 = new DataGridViewHelper(this.dataGridView2);
helper2.Headers.Add(new DataGridViewHelper.TopHeader(0, 1, PdnResources.GetString("Menu.picture.Text")));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(1, 1, PdnResources.GetString("Menu.view.text")));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(2, 1, PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(3, 1, PdnResources.GetString("Menu.Levelname.text")));
this.dataGridView2.Columns[0].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[0].ReadOnly = true;
this.dataGridView2.Columns[1].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[1].ReadOnly = true;
this.dataGridView2.Columns[2].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[2].ReadOnly = true;
this.dataGridView2.Columns[3].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[3].ReadOnly = true;
this.dataGridView2.AllowUserToResizeRows = false;
this.dataGridView2.AllowUserToResizeColumns = false;
this.dataGridView3.ColumnHeadersHeight = 30;
DataGridViewTextBoxColumn h22 = new DataGridViewTextBoxColumn();
//h22.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h22.Width = 187;
DataGridViewTextBoxColumn h23 = new DataGridViewTextBoxColumn();
//h23.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h23.Width = 187;
DataGridViewTextBoxColumn h24 = new DataGridViewTextBoxColumn();
//h24.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h24.Width = 187;
DataGridViewTextBoxColumn h25 = new DataGridViewTextBoxColumn();
//h25.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h25.Width = 187;
this.dataGridView3.Columns.Add(h22);
this.dataGridView3.Columns.Add(h23);
this.dataGridView3.Columns.Add(h24);
this.dataGridView3.Columns.Add(h25);
DataGridViewHelper helper3 = new DataGridViewHelper(this.dataGridView3);
helper3.Headers.Add(new DataGridViewHelper.TopHeader(0, 1, PdnResources.GetString("Menu.picture.Text")));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(1, 1, PdnResources.GetString("Menu.view.text")));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(2, 1, PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(3, 1, PdnResources.GetString("Menu.Levelname.text")));
this.dataGridView3.Columns[0].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[0].ReadOnly = true;
this.dataGridView3.Columns[1].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[1].ReadOnly = true;
this.dataGridView3.Columns[2].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[2].ReadOnly = true;
this.dataGridView3.Columns[3].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[3].ReadOnly = true;
this.dataGridView3.AllowUserToResizeRows = false;
this.dataGridView3.AllowUserToResizeColumns = false;
//
//左下表
//
this.listView2.View = View.Details;
ColumnHeader header0 = new ColumnHeader();
header0.Text = PdnResources.GetString("Menu.Imagelist.Text");
header0.Width = 175;
this.listView2.Columns.Add(header0);
}
///
/// 初始化画布按键功能
///
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 = DrawToolType.Pointer;
}
private void mobileModeButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ActiveTool = DrawToolType.MoveMode;
}
///
/// 调色板回调函数
///
///
///
private void colorsFormUserPrimaryColorChanged(object sender, ColorEventArgs ce)
{
}
///
/// 初始化其他控件
///
private void InitOtherTools()
{
//
//初始化图像控件
//
this.documentWorkspace = new DocumentWorkspaceWindow(this.appWorkspace);
this.documentWorkspace.Dock = DockStyle.Fill;
this.documentWorkspace.HookMouseEvents();
this.documentWorkspace.AuxiliaryLineEnabled = false;
this.documentWorkspace.Visible = false;
this.documentWorkspace.activeTool = DrawToolType.NullTool;
this.groupBox3.Controls.Add(documentWorkspace);
//
//初始化操作按钮
//
this.commonControlButtons = new CommonControlButtons();
this.commonControlButtons.Dock = DockStyle.Top;
this.commonControlButtons.Height = 30;
this.commonControlButtons.HideZoomToWindowAndActualSize();
this.commonControlButtons.Visible = false;
this.groupBox3.Controls.Add(commonControlButtons);
//二值化集成2
bc.OriginCheckedChangedAction += new EventHandler(this.bcOriginCheckedChanged);//初始化原图勾选改变事件
binaryClass.createDocumentItems(new string[] { PdnResources.GetString("Menu.BinaryAction.BinaryExtraction.Text"), PdnResources.GetString("Menu.Particlescreening.text")}
, this.bc, this.appWorkspace, this.documentWorkspace, this.listView1);//初始化相的工作结构
binaryClass.BinaryImplFinishAction += new EventHandler(this.bClassBinaryImplFinishAction);//二值化后续处理事件
//
//调色板
//
//this.colorsForm1 = new ColorsForm();
//this.colorsForm1.StartPosition = FormStartPosition.CenterScreen;
//this.colorsForm1.UserPrimaryColorChanged += new ColorEventHandler(this.colorsFormUserPrimaryColorChanged);
//
//调色板
//
this.colorsForm1 = new ColorsForm();
this.colorsForm1.StartPosition = FormStartPosition.CenterScreen;
this.colorsForm1.UserPrimaryColorChanged += new ColorEventHandler(this.colorsFormUserPrimaryColorChanged);
this.colorsFormGrid = new ColorsForm();
this.colorsFormGrid.StartPosition = FormStartPosition.CenterScreen;
this.colorsFormGrid.setSaveBtn_Click(new System.EventHandler(this.gridColorChanged));
//
//颜色panel给定初始值
//
//this.panel1.BackColor = Color.Red;
////获取系统标尺-微米
////
//this.appWorkspace.getMeasureInfo().TryGetValue(MeasurementUnit.Micron, out unitLength);
//
//获取系统标尺-放大倍数
//
if (this.documentWorkspace.GetGainMultiple() != 0)
{
multiple = double.Parse(this.documentWorkspace.GetGainMultiple().ToString());
}
}
//二值化集成3
#region 二值化相关方法
private void InclusionsStandardDialog_FormClosing(object sender, FormClosingEventArgs e)
{
#region [开启脚本录制]
if (appWorkspace.startScriptRecording)
{
getScriptRecording();
}
#endregion
this.saveDialogParamValues();
binaryClass.saveParams();
//xml保存路径
string filePath = Application.StartupPath + "\\Config\\" + Startup.instance.SettingPrefix + "\\GrainSizeAnalyze\\GrainSizeAnalysisModel.xml";
GrainSizeAnalysisModel analysisModelXml = XmlSerializeHelper.DESerializer(FileOperationHelper.ReadStringFromFile(filePath, System.IO.FileMode.Open));
foreach (var analysisItem in this.eachData[GetImgKey()].ListParam)
{
bool foundItem = false;
foreach (var item in analysisModelXml.ListParam)
{
if (item.param_key.Equals(analysisItem.param_key) && item.menuId == analysisItem.menuId)
{
item.param_value = analysisItem.param_value;
foundItem = true;
break;
}
}
if (!foundItem)
analysisModelXml.ListParam.Add(analysisItem.cloneModel());
}
//按路径和名称保存xml文件
string userInfoXml = XmlSerializeHelper.XmlSerialize(analysisModelXml);
//保存xml
FileOperationHelper.WriteStringToFile(userInfoXml, filePath, System.IO.FileMode.Create);
}
private void ShownChoiseItemAndInitData(object sender, EventArgs e)
{
binaryClass.RefreshHistogramControl1Values();
}
///
/// 添加参数改变的监听
///
///
///
private void GrainSizeDialog_Load(object sender, EventArgs e)
{
this.binaryClass.loadParams();
if (this.initScriptValues && this.appWorkspace.ScriptAutomatic)
this.startScriptAutomaticAction();
}
private bool bcBinaryChecked()
{
return bc != null && bc.BinaryChecked;
}
private bool bcOriginChecked()
{
return bc != null && bc.OriginChecked;
}
///
/// Panel2的调色板颜色改变
///
///
///
private void gridColorChanged(object sender, EventArgs e)
{
this.colorsForm1.Close();
changeColor = true;
//ReLoadBinarization();
this.documentWorkspace.Refresh();
}
///
/// 参数改变时,重新处理图像
///
///
///
private void bClassBinaryImplFinishAction(object sender, EventArgs e)
{
if (phaseModel != null)
{
sum++;
this.documentWorkspace.PhaseModels[0].choise = false;
if (bcBinaryChecked())
{
if (bcOriginChecked())
{
phaseModel.choise = false;
}
else
{
phaseModel.choise = true;
}
binarizationMat = this.documentWorkspace.PhaseModels[0].mat;
//changeColor = false;
ResetAreaAndContent();
ReloadDebrisSelection();
//appCommonDisplay.DisplayData(this.dataGridView1, true);
}
else
{
phaseModel.choise = false;
if (this.checkBox5.Checked)
{
this.documentWorkspace.panel.Paint -= new PaintEventHandler(this.BoxPaintHandler);
}
appCommonDisplay.DisplayData(this.dataGridView1, false);
}
this.documentWorkspace.Refresh();
}
else
{
//MessageBox.Show(PdnResources.GetString("Menu.Pleaseselectapicture.text")+"!");
}
}
AppCommon appCommonDisplay = new AppCommon();
///
/// 显示原图/原图+二值图
///
///
///
private void bcOriginCheckedChanged(object sender, EventArgs e)
{
if (phaseModel != null)
{
this.documentWorkspace.PhaseModels[0].choise = false;
if (!bcBinaryChecked())
{
phaseModel.choise = false;
appCommonDisplay.DisplayData(this.dataGridView1, false);
}
else
{
if (bcOriginChecked())
{
phaseModel.choise = false;
if (this.checkBox5.Checked)
{
this.documentWorkspace.panel.Paint -= new PaintEventHandler(this.BoxPaintHandler);
}
appCommonDisplay.DisplayData(this.dataGridView1, false);
}
else
{
phaseModel.choise = true;
if (this.checkBox5.Checked)
{
this.documentWorkspace.panel.Paint += new PaintEventHandler(this.BoxPaintHandler);
}
appCommonDisplay.DisplayData(this.dataGridView1, true);
}
}
this.documentWorkspace.Refresh();
}
else
{
//MessageBox.Show(PdnResources.GetString("Menu.Pleaseselectapicture.text")+"!");
}
}
#endregion
///
/// 初始化图片列表数据
///
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 (this.appWorkspace.DocumentWorkspaces[i].Equals(this.appWorkspace.ActiveDocumentWorkspace))
{
defaultIndex = i;
}
}
this.Shown += ShowImgEvent;
}
///
/// 颜色设置设置按钮
///
///
///
private void btnColour_Click(object sender, EventArgs e)
{
ColorSetting colorSetting = new ColorSetting();
colorSetting.ShowDialog();
}
///
/// 显示参数设置按钮
///
///
///
private void btnDisplay_Click(object sender, EventArgs e)
{
DisplaySetting displaySetting = new DisplaySetting();
displaySetting.ShowDialog();
}
///
/// 设置按钮
///
///
///
private void btnSetUp_Click(object sender, EventArgs e)
{
AnalyzeSettingDialog metallographicMethodSetDialog = null;
if (IronType == 1)
{
metallographicMethodSetDialog = new AnalyzeSettingDialog(this, "Template.Manager.item3.DuctileIronGBT9441Pearlite");
}
else if (IronType == 2)
{
metallographicMethodSetDialog = new AnalyzeSettingDialog(this, "Template.Manager.item3.VermiculateCastGBT26656PN");
}
else if (IronType == 3)
{
metallographicMethodSetDialog = new AnalyzeSettingDialog(this, "Template.Manager.item3.VermiculateCastJBT3829PN");
}
if (metallographicMethodSetDialog.hasModule)
{
metallographicMethodSetDialog.StartPosition = FormStartPosition.CenterScreen;
metallographicMethodSetDialog.ShowDialog();
}
else
{
metallographicMethodSetDialog = null;
}
}
///
/// 图像索引切换选中事件
///
///
///
double picArea = 0;//图片面积
int sum;//判断是否二值过
private void listView1_SelectedIndexChanged(object sender, EventArgs e)
{
if (this.listView1.FocusedItem != null && this.listView1.FocusedItem.Selected)
{
//获取标尺-微米
unitLength = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GetRuler(MeasurementUnit.Micron);
GetListParamModel();
sum = 0;
if (this.checkBox5.Checked)
{
this.documentWorkspace.panel.Paint -= new PaintEventHandler(this.BoxPaintHandler);
}
this.dataGridView1.Rows.Clear();
if (this.documentWorkspace.PhaseModels.Count > 1)
this.documentWorkspace.PhaseModels.Remove(this.documentWorkspace.PhaseModels[1]);
this.commonControlButtons.Visible = true;
this.documentWorkspace.GraphicsList = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GraphicsList;
this.bitmap = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].CompositionSurface.CreateAliasedBitmap();
//总面积
picArea = AnalysisTools.GetPointsFromMat(BitmapConverter.ToMat(this.bitmap));
changeColor = false;
phaseModel = new PhaseModel();//同上
phaseModel.choise = true;
//二值化集成4
binaryClass.listView1_SelectedIndexChangedNoCheckedChanged(this.bitmap, this.imageList1.Images.Keys[this.listView1.FocusedItem.Index]);
if (binaryClass.getModelMat(this.imageList1.Images.Keys[this.listView1.FocusedItem.Index]) != null)
{
this.binarizationMat = binaryClass.getModelMat(this.imageList1.Images.Keys[this.listView1.FocusedItem.Index]).Clone();
}
else
{
if (this.documentWorkspace.PhaseModels[0].mat == null)
{
this.binarizationMat = new Mat();
}
else
{
this.binarizationMat = this.documentWorkspace.PhaseModels[0].mat.Clone();
}
}
this.documentWorkspace.PhaseModels[0].choise = false;
this.documentWorkspace.phaseModels.Add(phaseModel);
if (sum == 0)
{
if (bcOriginChecked() || !bcBinaryChecked())
{
phaseModel.choise = false;
}
ResetAreaAndContent();
ReloadDebrisSelection();
}
else
{
if (bcOriginChecked() || !bcBinaryChecked())
{
phaseModel.choise = false;
}
else
{
phaseModel.choise = true;
}
this.documentWorkspace.Refresh();
}
sum = 0;
}
}
Mat temp;//中间变量
List> ps;//轮廓的拓扑信息
DataTable dtDataGridView1 = null;
DataTable dtResult = null;
AppCommon appCommon = new AppCommon();
List lstScreenArea;//珠光体面积集合
List lstScreenAreaRatio;//珠光体面积率集合
///
/// 刷新颗粒筛选颜色面积率效果
///
private void ReloadDebrisSelection()
{
if (binarizationMat != null && bcBinaryChecked())
{
this.dataGridView1.Rows.Clear();
dtDataGridView1 = new DataTable();
//记录条件范围内石墨
lstPoint08_1 = new List>();
lstPoint06_08 = new List>();
lstPoint04_06 = new List>();
lstPoint02_04 = new List>();
lstPoint01_02 = new List>();
lstPoint0_01 = new List>();
//记录视场珠光体含量总和
double pearliteNumSum = 0;
lstScreenArea = new List();//珠光体面积集合
lstScreenAreaRatio = new List();//珠光体面积集合
ps = new List>();//轮廓的拓扑信息
pointList.Clear();
leList.Clear();
temp = new Mat();
if (this.documentWorkspace.GraphicsList.IsExsitView())
{
List points = new List();//各石墨轮廓集合
List> lstAttribute = new List>();//各个视场属性集合,索引0-横坐标,1-纵坐标,2-视场宽度,3-视场高度,4-视场面积
int sumFieldl = 0; //视场个数
Mat tempCopy = BinaryClass.BGRA2GRAY(binarizationMat);
//调用处理视场方法
appCommon.MultiFieldView(appWorkspace, binarizationMat, listView1, documentWorkspace, out points, out lstAttribute, out sumFieldl);
int h = 0;
foreach (OpenCvSharp.Point[][] contours in points)
{
h++;
double totalAreaSum = 0;//面积总数
double screenArea = 0;//筛选的面积
for (int i = 0; i < contours.Length; i++)
{
for (int f = 0; f < contours[i].Length; f++)
{
contours[i][f].X = contours[i][f].X + lstAttribute[h - 1][0];
contours[i][f].Y = contours[i][f].Y + lstAttribute[h - 1][1];
}
double radius; //外接圆半径
double area = appCommon.Area(tempCopy, contours[i][0]);
double equalDiameter = Math.Sqrt(area / Math.PI) * 2 * unitLength;
if (this.checkBox3.Checked)
{
if (this.checkBox6.Checked)
{
if (equalDiameter < 20)
{
ps.Add(contours[i].ToList());
continue;
}
if (area >= (this.trackBar2.Value / (unitLength * unitLength)) && area <= (this.trackBar4.Value / (unitLength * unitLength)))
{
ps.Add(contours[i].ToList());
}
else
{
if (contours[i].Length < 5)
{
continue;
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
}
else
{
if (area >= (this.trackBar2.Value / (unitLength * unitLength)) && area <= (this.trackBar4.Value / (unitLength * unitLength)))
{
ps.Add(contours[i].ToList());
}
else
{
if (contours[i].Length < 5)
{
continue;
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
}
}
else
{
if (this.checkBox6.Checked)
{
if (equalDiameter < 20)
{
ps.Add(contours[i].ToList());
}
}
if (contours[i].Length < 5)
continue;
else
{
if (this.checkBox6.Checked)
{
//if (equalDiameter < 20)
//{
// ps.Add(contours[i].ToList());
//}
if (equalDiameter >= 20)
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
}
}
string level = string.Empty; //珠光体级别
double pearliteNum = (totalAreaSum - screenArea) / (lstAttribute[h - 1][4] - screenArea); //珠光体数量
if (IronType == 1)
{
if (pearliteNum > 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (pearliteNum > 0.8 && pearliteNum <= 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (pearliteNum > 0.7 && pearliteNum <= 0.8)
{
level = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (pearliteNum > 0.6 && pearliteNum <= 0.7)
{
level = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (pearliteNum > 0.5 && pearliteNum <= 0.6)
{
level = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (pearliteNum > 0.4 && pearliteNum <= 0.5)
{
level = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (pearliteNum > 0.3 && pearliteNum <= 0.4)
{
level = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (pearliteNum > 0.25 && pearliteNum <= 0.3)
{
level = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (pearliteNum > 0.2 && pearliteNum <= 0.25)
{
level = PdnResources.GetString("Menu.bead.Text") + "20";
}
else if (pearliteNum > 0.15 && pearliteNum <= 0.2)
{
level = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (pearliteNum > 0.1 && pearliteNum <= 0.15)
{
level = PdnResources.GetString("Menu.bead.Text") + "10";
}
else if (pearliteNum > 0 && pearliteNum <= 0.1)
{
level = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
level = "-";
}
}
else
{
if (pearliteNum > 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (pearliteNum > 0.8 && pearliteNum <= 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (pearliteNum > 0.7 && pearliteNum <= 0.8)
{
level = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (pearliteNum > 0.6 && pearliteNum <= 0.7)
{
level = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (pearliteNum > 0.5 && pearliteNum <= 0.6)
{
level = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (pearliteNum > 0.4 && pearliteNum <= 0.5)
{
level = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (pearliteNum > 0.3 && pearliteNum <= 0.4)
{
level = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (pearliteNum > 0.2 && pearliteNum <= 0.3)
{
level = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (pearliteNum > 0.1 && pearliteNum <= 0.2)
{
level = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (pearliteNum > 0 && pearliteNum <= 0.1)
{
level = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
level = "-";
}
}
this.dataGridView1.Rows.Add($"{PdnResources.GetString("Menu.view.text")}{h}", pearliteNum * 100, level);
pearliteNumSum += pearliteNum;
}
if (sumFieldl > 1)
{
string avgLevel = string.Empty;
double avgPearliteNum = pearliteNumSum / sumFieldl;
if (IronType == 1)
{
if (avgPearliteNum > 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (avgPearliteNum > 0.8 && avgPearliteNum <= 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (avgPearliteNum > 0.7 && avgPearliteNum <= 0.8)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (avgPearliteNum > 0.6 && avgPearliteNum <= 0.7)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (avgPearliteNum > 0.5 && avgPearliteNum <= 0.6)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (avgPearliteNum > 0.4 && avgPearliteNum <= 0.5)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (avgPearliteNum > 0.3 && avgPearliteNum <= 0.4)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (avgPearliteNum > 0.25 && avgPearliteNum <= 0.3)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (avgPearliteNum > 0.2 && avgPearliteNum <= 0.25)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "20";
}
else if (avgPearliteNum > 0.15 && avgPearliteNum <= 0.2)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (avgPearliteNum > 0.1 && avgPearliteNum <= 0.15)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "10";
}
else if (avgPearliteNum > 0 && avgPearliteNum <= 0.1)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
avgLevel = "-";
}
}
else
{
if (avgPearliteNum > 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (avgPearliteNum > 0.8 && avgPearliteNum <= 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (avgPearliteNum > 0.7 && avgPearliteNum <= 0.8)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (avgPearliteNum > 0.6 && avgPearliteNum <= 0.7)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (avgPearliteNum > 0.5 && avgPearliteNum <= 0.6)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (avgPearliteNum > 0.4 && avgPearliteNum <= 0.5)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (avgPearliteNum > 0.3 && avgPearliteNum <= 0.4)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (avgPearliteNum > 0.2 && avgPearliteNum <= 0.3)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (avgPearliteNum > 0.1 && avgPearliteNum <= 0.2)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (avgPearliteNum > 0 && avgPearliteNum <= 0.1)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
avgLevel = "-";
}
}
this.dataGridView1.Rows.Add(PdnResources.GetString("Menu.Image.Average.Text"), 100 * avgPearliteNum, avgLevel);
}
}
else
{
OpenCvSharp.Point[][] contours;//原始轮廓信息
HierarchyIndex[] hierachy;
Mat tempCopy = BinaryClass.BGRA2GRAY(binarizationMat);
Cv2.FindContours(BinaryClass.BGRA2GRAY(binarizationMat), out contours, out hierachy, RetrievalModes.CComp, ContourApproximationModes.ApproxNone);
double totalAreaSum = 0;//面积总数
double screenArea = 0;
for (int i = 0; i < hierachy.Length; i++)
{
if (hierachy[i].Parent == -1)
{
double radius; //外接圆半径
double area = appCommon.Area(tempCopy, contours[i][0]);
double equalDiameter = Math.Sqrt(area / Math.PI) * 2 * unitLength;
if (this.checkBox3.Checked)
{
if (this.checkBox6.Checked)
{
if (equalDiameter < 20)
{
ps.Add(contours[i].ToList());
continue;
}
if (area >= (this.trackBar2.Value / (unitLength * unitLength)) && area <= (this.trackBar4.Value / (unitLength * unitLength)))
{
ps.Add(contours[i].ToList());
}
else
{
if (contours[i].Length < 5)
{
continue;
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
}
else
{
if (area >= (this.trackBar2.Value / (unitLength * unitLength)) && area <= (this.trackBar4.Value / (unitLength * unitLength)))
{
ps.Add(contours[i].ToList());
}
else
{
if (contours[i].Length < 5)
{
continue;
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
}
}
else
{
if (this.checkBox6.Checked)
{
if (equalDiameter < 20)
{
ps.Add(contours[i].ToList());
}
}
if (contours[i].Length < 5)
continue;
else
{
if (this.checkBox6.Checked)
{
//if (equalDiameter < 20)
//{
// ps.Add(contours[i].ToList());
//}
if (equalDiameter >= 20)
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio > 0 && areaRatio <= 1)
{
totalAreaSum += area;
if (areaRatio * 100 >= this.trackBar5.Value && areaRatio * 100 <= this.trackBar6.Value)
{
screenArea += area;
}
else
{
lstScreenArea.Add(area * unitLength * unitLength);
lstScreenAreaRatio.Add(areaRatio);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(areaRatio.ToString()) ? "0" :
areaRatio.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (areaRatio > 0.8 && areaRatio <= 1)
{
lstPoint08_1.Add(contours[i].ToList());
}
else if (areaRatio > 0.6 && areaRatio <= 0.8)
{
lstPoint06_08.Add(contours[i].ToList());
}
else if (areaRatio > 0.4 && areaRatio <= 0.6)
{
lstPoint04_06.Add(contours[i].ToList());
}
else if (areaRatio > 0.2 && areaRatio <= 0.4)
{
lstPoint02_04.Add(contours[i].ToList());
}
else if (areaRatio > 0.1 && areaRatio <= 0.2)
{
lstPoint01_02.Add(contours[i].ToList());
}
else if (areaRatio > 0 && areaRatio <= 0.1)
{
lstPoint0_01.Add(contours[i].ToList());
}
}
else
{
ps.Add(contours[i].ToList());
}
}
}
}
}
}
string level = string.Empty; //球化级别
double pearliteNum = (totalAreaSum - screenArea) / (picArea - screenArea); //珠光体数量
if (IronType == 1)
{
if (pearliteNum > 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (pearliteNum > 0.8 && pearliteNum <= 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (pearliteNum > 0.7 && pearliteNum <= 0.8)
{
level = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (pearliteNum > 0.6 && pearliteNum <= 0.7)
{
level = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (pearliteNum > 0.5 && pearliteNum <= 0.6)
{
level = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (pearliteNum > 0.4 && pearliteNum <= 0.5)
{
level = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (pearliteNum > 0.3 && pearliteNum <= 0.4)
{
level = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (pearliteNum > 0.25 && pearliteNum <= 0.3)
{
level = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (pearliteNum > 0.2 && pearliteNum <= 0.25)
{
level = PdnResources.GetString("Menu.bead.Text") + "20";
}
else if (pearliteNum > 0.15 && pearliteNum <= 0.2)
{
level = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (pearliteNum > 0.1 && pearliteNum <= 0.15)
{
level = PdnResources.GetString("Menu.bead.Text") + "10";
}
else if (pearliteNum > 0 && pearliteNum <= 0.1)
{
level = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
level = "-";
}
}
else
{
if (pearliteNum > 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (pearliteNum > 0.8 && pearliteNum <= 0.9)
{
level = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (pearliteNum > 0.7 && pearliteNum <= 0.8)
{
level = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (pearliteNum > 0.6 && pearliteNum <= 0.7)
{
level = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (pearliteNum > 0.5 && pearliteNum <= 0.6)
{
level = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (pearliteNum > 0.4 && pearliteNum <= 0.5)
{
level = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (pearliteNum > 0.3 && pearliteNum <= 0.4)
{
level = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (pearliteNum > 0.2 && pearliteNum <= 0.3)
{
level = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (pearliteNum > 0.1 && pearliteNum <= 0.2)
{
level = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (pearliteNum > 0 && pearliteNum <= 0.1)
{
level = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
level = "-";
}
}
if (pointList.Count > 0)
{
this.dataGridView1.Rows.Add(PdnResources.GetString("Menu.view.text")+"1", pearliteNum * 100, level);
}
}
binarizationMat.CopyTo(temp);
if (checkBox4.Checked)
{
DisplayColor();
}
if (checkBox5.Checked && !bcOriginChecked())
{
AddPictureBoxEvent();
}
Cv2.FillPoly(temp, ps, new Scalar(0, 0, 0, 0)); //筛选颜色
phaseModel.mat = temp;
//RefreshDataGridView1();
this.documentWorkspace.Refresh();
//数据结果保存
dtDataGridView1 = appCommon.ResultDataSaving(dataGridView1);
string imgName = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GetFriendlyName();
string tag = this.imageList1.Images.Keys[this.listView1.FocusedItem.Index];
//dtResult = new DataTable(tag);
//分析数据保存
dtResult = appCommon.AnalysisDataSaving(dataGridView1, imgName, tag);
if (dtDataGridView1.Rows.Count > 0)
{
RefreshDataGridView1();
}
if (bcOriginChecked())
{
appCommonDisplay.DisplayData(this.dataGridView1, false);
}
}
}
///
/// 显示不同颜色方法
///
public void DisplayColor()
{
//this.documentWorkspace.PhaseModels[0].choise = false;
//填充颜色
if (this.checkBox4.Checked)
{
Mat[] arr = temp.Split();
temp = temp.CvtColor(ColorConversionCodes.BGRA2BGR);
for (int i = 0; i < lstPoint08_1.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint08_1[i][lstPoint08_1[i].Count - 1], new Scalar(colour["panelColour1_08"].B, colour["panelColour1_08"].G, colour["panelColour1_08"].R));
}
for (int i = 0; i < lstPoint06_08.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint06_08[i][lstPoint06_08[i].Count - 1], new Scalar(colour["panelColour08_06"].B, colour["panelColour08_06"].G, colour["panelColour08_06"].R));
}
for (int i = 0; i < lstPoint04_06.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint04_06[i][lstPoint04_06[i].Count - 1], new Scalar(colour["panelColour06_04"].B, colour["panelColour06_04"].G, colour["panelColour06_04"].R));
}
for (int i = 0; i < lstPoint02_04.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint02_04[i][lstPoint02_04[i].Count - 1], new Scalar(colour["panelColour04_02"].B, colour["panelColour04_02"].G, colour["panelColour04_02"].R));
}
for (int i = 0; i < lstPoint01_02.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint01_02[i][lstPoint01_02[i].Count - 1], new Scalar(colour["panelColour02_01"].B, colour["panelColour02_01"].G, colour["panelColour02_01"].R));
}
for (int i = 0; i < lstPoint0_01.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint0_01[i][lstPoint0_01[i].Count - 1], new Scalar(colour["panelColour01_0"].B, colour["panelColour01_0"].G, colour["panelColour01_0"].R));
}
Mat[] arr2 = temp.Split();
arr[0] = arr2[0];
arr[1] = arr2[1];
arr[2] = arr2[2];
Cv2.Merge(arr, temp);
phaseModel.mat = temp;
}
this.documentWorkspace.Refresh();
}
///
/// 添加内容单元格
///
///
///
///
private DataGridViewTextBoxCell CreateTextBoxCell(string text, object tag)
{
DataGridViewTextBoxCell textboxcell = new DataGridViewTextBoxCell();
textboxcell.Value = text;
textboxcell.Tag = tag;
return textboxcell;
}
///
/// 刷新其他信息
///
private void ResetAreaAndContent()
{
if (binarizationMat != null && bcBinaryChecked())
{
OpenCvSharp.Point[][] contours;//原始轮廓信息
HierarchyIndex[] hierachy;
Mat tempCopy = BinaryClass.BGRA2GRAY(binarizationMat);
//Mat temp = new Mat();
//binarizationMat.CopyTo(temp);
Cv2.FindContours(BinaryClass.BGRA2GRAY(binarizationMat), out contours, out hierachy, RetrievalModes.CComp, ContourApproximationModes.ApproxNone);
if (hierachy.Length > 0)
{
double maxArea = 0;//面积最大值
double minArea = 9999999999;//面积最小值
double maxAreaRatio = 0;//面积率最大值
double minAreaRatio = 100;//面积率最小值
double radius = 0;//外接圆半径
double area = 0;
for (int i = 0; i < hierachy.Length; i++)
{
if (hierachy[i].Parent == -1)
{
area = appCommon.Area(tempCopy, contours[i][0]);
if (maxArea < area)
maxArea = area;
if (minArea > area)
minArea = area;
}
if (contours[i].Length < 5)
continue;
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
radius = BasicCalculationHelper.CalcLongTrail(contours[i]);
double outerCircle = radius * radius * Math.PI;//外接圆面积
double areaRatio = (area - contours[i].Length / 2.0) / outerCircle;
if (areaRatio >= 0 && areaRatio <= 1)
{
if (maxAreaRatio < areaRatio * 100)
maxAreaRatio = areaRatio * 100;
if (minAreaRatio > areaRatio * 100)
minAreaRatio = areaRatio * 100;
}
}
}
//phaseModel.mat = temp;
if (!changeColor)
{
maxArea = maxArea * unitLength * unitLength;
minArea = minArea * unitLength * unitLength;
//maxAreaRatio = maxAreaRatio;
//minAreaRatio = minAreaRatio;
int maxNum = (int)Math.Ceiling(maxArea);//获取面积最大值
int minNum = (int)Math.Floor(minArea);//获取面积最小值
int maxNumRatio = (int)Math.Ceiling(maxAreaRatio);//获取面积率最大值
int minNumRatio = (int)Math.Floor(minAreaRatio);//获取面积率最小值
//先解绑事件以防数据赋值异常
this.numericUpDown4.ValueChanged -= numericUpDown4_ValueChanged;
this.numericUpDown5.ValueChanged -= numericUpDown5_ValueChanged;
this.numericUpDown6.ValueChanged -= numericUpDown6_ValueChanged;
this.numericUpDown7.ValueChanged -= numericUpDown7_ValueChanged;
this.trackBar2.Scroll -= trackBar2_Scroll;
this.trackBar4.Scroll -= trackBar4_Scroll;
this.trackBar5.Scroll -= trackBar5_Scroll;
this.trackBar6.Scroll -= trackBar6_Scroll;
this.numericUpDown4.Maximum = maxNum;
this.numericUpDown4.Minimum = minNum;
this.trackBar2.Maximum = maxNum;
this.trackBar2.Minimum = minNum;
this.numericUpDown5.Maximum = maxNum;
this.numericUpDown5.Minimum = minNum;
this.trackBar4.Maximum = maxNum;
this.trackBar4.Minimum = minNum;
this.numericUpDown4.Value = minNum;
this.trackBar2.Value = minNum;
this.numericUpDown5.Value = maxNum;
this.trackBar4.Value = maxNum;
if (maxNumRatio != 0 || minNumRatio != 100)
{
this.numericUpDown6.Maximum = maxNumRatio;
this.numericUpDown6.Minimum = minNumRatio;
this.trackBar5.Maximum = maxNumRatio;
this.trackBar5.Minimum = minNumRatio;
this.numericUpDown7.Maximum = maxNumRatio;
this.numericUpDown7.Minimum = minNumRatio;
this.trackBar6.Maximum = maxNumRatio;
this.trackBar6.Minimum = minNumRatio;
if (maxNumRatio > 60 && minNumRatio < 60)
{
this.trackBar5.Value = 60;
this.numericUpDown6.Value = 60;
}
this.numericUpDown7.Value = maxNumRatio;
this.trackBar6.Value = maxNumRatio;
}
if (areaRatioRangeMin != -1 && areaRatioRangeMin >= this.numericUpDown6.Minimum && areaRatioRangeMin <= this.numericUpDown7.Maximum)
{
trackBar5.Value = (int)areaRatioRangeMin;
this.numericUpDown6.Value = areaRatioRangeMin;
}
if (areaRatioRangeMax != -1 && areaRatioRangeMax >= this.numericUpDown6.Value && areaRatioRangeMax <= this.numericUpDown7.Maximum)
{
trackBar6.Value = (int)areaRatioRangeMax;
this.numericUpDown7.Value = areaRatioRangeMax;
}
if (areaMin != -1 && areaMin >= this.numericUpDown4.Minimum && areaMin <= this.numericUpDown5.Maximum)
{
trackBar2.Value = (int)areaMin;
this.numericUpDown4.Value = areaMin;
}
if (areaMax != -1 && areaMax >= this.numericUpDown4.Value && areaMax <= this.numericUpDown5.Maximum)
{
trackBar4.Value = (int)areaMax;
this.numericUpDown5.Value = areaMax;
}
this.numericUpDown4.ValueChanged += new EventHandler(numericUpDown4_ValueChanged);
this.numericUpDown5.ValueChanged += new EventHandler(numericUpDown5_ValueChanged);
this.numericUpDown6.ValueChanged += new EventHandler(numericUpDown6_ValueChanged);
this.numericUpDown7.ValueChanged += new EventHandler(numericUpDown7_ValueChanged);
this.trackBar2.Scroll += new EventHandler(trackBar2_Scroll);
this.trackBar4.Scroll += new EventHandler(trackBar4_Scroll);
this.trackBar5.Scroll += new EventHandler(trackBar5_Scroll);
this.trackBar6.Scroll += new EventHandler(trackBar6_Scroll);
//RefreshDataGridView1();
}
}
else
{
this.trackBar2.Maximum = 0;
this.trackBar2.Minimum = 0;
this.trackBar4.Maximum = 0;
this.trackBar4.Minimum = 0;
this.trackBar5.Maximum = 0;
this.trackBar5.Minimum = 0;
this.trackBar6.Maximum = 0;
this.trackBar6.Minimum = 0;
this.numericUpDown4.Maximum = 0;
this.numericUpDown4.Minimum = 0;
this.numericUpDown5.Maximum = 0;
this.numericUpDown5.Minimum = 0;
this.numericUpDown6.Maximum = 0;
this.numericUpDown6.Minimum = 0;
this.numericUpDown7.Maximum = 0;
this.numericUpDown7.Minimum = 0;
}
}
}
///
/// 小数数字框值改变
///
///
///
private void numericUpDown1_ValueChanged(object sender, EventArgs e)
{
if (this.numericUpDown1.Value > this.numericUpDown1.Maximum)
this.numericUpDown1.Value = this.numericUpDown1.Maximum;
if (this.numericUpDown1.Value < this.numericUpDown1.Minimum)
this.numericUpDown1.Value = this.numericUpDown1.Minimum;
RefreshDataGridView1();
RefreshDataGridView2();
ReloadDebrisSelection();
}
///
/// 是否筛选
///
///
///
private void checkBox3_CheckedChanged(object sender, EventArgs e)
{
if (this.documentWorkspace == null || this.documentWorkspace.CompositionSurface == null)
return;
ResetAreaAndContent();
ReloadDebrisSelection();
}
///
/// 颗粒筛选范围最小值
///
///
///
private void numericUpDown4_ValueChanged(object sender, EventArgs e)
{
if (this.numericUpDown4.Value > this.numericUpDown5.Value)
this.numericUpDown4.Value = this.numericUpDown5.Value;
this.trackBar2.Value = Convert.ToInt32(this.numericUpDown4.Value);
areaMin = this.numericUpDown4.Value;
areaMax = this.numericUpDown5.Value;
//二值判断
if (this.checkBox3.Checked && bcBinaryChecked() && !this.checkBox4.Checked)
{
ReloadDebrisSelection();
}
if (this.checkBox3.Checked && bcBinaryChecked() && this.checkBox4.Checked)
{
ReloadDebrisSelection();
}
}
///
/// 颗粒筛选范围最大值
///
///
///
private void numericUpDown5_ValueChanged(object sender, EventArgs e)
{
if (this.numericUpDown5.Value < this.numericUpDown4.Value)
this.numericUpDown5.Value = this.numericUpDown4.Value;
this.trackBar4.Value = Convert.ToInt32(this.numericUpDown5.Value);
areaMin = this.numericUpDown4.Value;
areaMax = this.numericUpDown5.Value;
//二值判断
if (this.checkBox3.Checked && bcBinaryChecked() && !this.checkBox4.Checked)
{
ReloadDebrisSelection();
}
if (this.checkBox3.Checked && bcBinaryChecked() && this.checkBox4.Checked)
{
ReloadDebrisSelection();
}
}
///
/// 颗粒筛选最小值滚动条
///
///
///
private void trackBar2_Scroll(object sender, EventArgs e)
{
this.numericUpDown4.Value = this.trackBar2.Value;
}
///
/// 颗粒筛选最大值滚动条
///
///
///
private void trackBar4_Scroll(object sender, EventArgs e)
{
this.numericUpDown5.Value = this.trackBar4.Value;
}
///
/// 石墨面积率区间最小
///
///
///
private void numericUpDown6_ValueChanged(object sender, EventArgs e)
{
if (this.numericUpDown6.Value > this.numericUpDown7.Value)
this.numericUpDown6.Value = this.numericUpDown7.Value;
this.trackBar5.Value = Convert.ToInt32(this.numericUpDown6.Value);
areaRatioRangeMin = this.numericUpDown6.Value;
areaRatioRangeMax = this.numericUpDown7.Value;
ReloadDebrisSelection();
}
///
/// 石墨面积率区间最大
///
///
///
private void numericUpDown7_ValueChanged(object sender, EventArgs e)
{
if (this.numericUpDown7.Value < this.numericUpDown6.Value)
this.numericUpDown7.Value = this.numericUpDown6.Value;
this.trackBar6.Value = Convert.ToInt32(this.numericUpDown7.Value);
areaRatioRangeMin = this.numericUpDown6.Value;
areaRatioRangeMax = this.numericUpDown7.Value;
ReloadDebrisSelection();
}
///
/// 石墨面积率最小值滚动条
///
///
///
private void trackBar5_Scroll(object sender, EventArgs e)
{
this.numericUpDown6.Value = this.trackBar5.Value;
}
///
/// 石墨面积率最大值滚动条
///
///
///
private void trackBar6_Scroll(object sender, EventArgs e)
{
this.numericUpDown7.Value = this.trackBar6.Value;
}
///
/// 显示不同颜色
///
///
///
private void checkBox4_CheckedChanged(object sender, EventArgs e)
{
ReloadDebrisSelection();
}
///
/// 添加画布绑定事件
///
public void AddPictureBoxEvent()
{
this.documentWorkspace.panel.Paint -= new PaintEventHandler(this.BoxPaintHandler);
this.documentWorkspace.panel.Paint += new PaintEventHandler(this.BoxPaintHandler);
}
///
/// 绘制事件
///
///
///
private void BoxPaintHandler(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;
e.Graphics.TranslateTransform(x, y);
e.Graphics.ScaleTransform((float)this.documentWorkspace.ScaleFactor.Ratio, (float)this.documentWorkspace.ScaleFactor.Ratio);
Draw(e.Graphics);
e.Graphics.ScaleTransform(1 / (float)this.documentWorkspace.ScaleFactor.Ratio, 1 / (float)this.documentWorkspace.ScaleFactor.Ratio);
e.Graphics.TranslateTransform(-x, -y);
}
}
///
/// 绘制
///
private void Draw(Graphics graphics)
{
graphics.SmoothingMode = SmoothingMode.AntiAlias;
Pen rectPen = new Pen(Color.Black);
rectPen.DashStyle = DashStyle.Custom;
float[] dashArray = { 2.0f, 3.0f };
rectPen.DashPattern = dashArray;
if (pointList.Count > 0 && leList.Count > 0)
{
for (int i = 0; i < pointList.Count; i++)
{
graphics.DrawString(leList[i].ToString(), new Font("宋体", float.Parse(colourFont.Keys.First()), System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))), new SolidBrush(colourFont.Values.First()), pointList[i].X, pointList[i].Y);
}
}
}
///
/// 显示面积率
///
///
///
private void checkBox5_CheckedChanged(object sender, EventArgs e)
{
if (bcBinaryChecked() && !bcOriginChecked())
{
if (checkBox5.Checked)
{
ReloadDebrisSelection();
this.documentWorkspace.Refresh();
}
else
{
this.documentWorkspace.panel.Paint -= new PaintEventHandler(this.BoxPaintHandler);
this.documentWorkspace.Refresh();
}
}
}
///
/// 等积圆直径小于20um的颗粒不参与计算
///
///
///
private void checkBox6_CheckedChanged(object sender, EventArgs e)
{
ReloadDebrisSelection();
}
DialogResult dr;
///
/// 保存结果
///
///
///
private void button2_Click(object sender, EventArgs e)
{
if (picArea == 0)
{
MessageBox.Show(PdnResources.GetString("Menu.Pleaseselectapicture.text")+"!");
return;
}
else
{
//二值判断
if (!bcBinaryChecked())
{
MessageBox.Show(PdnResources.GetString("Menu.PleaseBinarize.text")+"!");
return;
}
}
if (this.listView1.SelectedItems.Count > 0)
{
string imgName = this.appWorkspace.DocumentWorkspaces[this.listView1.FocusedItem.Index].GetFriendlyName();
string tag = this.imageList1.Images.Keys[this.listView1.SelectedItems[0].Index];
bool replace = false;
int rowIndex = 0;
if (this.dataGridView1.Rows.Count > 0 && dataGridView1.Rows[0].Visible)
{
if (this.listView2.Items.Count > 0)
{
foreach (ListViewItem item in this.listView2.Items)
{
if (!blSaveAll && item.Name.Equals(tag))
{
dr = MessageBox.Show(PdnResources.GetString("Menu.Theanalysisreertoreplaceit.text") + "?", PdnResources.GetString("Menu.hint.text"), MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
break;
}
}
foreach (ListViewItem item in this.listView2.Items)
{
if (item.Name.Equals(tag))
{
if (dr == DialogResult.OK || blSaveAll)
{
replace = true;
}
else
{
return;
}
break;
}
}
}
//添加结果,有重名需要替换
if (replace)
{
for (int i = 0; i < this.resultTableList.Count; i++)
{
if (this.resultTableList[i].TableName.Equals(tag))
{
rowIndex = i;
this.resultTableList.Remove(this.resultTableList[i]);
if (this.pointList.Count > 0)
{
resultTableList.Insert(rowIndex, dtResult);
}
}
}
}
else
{
ListViewItem listViewItem = new ListViewItem();
listViewItem.Name = tag;
listViewItem.SubItems[0].Text = imgName;
this.listView2.Items.Add(listViewItem);
this.listView2.SelectedItems.Clear();
this.listView2.Items[this.listView2.Items.Count - 1].Selected = true;
if (this.pointList.Count > 0)
{
resultTableList.Insert(rowIndex, dtResult);
}
}
RefreshDataGridView2();
//保存处理后的图片
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 = BitmapConverter.ToBitmap(phaseModel.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));
if (this.checkBox4.Checked)
{
DisplayColor();
}
if (this.checkBox5.Checked)
{
Draw(graphics);
}
newBit.Tag = pantographRatio;
tempBit.Add(newBit);
if (bitDic.ContainsKey(tag))
bitDic[tag] = tempBit;
else
bitDic.Add(tag, tempBit);
//拼接中间数据
List> dataList = new List>();
List columnName = new List();
columnName.Add(PdnResources.GetString("Menu.Imagement.Measurementlist.ordernumber.text"));
columnName.Add(PdnResources.GetString("Menu.Pearlitearea.Text"));
columnName.Add(PdnResources.GetString("Menu.Pearliteareay.Text"));
dataList.Add(columnName);
if (this.lstScreenArea.Count > 0)
{
for (int i = 0; i < this.lstScreenArea.Count; i++)
{
List strList = new List();
strList.Add((i + 1).ToString());
strList.Add(this.lstScreenArea[i].ToString());
strList.Add(this.lstScreenAreaRatio[i].ToString());
dataList.Add(strList);
}
}
bool isExist = false;//是否已存在进行替换
int modelIndex = -1;//要替换的下标
for (int j = 0; j < tempDataModel.Count; j++)
{
if (tempDataModel[j].tagName.Equals(tag))
{
isExist = true;
modelIndex = j;
break;
}
}
if (isExist && modelIndex > -1)
tempDataModel[modelIndex].dataList = dataList;
else
{
ExportProjectModel newModel = new ExportProjectModel();
newModel.tagName = tag;
newModel.picName = imgName;
newModel.dataList = dataList;
tempDataModel.Add(newModel);
}
}
else
{
MessageBox.Show(PdnResources.GetString("Menu.Nodatatosave.text"));
}
}
}
///
/// 刷新数据展示表
///
private void RefreshDataGridView1()
{
this.dataGridView1.Rows.Clear();
if (dtDataGridView1 != null && dtDataGridView1.Rows.Count > 0)
{
dataGridView1.Rows.Add(dtDataGridView1.Rows.Count);//增加同等数量的行数
int i = 0;
foreach (DataRow row in dtDataGridView1.Rows)//逐个读取单元格的内容;
{
DataGridViewRow r1 = dataGridView1.Rows[i];
r1.Cells[0].Value = row.RowState.ToString();
for (int j = 0; j < dtDataGridView1.Columns.Count; j++)
{
if (j == 0 || j == 2)
{
r1.Cells[j].Value = row[j].ToString();
}
else
{
r1.Cells[j].Value = Math.Round(double.Parse(string.IsNullOrEmpty(row[j].ToString()) ? "0" :
row[j].ToString()), Convert.ToInt32(this.numericUpDown1.Value));
}
}
i++;
}
}
}
///
/// 刷新分析结果表
///
private void RefreshDataGridView2()
{
//需要计算平均值的集合
List lstPearliteNum = new List();
//综合平均值
double avgPearliteNum = 0;
if (resultTableList.Count > 0)
{
dataGridView2.Rows.Clear();
dataGridView3.Rows.Clear();
if (this.showAll)
{
//dataGridView2.Rows.Clear();
int i = 0;
for (int k = 0; k < resultTableList.Count; k++)
{
dataGridView2.Rows.Add(resultTableList[k].Rows.Count);//增加同等数量的行数
foreach (DataRow row in resultTableList[k].Rows)//逐个读取单元格的内容;
{
DataGridViewRow r1 = dataGridView2.Rows[i];
r1.Cells[0].Value = row.RowState.ToString();
for (int j = 0; j < resultTableList[k].Columns.Count; j++)
{
if (j == 0 || j == 1 || j == 3)
{
r1.Cells[j].Value = row[j].ToString();
}
else
{
r1.Cells[j].Value = Math.Round(double.Parse(string.IsNullOrEmpty(row[j].ToString()) ? "0" :
row[j].ToString()), Convert.ToInt32(this.numericUpDown1.Value));
}
//r1.Cells[j].Value = row[j];
if (!row[1].Equals(PdnResources.GetString("Menu.Image.Average.Text")))
{
if (j == 2)
{
lstPearliteNum.Add(double.Parse(row[j].ToString()));
}
}
}
i++;
}
}
}
else
{
//dataGridView2.Rows.Clear();
if (this.listView2.SelectedItems != null && this.listView2.SelectedItems.Count > 0)
{
int h = 0;
for (int i = 0; i < this.listView2.SelectedItems.Count; i++)
{
string tableName = this.listView2.SelectedItems[i].Name;
foreach (DataTable dt in resultTableList)
{
if (dt.TableName.Equals(tableName))
{
dataGridView2.Rows.Add(dt.Rows.Count);//增加同等数量的行数
foreach (DataRow row in dt.Rows)//逐个读取单元格的内容;
{
DataGridViewRow r1 = dataGridView2.Rows[h];
r1.Cells[0].Value = row.RowState.ToString();
for (int j = 0; j < dt.Columns.Count; j++)
{
if (j == 0 || j == 1 || j == 3)
{
r1.Cells[j].Value = row[j].ToString();
}
else
{
r1.Cells[j].Value = Math.Round(double.Parse(string.IsNullOrEmpty(row[j].ToString()) ? "0" :
row[j].ToString()), Convert.ToInt32(this.numericUpDown1.Value));
}
//r1.Cells[j].Value = row[j];
if (!row[1].Equals(PdnResources.GetString("Menu.Image.Average.Text")))
{
if (j == 2)
{
lstPearliteNum.Add(double.Parse(row[j].ToString()));
}
}
}
h++;
}
}
}
}
}
}
if (dataGridView2.Rows.Count > 0)
{
if (lstPearliteNum.Count > 0)
{
avgPearliteNum = (double)lstPearliteNum.Average();
}
string avgLevel = string.Empty;
if (IronType == 1)
{
if (avgPearliteNum / 100 > 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (avgPearliteNum / 100 > 0.8 && avgPearliteNum / 100 <= 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (avgPearliteNum / 100 > 0.7 && avgPearliteNum / 100 <= 0.8)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (avgPearliteNum / 100 > 0.6 && avgPearliteNum / 100 <= 0.7)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (avgPearliteNum / 100 > 0.5 && avgPearliteNum / 100 <= 0.6)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (avgPearliteNum / 100 > 0.4 && avgPearliteNum / 100 <= 0.5)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (avgPearliteNum / 100 > 0.3 && avgPearliteNum / 100 <= 0.4)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (avgPearliteNum / 100 > 0.25 && avgPearliteNum / 100 <= 0.3)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (avgPearliteNum / 100 > 0.2 && avgPearliteNum / 100 <= 0.25)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "20";
}
else if (avgPearliteNum / 100 > 0.15 && avgPearliteNum / 100 <= 0.2)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (avgPearliteNum / 100 > 0.1 && avgPearliteNum / 100 <= 0.15)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "10";
}
else if (avgPearliteNum / 100 > 0 && avgPearliteNum / 100 <= 0.1)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
avgLevel = "-";
}
}
else
{
if (avgPearliteNum / 100 > 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "95";
}
else if (avgPearliteNum / 100 > 0.8 && avgPearliteNum / 100 <= 0.9)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "85";
}
else if (avgPearliteNum / 100 > 0.7 && avgPearliteNum / 100 <= 0.8)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "75";
}
else if (avgPearliteNum / 100 > 0.6 && avgPearliteNum / 100 <= 0.7)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "65";
}
else if (avgPearliteNum / 100 > 0.5 && avgPearliteNum / 100 <= 0.6)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "55";
}
else if (avgPearliteNum / 100 > 0.4 && avgPearliteNum / 100 <= 0.5)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "45";
}
else if (avgPearliteNum / 100 > 0.3 && avgPearliteNum / 100 <= 0.4)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "35";
}
else if (avgPearliteNum / 100 > 0.2 && avgPearliteNum / 100 <= 0.3)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "25";
}
else if (avgPearliteNum / 100 > 0.1 && avgPearliteNum / 100 <= 0.2)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "15";
}
else if (avgPearliteNum / 100 > 0 && avgPearliteNum / 100 <= 0.1)
{
avgLevel = PdnResources.GetString("Menu.bead.Text") + "5";
}
else
{
avgLevel = "-";
}
}
this.dataGridView3.Rows.Add(PdnResources.GetString("Menu.comprehensive.text"), PdnResources.GetString("Menu.Comprehensivaverage.text"), Math.Round(double.Parse(string.IsNullOrEmpty(avgPearliteNum.ToString()) ? "0" : avgPearliteNum.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), avgLevel);
}
}
else
{
dataGridView2.Rows.Clear();
dataGridView3.Rows.Clear();
}
}
///
/// 生成报告
///
///
///
private void button8_Click(object sender, EventArgs e)
{
if (dataGridView2.Rows.Count == 0)
{
MessageBox.Show(PdnResources.GetString("Menu.Noanalysineratereport.text")+"!");
return;
}
if (this.checkBox1.Checked)
this.btnSetUp.PerformClick();
if (this.analyzeSettingModel != null && !string.IsNullOrEmpty(this.analyzeSettingModel.analyzeClassify))
{
//获取word书签与excel单元格的关系,以字典方式存储
List mic_module_infos = mic_module_infos_BLL.FindAll().FindAll(a => a.analyze_classify == this.analyzeSettingModel.analyzeClassify);
Dictionary tagInfos = new Dictionary();
if (mic_module_infos != null && mic_module_infos.Count > 0)
{
foreach (mic_module_infos info in mic_module_infos)
{
tagInfos.Add(info.tag_name, info.cell_position);
}
}
//分析结果
List> analysisContent = new List>();
List contentHead = new List();
contentHead.Add(PdnResources.GetString("Menu.picture.Text"));
contentHead.Add(PdnResources.GetString("Menu.view.text"));
contentHead.Add(PdnResources.GetString("Menu.Numberofpearlite.Text")+ "(%)");
contentHead.Add(PdnResources.GetString("Menu.Levelname.text"));
analysisContent.Add(contentHead);
foreach (DataGridViewRow item in this.dataGridView2.Rows)
{
List content = new List();
content.Add(item.Cells[0].Value.ToString());
content.Add(item.Cells[1].Value.ToString());
content.Add(item.Cells[2].Value.ToString());
content.Add(item.Cells[3].Value.ToString());
analysisContent.Add(content);
}
analysisContent.Add(new List() { "\r" });
foreach (DataGridViewRow item in this.dataGridView3.Rows)
{
List content = new List();
content.Add(item.Cells[0].Value.ToString());
content.Add(item.Cells[1].Value.ToString());
content.Add(item.Cells[2].Value.ToString());
content.Add(item.Cells[3].Value.ToString());
analysisContent.Add(content);
}
//图片
bitList = new List();
if (this.showAll)
{
foreach (KeyValuePair> kv in this.bitDic)
{
bitList.Add(kv.Value[0]);
bitList.Add(kv.Value[1]);
}
}
else
{
if (this.listView2.SelectedItems != null && this.listView2.SelectedItems.Count > 0)
{
foreach (ListViewItem item in this.listView2.SelectedItems)
{
if (bitDic.ContainsKey(item.Name))
{
bitList.Add(bitDic[item.Name][0]);
bitList.Add(bitDic[item.Name][1]);
}
}
}
}
this.appWorkspace.CreateAnalysisReport(this.analyzeSettingModel, analysisContent, bitList, tagInfos);
}
else
MessageBox.Show(PdnResources.GetString("Menu.Pleasesettheanalysisreportfirst.text")+"!");
}
///
/// 导出项目
///
///
///
private void button1_Click(object sender, EventArgs e)
{
if (dataGridView2.Rows.Count == 0)
{
MessageBox.Show(PdnResources.GetString("Menu.Noanalysineratereport.text")+"!");
return;
}
if (this.checkBox1.Checked)
this.btnSetUp.PerformClick();
if (this.analyzeSettingModel != null && !string.IsNullOrEmpty(this.analyzeSettingModel.analyzeClassify))
{
PaintDotNet.Instrument.ProjectEngineering.NodeItem nodeItem = this.appWorkspace.GetInsertProjectPath(2, "Menu.DedicatedAnalysis.BlackMetal.DuctileIron.Text", this.analyzeSettingModel.savePath);
if (nodeItem == null) return;
//获取word书签与excel单元格的关系,以字典方式存储
List mic_module_infos = mic_module_infos_BLL.FindAll().FindAll(a => a.analyze_classify == this.analyzeSettingModel.analyzeClassify);
Dictionary tagInfos = new Dictionary();
if (mic_module_infos != null && mic_module_infos.Count > 0)
{
foreach (mic_module_infos info in mic_module_infos)
{
tagInfos.Add(info.tag_name, info.cell_position);
}
}
//分析结果
List> analysisContent = new List>();
List contentHead = new List();
contentHead.Add(PdnResources.GetString("Menu.picture.Text"));
contentHead.Add(PdnResources.GetString("Menu.view.text"));
contentHead.Add(PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)");
contentHead.Add(PdnResources.GetString("Menu.Levelname.text"));
analysisContent.Add(contentHead);
foreach (DataGridViewRow item in this.dataGridView2.Rows)
{
List content = new List();
content.Add(item.Cells[0].Value.ToString());
content.Add(item.Cells[1].Value.ToString());
content.Add(item.Cells[2].Value.ToString());
content.Add(item.Cells[3].Value.ToString());
analysisContent.Add(content);
}
analysisContent.Add(new List() { "\r" });
foreach (DataGridViewRow item in this.dataGridView3.Rows)
{
List content = new List();
content.Add(item.Cells[0].Value.ToString());
content.Add(item.Cells[1].Value.ToString());
content.Add(item.Cells[2].Value.ToString());
content.Add(item.Cells[3].Value.ToString());
analysisContent.Add(content);
}
//图片
bitList = new List();
if (this.showAll)
{
foreach (KeyValuePair> kv in this.bitDic)
{
bitList.Add(kv.Value[0]);
bitList.Add(kv.Value[1]);
}
}
else
{
if (this.listView2.SelectedItems != null && this.listView2.SelectedItems.Count > 0)
{
foreach (ListViewItem item in this.listView2.SelectedItems)
{
if (bitDic.ContainsKey(item.Name))
{
bitList.Add(bitDic[item.Name][0]);
bitList.Add(bitDic[item.Name][1]);
}
}
}
}
this.appWorkspace.CreateAnalysisReport(this.analyzeSettingModel, analysisContent, tempDataModel, bitList, tagInfos, nodeItem.path, nodeItem.code);
//保存项目信息到数据库
this.appWorkspace.InsertIntoDB(this.analyzeSettingModel, nodeItem);
}
else
MessageBox.Show(PdnResources.GetString("Menu.Pleasesettheanalysisreportfirst.text")+"!");
}
///
/// 导出结果
///
///
///
private void button9_Click(object sender, EventArgs e)
{
if (this.dataGridView2.Rows.Count > 0)
{
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);
if (IronType == 1)
{
exe.FileName = PdnResources.GetString("Menu.DedicatedAnalysis.BlackMetal.DuctileIron.Text")+"(GBT9441" + PdnResources.GetString("Menu.Numberofpearlite.Text")+ ")" + PdnResources.GetString("Menu.Analysisresult.text") + DateTime.Now.ToString("yyyyMMddHHmmss");
}
else if (IronType == 2)
{
exe.FileName = PdnResources.GetString("Menu.DedicatedAnalysis.BlackMetal.VermiculateCastIron.Text")+"(GBT26656" + PdnResources.GetString("Menu.Numberofpearlite.Text")+ ")" + PdnResources.GetString("Menu.Analysisresult.text") + DateTime.Now.ToString("yyyyMMddHHmmss");
}
else if (IronType == 3)
{
exe.FileName = PdnResources.GetString("Menu.DedicatedAnalysis.BlackMetal.VermiculateCastIron.Text")+"(JBT3829" + PdnResources.GetString("Menu.Numberofpearlite.Text")+ ")" + PdnResources.GetString("Menu.Analysisresult.text") + DateTime.Now.ToString("yyyyMMddHHmmss");
}
DialogResult dr = exe.ShowDialog();
if (dr != DialogResult.OK)
return;
DataTable dtb = new DataTable();
dtb.Columns.Add(PdnResources.GetString("Menu.picture.Text"));
dtb.Columns.Add(PdnResources.GetString("Menu.view.text"));
dtb.Columns.Add(PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)");
dtb.Columns.Add(PdnResources.GetString("Menu.Levelname.text"));
for (int i = 0; i < this.dataGridView2.Rows.Count; i++)
{
DataRow dataRow = dtb.NewRow();
dataRow[PdnResources.GetString("Menu.picture.Text")] = this.dataGridView2.Rows[i].Cells[0].Value;
dataRow[PdnResources.GetString("Menu.view.text")] = this.dataGridView2.Rows[i].Cells[1].Value;
dataRow[PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)"] = this.dataGridView2.Rows[i].Cells[2].Value;
dataRow[PdnResources.GetString("Menu.Levelname.text")] = this.dataGridView2.Rows[i].Cells[3].Value;
dtb.Rows.Add(dataRow);
}
for (int i = 0; i < this.dataGridView3.Rows.Count; i++)
{
DataRow dataRow = dtb.NewRow();
dataRow[PdnResources.GetString("Menu.picture.Text")] = this.dataGridView3.Rows[i].Cells[0].Value;
dataRow[PdnResources.GetString("Menu.view.text")] = this.dataGridView3.Rows[i].Cells[1].Value;
dataRow[PdnResources.GetString("Menu.Numberofpearlite.Text") + "(%)"] = this.dataGridView3.Rows[i].Cells[2].Value;
dataRow[PdnResources.GetString("Menu.Levelname.text")] = this.dataGridView3.Rows[i].Cells[3].Value;
dtb.Rows.Add(dataRow);
}
//DataTable dtb1 = new DataTable();
//dtb1.Columns.Add(PdnResources.GetString("Menu.picture.Text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.view.text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)");
//dtb1.Columns.Add(PdnResources.GetString("Menu.Levelname.text"));
//for (int i = 0; i < this.dataGridView3.Rows.Count; i++)
//{
// DataRow dataRow = dtb1.NewRow();
// dataRow[PdnResources.GetString("Menu.picture.Text")] = this.dataGridView3.Rows[i].Cells[0].Value;
// dataRow[PdnResources.GetString("Menu.view.text")] = this.dataGridView3.Rows[i].Cells[1].Value;
// dataRow[PdnResources.GetString("Menu.Numberofpearlite.Text")+"(%)"] = this.dataGridView3.Rows[i].Cells[2].Value;
// dataRow[PdnResources.GetString("Menu.Levelname.text")] = this.dataGridView3.Rows[i].Cells[3].Value;
// dtb1.Rows.Add(dataRow);
//}
List list = new List();
list.Add(dtb);
//list.Add(dtb1);
this.appWorkspace.ExportDataToExcelWithProgress(list, exe.FileName, true, false, true);
}
else
MessageBox.Show(PdnResources.GetString("Menu.Noanalysineratereport.text")+"!");
}
private void listView2_SelectedIndexChanged(object sender, EventArgs e)
{
if (this.showAll)
return;
RefreshDataGridView2();
}
///
/// 全部显示
///
///
///
private void button6_Click(object sender, EventArgs e)
{
if (this.button6.Text == PdnResources.GetString("Menu.Showall.text"))
{
this.button6.Text = PdnResources.GetString("Menu.Cancelshowall.text");
this.showAll = true;
RefreshDataGridView2();
}
else if (this.button6.Text == PdnResources.GetString("Menu.Cancelshowall.text"))
{
this.button6.Text = PdnResources.GetString("Menu.Showall.text");
this.showAll = false;
RefreshDataGridView2();
}
}
///
/// 删除
///
///
///
private void button7_Click(object sender, EventArgs e)
{
if (this.listView2.SelectedItems != null && this.listView2.SelectedItems.Count > 0)
{
DialogResult dr = MessageBox.Show(PdnResources.GetString("Menu.Determineallanalysisrlete.text")+"?", PdnResources.GetString("Menu.alert.text"), MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
if (dr == DialogResult.OK)
{
for (int i = 0; i < this.listView2.SelectedItems.Count; i++)
{
string tableName = this.listView2.SelectedItems[i].Name;
foreach (DataTable dt in resultTableList)
{
if (dt.TableName.Equals(tableName))
{
resultTableList.Remove(dt);
break;
}
}
if (bitDic.ContainsKey(tableName))
bitDic.Remove(tableName);
}
foreach (ListViewItem item in this.listView2.Items)
{
if (item.Selected)
this.listView2.Items.Remove(item);
}
RefreshDataGridView2();
}
}
}
///
/// 设置窗体缩放最小尺寸
///
///
///
private void SpheroidizationLevelDialog_ResizeEnd(object sender, EventArgs e)
{
if (this.Width <= 1179)
{
this.Width = 1179;
}
if (this.Height <= 945)
{
this.Height = 945;
}
}
#region 参数保存及提取
///
/// 保存参数的key,value和type
///
///
///
///
private void saveParamValue(string param_key, string param_value, int param_type)
{
bool foundItem = false;
if (!this.eachData.ContainsKey(GetImgKey()))
{
GrainSizeAnalysisModel analysisItem = new GrainSizeAnalysisModel();
analysisItem.menuId = this.menuId;
analysisItem.param_key = param_key;
analysisItem.param_type = param_type;
analysisItem.param_value = param_value;
analysisItem.setValue();
analysisItem.ListParam = new List();
analysisItem.ListParam.Add(analysisItem);
this.eachData.Add(GetImgKey(), analysisItem);
}
foreach (var item in this.eachData[GetImgKey()].ListParam)
{
if (item.param_key.Equals(param_key) && item.menuId == this.menuId)
{
item.param_value = param_value;
item.setValue();
foundItem = true;
break;
}
}
if (!foundItem)
{
GrainSizeAnalysisModel analysisItem = new GrainSizeAnalysisModel();
analysisItem.menuId = this.menuId;
analysisItem.param_key = param_key;
analysisItem.param_type = param_type;
analysisItem.param_value = param_value;
analysisItem.setValue();
this.eachData[GetImgKey()].ListParam.Add(analysisItem);
}
}
///
/// 保存界面中的参数到model
///
private void saveDialogParamValues()
{
saveParamValue(ParamKey_Report, checkBox1.Checked ? "0" : "1", (int)PaintDotNet.Base.Dtryt.Boolean);//报告设置
saveParamValue(ParamKey_Screen, checkBox3.Checked ? "0" : "1", (int)PaintDotNet.Base.Dtryt.Boolean);//筛选
saveParamValue(ParamKey_ScreenMin, numericUpDown4 != null ? numericUpDown4.Value.ToString() : "", (int)PaintDotNet.Base.Dtryt.Decimal);//面积最小值
saveParamValue(ParamKey_ScreenMax, numericUpDown5 != null ? numericUpDown5.Value.ToString() : "", (int)PaintDotNet.Base.Dtryt.Decimal);//面积最大值
saveParamValue(ParamKey_Diameter, checkBox6.Checked ? "0" : "1", (int)PaintDotNet.Base.Dtryt.Boolean);//直径小于20um
saveParamValue(ParamKey_Colour, checkBox4.Checked ? "0" : "1", (int)PaintDotNet.Base.Dtryt.Boolean);//显示不同颜色
saveParamValue(ParamKey_AreaRatio, checkBox5.Checked ? "0" : "1", (int)PaintDotNet.Base.Dtryt.Boolean);//显示面积率
saveParamValue(ParamKey_AreaRatioRangeMin, numericUpDown6 != null ? numericUpDown6.Value.ToString() : "", (int)PaintDotNet.Base.Dtryt.Decimal);//面积率区间最小值
saveParamValue(ParamKey_AreaRatioRangeMax, numericUpDown7 != null ? numericUpDown7.Value.ToString() : "", (int)PaintDotNet.Base.Dtryt.Decimal);//面积率区间最大值
saveParamValue(ParamKey_DecimalPlace, numericUpDown1 != null ? numericUpDown1.Value.ToString() : "", (int)PaintDotNet.Base.Dtryt.Decimal);//保留小数位数
saveParamValue(ParamKey_panelColour1_08, colour != null ? colour[ParamKey_panelColour1_08].ToArgb().ToString() : Color.Orange.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_panelColour08_06, colour != null ? colour[ParamKey_panelColour08_06].ToArgb().ToString() : Color.Blue.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_panelColour06_04, colour != null ? colour[ParamKey_panelColour06_04].ToArgb().ToString() : Color.Green.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_panelColour04_02, colour != null ? colour[ParamKey_panelColour04_02].ToArgb().ToString() : Color.Pink.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_panelColour02_01, colour != null ? colour[ParamKey_panelColour02_01].ToArgb().ToString() : Color.Violet.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_panelColour01_0, colour != null ? colour[ParamKey_panelColour01_0].ToArgb().ToString() : Color.Yellow.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_FontSize, colourFont != null ? colourFont.Keys.First() : "12", (int)PaintDotNet.Base.Dtryt.Interger);//字体大小
saveParamValue(ParamKey_FontColour, colour != null ? colourFont.Values.First().ToArgb().ToString() : Color.Black.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//字体颜色
}
///
/// 获取保存的参数
///
private void GetListParamModel()
{
if (this.eachData.ContainsKey(GetImgKey()) && this.eachData[GetImgKey()] != null)
{
for (int i = 0; i < this.eachData[GetImgKey()].ListParam.Count; i++)
{
switch (this.eachData[GetImgKey()].ListParam[i].param_key)
{
case ParamKey_Report:
checkBox1.Checked = (Boolean)this.eachData[GetImgKey()].ListParam[i].value;
break;
case ParamKey_Screen:
checkBox3.Checked = (Boolean)this.eachData[GetImgKey()].ListParam[i].value;
break;
case ParamKey_ScreenMin:
areaMin = decimal.Parse(this.eachData[GetImgKey()].ListParam[i].param_value);
break;
case ParamKey_ScreenMax:
areaMax = decimal.Parse(this.eachData[GetImgKey()].ListParam[i].param_value);
break;
case ParamKey_Diameter:
checkBox6.Checked = (Boolean)this.eachData[GetImgKey()].ListParam[i].value;
break;
case ParamKey_Colour:
checkBox4.Checked = (Boolean)this.eachData[GetImgKey()].ListParam[i].value;
break;
case ParamKey_AreaRatio:
checkBox5.Checked = (Boolean)this.eachData[GetImgKey()].ListParam[i].value;
break;
case ParamKey_AreaRatioRangeMin:
areaRatioRangeMin = decimal.Parse(this.eachData[GetImgKey()].ListParam[i].param_value);
break;
case ParamKey_AreaRatioRangeMax:
areaRatioRangeMax = decimal.Parse(this.eachData[GetImgKey()].ListParam[i].param_value);
break;
case ParamKey_DecimalPlace:
numericUpDown1.Value = decimal.Parse(this.eachData[GetImgKey()].ListParam[i].param_value);
break;
case ParamKey_panelColour1_08:
colour.Remove(ParamKey_panelColour1_08);
colour.Add(ParamKey_panelColour1_08, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_panelColour08_06:
colour.Remove(ParamKey_panelColour08_06);
colour.Add(ParamKey_panelColour08_06, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_panelColour06_04:
colour.Remove(ParamKey_panelColour06_04);
colour.Add(ParamKey_panelColour06_04, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_panelColour04_02:
colour.Remove(ParamKey_panelColour04_02);
colour.Add(ParamKey_panelColour04_02, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_panelColour02_01:
colour.Remove(ParamKey_panelColour02_01);
colour.Add(ParamKey_panelColour02_01, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_panelColour01_0:
colour.Remove(ParamKey_panelColour01_0);
colour.Add(ParamKey_panelColour01_0, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_FontSize:
fontSize = this.eachData[GetImgKey()].ListParam[i].value.ToString();
break;
case ParamKey_FontColour:
fontColour = Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value);
break;
}
}
colourFont.Clear();
colourFont.Add(fontSize, fontColour);
}
}
///
/// 获取XML保存的参数
///
private void GetXmlParameter()
{
string filePath = Application.StartupPath + "\\Config\\" + Startup.instance.SettingPrefix + "\\GrainSizeAnalyze\\GrainSizeAnalysisModel.xml";
GrainSizeAnalysisModel analysisModelXml = XmlSerializeHelper.DESerializer(FileOperationHelper.ReadStringFromFile(filePath, System.IO.FileMode.Open));
for (int i = 0; i < listView1.Items.Count; i++)
{
if (this.eachData.ContainsKey(listView1.Items[i].Index.ToString()))
{
this.eachData[listView1.Items[i].Index.ToString()] = analysisModelXml.cloneListParamModel(this.menuId);
}
else
{
this.eachData.Add(listView1.Items[i].Index.ToString(), analysisModelXml.cloneListParamModel(this.menuId));
}
}
foreach (var item in this.eachData[GetImgKey()].ListParam)
item.setValue();
}
///
/// 保存参数,防止没有图片
///
private void NullKey()
{
GrainSizeAnalysisModel grainsizeanalysismodel = new GrainSizeAnalysisModel();
grainsizeanalysismodel.ListParam = new List();
this.eachData.Add("null", grainsizeanalysismodel);
}
private string GetImgKey()
{
string key = this.listView1.FocusedItem != null ? this.listView1.FocusedItem.Index.ToString() : "null";
return key;
}
#endregion
private void button4_Click(object sender, EventArgs e)
{
if (this.listView1.FocusedItem == null)
{
return;
}
binaryClass.saveParams();
binaryClass.applyToAll(this.imageList1.Images.Keys, this.imageList1.Images.Keys[int.Parse(GetImgKey())]);
saveDialogParamValues();
GrainSizeAnalysisModel data = new GrainSizeAnalysisModel();
if (eachData.ContainsKey(GetImgKey()))
{
data = eachData[GetImgKey()];
}
for (int i = 0; i < listView1.Items.Count; i++)
{
eachData[i.ToString()] = data.cloneListParamModel(this.menuId);
this.listView1.EnsureVisible(i);
this.listView1.Items[i].Focused = true;
this.listView1.Items[i].Selected = true;
}
}
private bool blSaveAll = false;
private void button3_Click(object sender, EventArgs e)
{
if (this.listView1.FocusedItem == null)
{
return;
}
if (eachData.Count - 1 != listView1.Items.Count)
{
MessageBox.Show("请先点击应用全部!");
return;
}
saveDialogParamValues();
int current = int.Parse(GetImgKey());
for (int i = 0; i < listView1.Items.Count; i++)
{
this.listView1.EnsureVisible(i);
this.listView1.Items[i].Focused = true;
this.listView1.Items[i].Selected = true;
this.button2.PerformClick();
blSaveAll = true;
}
this.listView1.EnsureVisible(current);
this.listView1.Items[current].Focused = true;
this.listView1.Items[current].Selected = true;
blSaveAll = false;
}
private void listView1_MouseDown(object sender, MouseEventArgs e)
{
if (this.listView1.FocusedItem != null)
saveDialogParamValues();
}
#region [脚本相关]
private void getValue(string key, object value)
{
switch (key)
{
case "parameter1":
checkBox3.Checked = Convert.ToBoolean(value);
break;
case "parameter2":
int min = Convert.ToInt32(value);
decimal minDec = Convert.ToDecimal(value);
if (bcBinaryChecked())
{
if (trackBar2.Minimum > min || trackBar2.Maximum < min)
{
trackBar2.Value = trackBar2.Minimum;
}
else
{
trackBar2.Value = min;
}
if (numericUpDown4.Minimum > min || numericUpDown4.Maximum < min)
{
numericUpDown4.Value = numericUpDown4.Minimum;
}
else
{
numericUpDown4.Value = minDec;
}
}
break;
case "parameter3":
int max = Convert.ToInt32(value);
decimal maxDec = Convert.ToDecimal(value);
if (bcBinaryChecked())
{
if (trackBar4.Minimum > max || trackBar4.Maximum < max)
{
trackBar4.Value = trackBar4.Maximum;
}
else
{
trackBar4.Value = max;
}
if (numericUpDown5.Minimum > max || numericUpDown5.Maximum < max)
{
numericUpDown5.Value = numericUpDown5.Maximum;
}
else
{
numericUpDown5.Value = maxDec;
}
}
break;
case "parameter4":
checkBox6.Checked = Convert.ToBoolean(value);
break;
case "parameter5":
checkBox4.Checked = Convert.ToBoolean(value);
break;
case "parameter6":
checkBox5.Checked = Convert.ToBoolean(value);
break;
case "parameter7":
fontSize = value.ToString();
colourFont.Clear();
colourFont.Add(fontSize, Color.Black);
break;
case "parameter8":
fontColour = Color.FromArgb((int)value);
if (colourFont.ContainsKey(fontSize))
{
colourFont[fontSize] = fontColour;
}
else
{
colourFont.Add("10", fontColour);
}
this.documentWorkspace.Refresh();
break;
case "parameter9":
if (colour.ContainsKey("panelColour1_08"))
{
colour["panelColour1_08"] = Color.FromArgb((int)value);
}
else
{
colour.Add("panelColour1_08", Color.FromArgb((int)value));
}
break;
case "parameter10":
if (colour.ContainsKey("panelColour08_06"))
{
colour["panelColour08_06"] = Color.FromArgb((int)value);
}
else
{
colour.Add("panelColour08_06", Color.FromArgb((int)value));
}
break;
case "parameter11":
if (colour.ContainsKey("panelColour06_04"))
{
colour["panelColour06_04"] = Color.FromArgb((int)value);
}
else
{
colour.Add("panelColour06_04", Color.FromArgb((int)value));
}
break;
case "parameter12":
if (colour.ContainsKey("panelColour04_02"))
{
colour["panelColour04_02"] = Color.FromArgb((int)value);
}
else
{
colour.Add("panelColour04_02", Color.FromArgb((int)value));
}
break;
case "parameter13":
if (colour.ContainsKey("panelColour02_01"))
{
colour["panelColour02_01"] = Color.FromArgb((int)value);
}
else
{
colour.Add("panelColour02_01", Color.FromArgb((int)value));
}
break;
case "parameter14":
if (colour.ContainsKey("panelColour01_0"))
{
colour["panelColour01_0"] = Color.FromArgb((int)value);
}
else
{
colour.Add("panelColour01_0", Color.FromArgb((int)value));
}
break;
case "parameter15":
int min2 = Convert.ToInt32(value);
decimal minDec2 = Convert.ToDecimal(value);
if (trackBar5.Minimum > min2 || trackBar5.Maximum < min2)
{
trackBar5.Value = trackBar5.Minimum;
}
else
{
trackBar5.Value = min2;
}
if (numericUpDown6.Minimum > minDec2 || numericUpDown6.Maximum < minDec2)
{
numericUpDown6.Value = numericUpDown6.Minimum;
}
else
{
numericUpDown6.Value = minDec2;
}
break;
case "parameter16":
int min3 = Convert.ToInt32(value);
decimal minDec3 = Convert.ToDecimal(value);
if (trackBar6.Minimum > min3 || trackBar6.Maximum < min3)
{
trackBar6.Value = trackBar6.Minimum;
}
else
{
trackBar6.Value = min3;
}
if (numericUpDown7.Minimum > minDec3 || numericUpDown7.Maximum < minDec3)
{
numericUpDown7.Value = numericUpDown7.Minimum;
}
else
{
numericUpDown7.Value = minDec3;
}
break;
case "OpenWhileExportReport":
checkBox1.Checked = Convert.ToBoolean(value);
break;
case "CalculatorDecimalDigits":
numericUpDown1.Value = Convert.ToDecimal(value);
break;
case "ExportResults":
isExportResults = Convert.ToBoolean(value);
break;
case "ExportReports":
isExportReports = Convert.ToBoolean(value);
break;
case "ExportProjects":
isExportProjects = Convert.ToBoolean(value);
break;
}
}
private void startScriptAutomaticAction()
{
this.button4.PerformClick();
this.button3.PerformClick();
this.button6.Text = PdnResources.GetString("Menu.Cancelshowall.text");
this.showAll = true;
RefreshDataGridView2();
if (isExportResults)//导出结果
this.button9.PerformClick();
if (isExportReports)//生成报告
this.button8.PerformClick();
if (isExportProjects)//导出项目
this.button1.PerformClick();
this.appWorkspace.ScriptAutomatic = false;
this.Close();
}
#endregion
#region [脚本录制]
private void getScriptRecording()
{
string className = InvariantData.path_Action + ".Action" + menuId;
ParamObject param = (ParamObject)System.Reflection.Assembly.Load(InvariantData.assembly_Data).CreateInstance(className);
List args = param.Lists;
foreach (var item in args)
{
item.value = setScriptRecording(item.key);
}
//找出二值相关参数 进行赋值
List isNullList = args.Where(m => m.value == null).ToList();
foreach (var item in isNullList)
{
item.value = binaryClass.setScriptRecording(item.key);
}
appWorkspace.SetScriptStartRecording(this.menuId, menuName, args);
}
private object setScriptRecording(string key)
{
object value = null;
switch (key)
{
case "parameter1":
value = checkBox3.Checked;
break;
case "parameter2":
value = trackBar2.Value;
break;
case "parameter3":
value = trackBar4.Value;
break;
case "parameter4":
value = checkBox6.Checked;
break;
case "parameter5":
value = checkBox4.Checked;
break;
case "parameter6":
value = checkBox5.Checked;
break;
case "parameter7":
value = colourFont.First().Key;
break;
case "parameter8":
value = colourFont.First().Value.ToArgb();
break;
case "parameter9":
if (colour.ContainsKey("panelColour1_08"))
{
value = colour["panelColour1_08"].ToArgb();
}
else
{
value = Color.Orange.ToArgb();
}
break;
case "parameter10":
if (colour.ContainsKey("panelColour08_06"))
{
value = colour["panelColour08_06"].ToArgb();
}
else
{
value = Color.Blue.ToArgb();
}
break;
case "parameter11":
if (colour.ContainsKey("panelColour06_04"))
{
value = colour["panelColour06_04"].ToArgb();
}
else
{
value = Color.Green.ToArgb();
}
break;
case "parameter12":
if (colour.ContainsKey("panelColour04_02"))
{
value = colour["panelColour04_02"].ToArgb();
}
else
{
value = Color.Pink.ToArgb();
}
break;
case "parameter13":
if (colour.ContainsKey("panelColour02_01"))
{
value = colour["panelColour02_01"].ToArgb();
}
else
{
value = Color.Purple.ToArgb();
}
break;
case "parameter14":
if (colour.ContainsKey("panelColour01_0"))
{
value = colour["panelColour01_0"].ToArgb();
}
else
{
value = Color.Yellow.ToArgb();
}
break;
case "parameter15":
value = trackBar5.Value;
break;
case "parameter16":
value = trackBar6.Value;
break;
case "OpenWhileExportReport":
value = checkBox1.Checked;
break;
case "CalculatorDecimalDigits":
value = numericUpDown1.Value;
break;
case "ExportResults":
value = isExportResults;
break;
case "ExportReports":
value = isExportReports;
break;
case "ExportProjects":
value = isExportProjects;
break;
}
return value;
}
#endregion
}
}