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.DedicatedAnalysis.DuctileIron.Common;
using PaintDotNet.GeneralAnalysis;
using Metis.ParameterSet;
namespace PaintDotNet.DedicatedAnalysis.DuctileIron.GBT9441_2009.GraphiteSize
{
internal class SpheroidizationGraphiteSize : 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(153, 59);
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 = 27;
this.Controls.Add(this.bc);
this.Controls.SetChildIndex(this.bc, 0);
this.groupBox9.Text = PdnResources.GetString("Menu.Analysisresult.text");
this.button1.Text = PdnResources.GetString("Menu.Exportproject.text");
this.label8.Text = PdnResources.GetString("Menu.Decimal.text") + ":";
this.button9.Text = PdnResources.GetString("Menu.Exportresults.text");
this.button8.Text = PdnResources.GetString("Menu.Tools.CreateReport.Text");
this.button7.Text = PdnResources.GetString("Menu.Edit.Delete.Text");
this.button6.Text = PdnResources.GetString("Menu.Showall.text");
this.groupBox8.Text = PdnResources.GetString("Menu.Theesultshow.text");
this.groupBox6.Text = PdnResources.GetString("Menu.paramssettings.text");
this.checkBox6.Text = PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Particleshecalculation.text");
this.btnDisplay.Text = PdnResources.GetString("Menu.Displayparamssettings.text");
this.btnColour.Text = PdnResources.GetString("Menu.Colorsetting.text");
this.checkBox5.Text = PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Displaythediualareacircle.text");
this.checkBox4.Text = PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Showdifofcolor.text");
this.groupBox5.Text = PdnResources.GetString("Menu.Particlescreening.text");
this.label3.Text = PdnResources.GetString("Menu.range.text") + ":";
this.checkBox3.Text = PdnResources.GetString("Menu.filter.text");
this.groupBox3.Text = PdnResources.GetString("Menu.Preview.text");
this.groupBox2.Text = PdnResources.GetString("Menu.Tools.ImageIndex.Text");
this.groupBox1.Text = PdnResources.GetString("Menu.operation.text");
this.button2.Text = PdnResources.GetString("Menu.Saveresult.text");
this.checkBox1.Text = PdnResources.GetString("Menu.Opensettingsatingreport.text");
this.btnSetUp.Text = PdnResources.GetString("Menu.Setting.Text");
this.Text = "GBT9441-2009(" + PdnResources.GetString("Menu.Sizeofgraphite.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.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.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();
//
// 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, 714);
this.groupBox9.Name = "groupBox9";
this.groupBox9.Size = new System.Drawing.Size(1151, 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(228, 120);
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(756, 76);
this.dataGridView3.TabIndex = 12;
//
// 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(1009, 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.Right)));
this.label10.AutoSize = true;
this.label10.ForeColor = System.Drawing.SystemColors.ScrollBar;
this.label10.Location = new System.Drawing.Point(990, 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(1061, 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(1023, 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(1009, 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(1009, 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, 12);
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(756, 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, 527);
this.groupBox8.Name = "groupBox8";
this.groupBox8.Size = new System.Drawing.Size(357, 182);
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)
| System.Windows.Forms.AnchorStyles.Right)));
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(340, 155);
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(153, 425);
this.groupBox6.Name = "groupBox6";
this.groupBox6.Size = new System.Drawing.Size(358, 99);
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(249, 58);
this.btnDisplay.Name = "btnDisplay";
this.btnDisplay.Size = new System.Drawing.Size(85, 26);
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(259, 33);
this.btnColour.Name = "btnColour";
this.btnColour.Size = new System.Drawing.Size(75, 23);
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(153, 352);
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(190, 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.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
this.trackBar2.AutoSize = false;
this.trackBar2.Location = new System.Drawing.Point(114, 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(46, 33);
this.numericUpDown4.Maximum = new decimal(new int[] {
0,
0,
0,
0});
this.numericUpDown4.Name = "numericUpDown4";
this.numericUpDown4.Size = new System.Drawing.Size(60, 21);
this.numericUpDown4.TabIndex = 10;
//
// label3
//
this.label3.AutoSize = true;
this.label3.Location = new System.Drawing.Point(9, 37);
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(30, 16);
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(647, 647);
this.groupBox3.TabIndex = 21;
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, 648);
this.groupBox2.TabIndex = 20;
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, 625);
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(1151, 50);
this.groupBox1.TabIndex = 19;
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(971, 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_1);
//
// 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(1061, 14);
this.button3.Name = "button3";
this.button3.Size = new System.Drawing.Size(84, 30);
this.button3.TabIndex = 19;
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(881, 14);
this.button4.Name = "button4";
this.button4.Size = new System.Drawing.Size(84, 30);
this.button4.TabIndex = 18;
this.button4.Text = "应用全部";
this.button4.UseVisualStyleBackColor = true;
this.button4.Click += new System.EventHandler(this.button4_Click);
//
// SpheroidizationGraphiteSize
//
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(1177, 922);
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 = "SpheroidizationGraphiteSize";
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.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 System.Windows.Forms.GroupBox groupBox9;
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;
private System.Windows.Forms.Button button1;
private System.Windows.Forms.DataGridView dataGridView3;
private CustomControl.BinaryControl bc;
#endregion
public static SpheroidizationGraphiteSize spheroidizationGraphiteSize;
///
/// 调色板
///
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;
///
/// 相的集合
///
private PhaseModel phaseModel;
///
/// 单位标尺
///
private double unitLength = 1;
///
/// 放大倍数
///
private double multiple = 1;
///
/// 坐标集合
///
private List pointList = new List();
///
/// 绘制点
///
private List leList = new List();
///
/// 直径500_250碳化物点集合
///
private List> lstPoint500_250;
///
/// 直径250_120碳化物点集合
///
private List> lstPoint250_120;
///
/// 直径120-60碳化物点集合
///
private List> lstPoint120_60;
///
/// 直径60-30碳化物点集合
///
private List> lstPoint60_30;
///
/// 直径30-15碳化物点集合
///
private List> lstPoint30_15;
///
/// 直径<=15碳化物点集合
///
private List> lstPoint0_15;
///
/// 面积率
///
private double areaRatio = 0;
///
/// 面积率最大值
///
double maxAreaRatio = 0;
///
/// 面积率最小值
///
double minAreaRatio = 100;
///
/// 平均直径
///
double avgDiameter = 0;
///
/// 等积圆直径
///
double equalDiameter;
///
/// 等积圆最大直径
///
double maxEqualDiameter;
///
/// 等积圆最小直径
///
double minEqualDiameter;
///
/// 直径集合
///
List lstEqualDiameter;
///
/// 大于最大半径个数
///
double largeMaxRadiusSum;
///
/// 大于最大半径平均直径
///
double largeMaxRadiusAvg;
///
/// 石墨含量
///
double spheroidizationAreaRate = 0;
///
/// 存储面积率颜色字典
///
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 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_DecimalPlace = "decimalPlace";//保留小数位数
private const string ParamKey_Panel6 = "panel6";//不同区间颜色
private const string ParamKey_Panel5 = "panel5";//不同区间颜色
private const string ParamKey_Panel4 = "panel4";//不同区间颜色
private const string ParamKey_Panel3 = "panel3";//不同区间颜色
private const string ParamKey_Panel2 = "panel2";//不同区间颜色
private const string ParamKey_Panel1 = "panel1";//不同区间颜色
private const string ParamKey_FontSize = "fontSize";//字体大小
private const string ParamKey_FontColour = "fontColour";//字体颜色
private decimal areaMin = -1;//面积最小
private decimal areaMax = -1;//面积最大
private string fontSize = "12";
private Color fontColour = Color.Black;
#region 二值化相关
///
/// 初始系统参数配置值
///
private BinaryExtractionModel binaryExtractionModel;
///
/// 处理程序
///
private ParamObject action = new Data.Action.Action901();
///
/// 调色板
///
private ColorsForm colorsFormGrid;
///
/// 参数下拉的集合
///
private List files = new List();
private bool needChange = true;
//二值化集成1
BinaryClass binaryClass;
private Button button3;
private Button button4;
private int menuId;
private string menuName;
#endregion
public SpheroidizationGraphiteSize(AppWorkspace appWorkspace, PdnMenuItem menuItem)
{
this.menuId = menuItem.MenuId;
this.menuName = menuItem.Text;
binaryClass = new BinaryClass(menuId);
spheroidizationGraphiteSize = this;
this.appWorkspace = appWorkspace;
NullKey();
InitializeComponent();
InitializeLanguageText();
InitColour();
InitPicList();
InitOtherTools();
InitCommonButtonEvent();
InitGridHeader();
SetAnalyzeModelFromXml("Template.Manager.item3.DuctileIronGBT9441Size");
}
/////
///// 初始化当前图片
/////
//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)
{
//如果是脚本执行,将参数带入
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();
}
this.listView1.Items[defaultIndex].Focused = true;
this.listView1.Items[defaultIndex].Selected = true;
if (this.initScriptValues && this.appWorkspace.ScriptAutomatic)
this.startScriptAutomaticAction();
}
}
///
/// 初始化面积率颜色、字号颜色
///
private void InitColour()
{
colour.Add("panel6", Color.Orange);
colour.Add("panel5", Color.Blue);
colour.Add("panel4", Color.Green);
colour.Add("panel3", Color.Pink);
colour.Add("panel2", Color.Violet);
colour.Add("panel1", Color.Yellow);
colourFont.Add("10", Color.Black);
}
///
/// 初始化表头
///
private void InitGridHeader()
{
//
//结果展示表
//
this.dataGridView1.ColumnHeadersHeight = 40;
DataGridViewTextBoxColumn h1 = new DataGridViewTextBoxColumn();
h1.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h1.Width = 115;
DataGridViewTextBoxColumn h2 = new DataGridViewTextBoxColumn();
h2.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h2.Width = 115;
DataGridViewTextBoxColumn h3 = new DataGridViewTextBoxColumn();
h3.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h3.Width = 115;
DataGridViewTextBoxColumn h4 = new DataGridViewTextBoxColumn();
h4.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h4.Width = 115;
DataGridViewTextBoxColumn h5 = new DataGridViewTextBoxColumn();
h5.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h5.Width = 115;
DataGridViewTextBoxColumn h6 = new DataGridViewTextBoxColumn();
h6.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h6.Width = 115;
DataGridViewTextBoxColumn h7 = new DataGridViewTextBoxColumn();
h7.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h7.Width = 115;
DataGridViewTextBoxColumn h8 = new DataGridViewTextBoxColumn();
h8.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h8.Width = 115;
DataGridViewTextBoxColumn h9 = new DataGridViewTextBoxColumn();
h9.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h9.Width = 115;
DataGridViewTextBoxColumn h10 = new DataGridViewTextBoxColumn();
h10.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h10.Width = 115;
DataGridViewTextBoxColumn h11 = new DataGridViewTextBoxColumn();
h11.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h11.Width = 115;
DataGridViewTextBoxColumn h12 = new DataGridViewTextBoxColumn();
h12.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h12.Width = 115;
DataGridViewTextBoxColumn h13 = new DataGridViewTextBoxColumn();
h13.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h13.Width = 115;
DataGridViewTextBoxColumn h14 = new DataGridViewTextBoxColumn();
h14.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h14.Width = 115;
this.dataGridView1.Columns.Add(h1);
this.dataGridView1.Columns.Add(h2);
this.dataGridView1.Columns.Add(h3);
this.dataGridView1.Columns.Add(h4);
this.dataGridView1.Columns.Add(h5);
this.dataGridView1.Columns.Add(h6);
this.dataGridView1.Columns.Add(h7);
this.dataGridView1.Columns.Add(h8);
this.dataGridView1.Columns.Add(h9);
this.dataGridView1.Columns.Add(h10);
this.dataGridView1.Columns.Add(h11);
this.dataGridView1.Columns.Add(h12);
this.dataGridView1.Columns.Add(h13);
this.dataGridView1.Columns.Add(h14);
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, "500-250"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(2, 1, "250-120"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(3, 1, "120-60"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(4, 1, "60-30"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(5, 1, "30-15"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(6, 1, "<=15"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(7, 1, PdnResources.GetString("Menu.Themaxdiameter.text")+"(um)"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(8, 1, PdnResources.GetString("Menu.minimumdiameter.text")+"(um)"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(9, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text")+"(um)"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(10, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text")));
helper.Headers.Add(new DataGridViewHelper.TopHeader(11, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text")));
helper.Headers.Add(new DataGridViewHelper.TopHeader(12, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text")+"(um)"));
helper.Headers.Add(new DataGridViewHelper.TopHeader(13, 1, PdnResources.GetString("Menu.levdel.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.Columns[3].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[3].ReadOnly = true;
this.dataGridView1.Columns[3].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[4].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[4].ReadOnly = true;
this.dataGridView1.Columns[4].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[5].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[5].ReadOnly = true;
this.dataGridView1.Columns[5].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[6].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[6].ReadOnly = true;
this.dataGridView1.Columns[6].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[7].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[7].ReadOnly = true;
this.dataGridView1.Columns[7].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[8].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[8].ReadOnly = true;
this.dataGridView1.Columns[8].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[9].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[9].ReadOnly = true;
this.dataGridView1.Columns[9].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[10].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[10].ReadOnly = true;
this.dataGridView1.Columns[10].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[11].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[11].ReadOnly = true;
this.dataGridView1.Columns[11].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[12].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[12].ReadOnly = true;
this.dataGridView1.Columns[12].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.Columns[13].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView1.Columns[13].ReadOnly = true;
this.dataGridView1.Columns[13].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1.AllowUserToResizeRows = false;
this.dataGridView1.AllowUserToResizeColumns = false;
//
//分析结果表
//
this.dataGridView2.ColumnHeadersHeight = 30;
DataGridViewTextBoxColumn h15 = new DataGridViewTextBoxColumn();
h15.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h15.Width = 115;
DataGridViewTextBoxColumn h16 = new DataGridViewTextBoxColumn();
h16.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h16.Width = 115;
DataGridViewTextBoxColumn h17 = new DataGridViewTextBoxColumn();
h17.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h17.Width = 115;
DataGridViewTextBoxColumn h18 = new DataGridViewTextBoxColumn();
h18.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h18.Width = 115;
DataGridViewTextBoxColumn h19 = new DataGridViewTextBoxColumn();
h19.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h19.Width = 115;
DataGridViewTextBoxColumn h20 = new DataGridViewTextBoxColumn();
h20.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h20.Width = 115;
DataGridViewTextBoxColumn h21 = new DataGridViewTextBoxColumn();
h21.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h21.Width = 115;
DataGridViewTextBoxColumn h22 = new DataGridViewTextBoxColumn();
h22.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h22.Width = 115;
DataGridViewTextBoxColumn h23 = new DataGridViewTextBoxColumn();
h23.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h23.Width = 115;
DataGridViewTextBoxColumn h24 = new DataGridViewTextBoxColumn();
h24.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h24.Width = 115;
DataGridViewTextBoxColumn h25 = new DataGridViewTextBoxColumn();
h25.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h25.Width = 115;
DataGridViewTextBoxColumn h26 = new DataGridViewTextBoxColumn();
h26.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h26.Width = 115;
DataGridViewTextBoxColumn h27 = new DataGridViewTextBoxColumn();
h27.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h27.Width = 115;
DataGridViewTextBoxColumn h28 = new DataGridViewTextBoxColumn();
h28.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h28.Width = 115;
DataGridViewTextBoxColumn h29 = new DataGridViewTextBoxColumn();
h29.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h29.Width = 115;
this.dataGridView2.Columns.Add(h15);
this.dataGridView2.Columns.Add(h16);
this.dataGridView2.Columns.Add(h17);
this.dataGridView2.Columns.Add(h18);
this.dataGridView2.Columns.Add(h19);
this.dataGridView2.Columns.Add(h20);
this.dataGridView2.Columns.Add(h21);
this.dataGridView2.Columns.Add(h22);
this.dataGridView2.Columns.Add(h23);
this.dataGridView2.Columns.Add(h24);
this.dataGridView2.Columns.Add(h25);
this.dataGridView2.Columns.Add(h26);
this.dataGridView2.Columns.Add(h27);
this.dataGridView2.Columns.Add(h28);
this.dataGridView2.Columns.Add(h29);
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, "500-250"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(3, 1, "250-120"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(4, 1, "120-60"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(5, 1, "60-30"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(6, 1, "30-15"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(7, 1, "<=15"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(8, 1, PdnResources.GetString("Menu.Themaxdiameter.text")+"(um)"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(9, 1, PdnResources.GetString("Menu.minimumdiameter.text")+"(um)"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(10, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text")+"(um)"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(11, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text")));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(12, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text")));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(13, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text")+"(um)"));
helper2.Headers.Add(new DataGridViewHelper.TopHeader(14, 1, PdnResources.GetString("Menu.levdel.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.Columns[4].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[4].ReadOnly = true;
this.dataGridView2.Columns[5].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[5].ReadOnly = true;
this.dataGridView2.Columns[6].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[6].ReadOnly = true;
this.dataGridView2.Columns[7].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[7].ReadOnly = true;
this.dataGridView2.Columns[8].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[8].ReadOnly = true;
this.dataGridView2.Columns[9].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[9].ReadOnly = true;
this.dataGridView2.Columns[10].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[10].ReadOnly = true;
this.dataGridView2.Columns[11].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[11].ReadOnly = true;
this.dataGridView2.Columns[12].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[12].ReadOnly = true;
this.dataGridView2.Columns[13].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[13].ReadOnly = true;
this.dataGridView2.Columns[14].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView2.Columns[14].ReadOnly = true;
this.dataGridView2.AllowUserToResizeRows = false;
this.dataGridView2.AllowUserToResizeColumns = false;
this.dataGridView3.ColumnHeadersHeight = 30;
DataGridViewTextBoxColumn h30 = new DataGridViewTextBoxColumn();
h30.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h30.Width = 115;
DataGridViewTextBoxColumn h31 = new DataGridViewTextBoxColumn();
h31.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h31.Width = 115;
DataGridViewTextBoxColumn h32 = new DataGridViewTextBoxColumn();
h32.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h32.Width = 115;
DataGridViewTextBoxColumn h33 = new DataGridViewTextBoxColumn();
h33.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h33.Width = 115;
DataGridViewTextBoxColumn h34 = new DataGridViewTextBoxColumn();
h34.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h34.Width = 115;
DataGridViewTextBoxColumn h35 = new DataGridViewTextBoxColumn();
h35.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h35.Width = 115;
DataGridViewTextBoxColumn h36 = new DataGridViewTextBoxColumn();
h36.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h36.Width = 115;
DataGridViewTextBoxColumn h37 = new DataGridViewTextBoxColumn();
h37.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h37.Width = 115;
DataGridViewTextBoxColumn h38 = new DataGridViewTextBoxColumn();
h38.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h38.Width = 115;
DataGridViewTextBoxColumn h39 = new DataGridViewTextBoxColumn();
h39.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h39.Width = 115;
DataGridViewTextBoxColumn h40 = new DataGridViewTextBoxColumn();
h40.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h40.Width = 115;
DataGridViewTextBoxColumn h41 = new DataGridViewTextBoxColumn();
h41.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h41.Width = 115;
DataGridViewTextBoxColumn h42 = new DataGridViewTextBoxColumn();
h42.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h42.Width = 115;
DataGridViewTextBoxColumn h43 = new DataGridViewTextBoxColumn();
h43.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h43.Width = 115;
DataGridViewTextBoxColumn h44 = new DataGridViewTextBoxColumn();
h44.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
h44.Width = 115;
this.dataGridView3.Columns.Add(h30);
this.dataGridView3.Columns.Add(h31);
this.dataGridView3.Columns.Add(h32);
this.dataGridView3.Columns.Add(h33);
this.dataGridView3.Columns.Add(h34);
this.dataGridView3.Columns.Add(h35);
this.dataGridView3.Columns.Add(h36);
this.dataGridView3.Columns.Add(h37);
this.dataGridView3.Columns.Add(h38);
this.dataGridView3.Columns.Add(h39);
this.dataGridView3.Columns.Add(h40);
this.dataGridView3.Columns.Add(h41);
this.dataGridView3.Columns.Add(h42);
this.dataGridView3.Columns.Add(h43);
this.dataGridView3.Columns.Add(h44);
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, "500-250"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(3, 1, "250-120"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(4, 1, "120-60"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(5, 1, "60-30"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(6, 1, "30-15"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(7, 1, "<=15"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(8, 1, PdnResources.GetString("Menu.Themaxdiameter.text")+"(um)"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(9, 1, PdnResources.GetString("Menu.minimumdiameter.text")+"(um)"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(10, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text")+"(um)"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(11, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text")));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(12, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text")));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(13, 1, PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text")+"(um)"));
helper3.Headers.Add(new DataGridViewHelper.TopHeader(14, 1, PdnResources.GetString("Menu.levdel.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.Columns[4].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[4].ReadOnly = true;
this.dataGridView3.Columns[5].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[5].ReadOnly = true;
this.dataGridView3.Columns[6].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[6].ReadOnly = true;
this.dataGridView3.Columns[7].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[7].ReadOnly = true;
this.dataGridView3.Columns[8].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[8].ReadOnly = true;
this.dataGridView3.Columns[9].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[9].ReadOnly = true;
this.dataGridView3.Columns[10].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[10].ReadOnly = true;
this.dataGridView3.Columns[11].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[11].ReadOnly = true;
this.dataGridView3.Columns[12].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[12].ReadOnly = true;
this.dataGridView3.Columns[13].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[13].ReadOnly = true;
this.dataGridView3.Columns[14].SortMode = DataGridViewColumnSortMode.NotSortable;
this.dataGridView3.Columns[14].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 = Annotation.Enum.DrawToolType.Pointer;
}
private void mobileModeButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ActiveTool = Annotation.Enum.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 = Annotation.Enum.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 = new AnalyzeSettingDialog(this, "Template.Manager.item3.DuctileIronGBT9441Size");
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]);
this.documentWorkspace.PhaseModels[0].choise = false;
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.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;//轮廓的拓扑信息
//List equalDiameterList;
DataTable dtDataGridView1 = null;
DataTable dtResult = null;
AppCommon appCommon = new AppCommon();
List lstDiameter;// 直径集合
///
/// 刷新颗粒筛选颜色面积率效果
///
private void ReloadDebrisSelection()
{
if (binarizationMat != null && bcBinaryChecked())
{
this.dataGridView1.Rows.Clear();
dtDataGridView1 = new DataTable();
lstPoint500_250 = new List>();
lstPoint250_120 = new List>();
lstPoint120_60 = new List>();
lstPoint60_30 = new List>();
lstPoint30_15 = new List>();
lstPoint0_15 = new List>();
//记录上个视场内石墨个数
int prevLstPoint500_250 = 0;
int prevLstPoint250_120 = 0;
int prevLstPoint120_60 = 0;
int prevLstPoint60_30 = 0;
int prevLstPoint30_15 = 0;
int prevLstPoint0_15 = 0;
double sumMaxEqualDiameter = 0;//最大直径和
double sumMinEqualDiameter = 0;//最小直径和
double sumAvgDiameter = 0;//平均直径和
double sumLstEqualDiameter = 0;//石墨总个数和
double sumLargeMaxRadiusSum = 0;//评级个数和
double sumLargeMaxRadiusAvg = 0;//评级直径和
//equalDiameterList = new List();//大于20um等积圆直径集合
lstDiameter = 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++;
largeMaxRadiusSum = 0;
maxEqualDiameter = 0;//最大直径
minEqualDiameter = 0;//最小直径
lstEqualDiameter = new List();
double totalEqualDiameterSum = 0;//直径和
double totalLargeMaxRadius = 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 area = appCommon.Area(tempCopy, contours[i][0]);
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]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.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]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.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]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.Add(contours[i].ToList());
}
//}
//else
//{
// ps.Add(contours[i].ToList());
//}
}
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.Add(contours[i].ToList());
}
//}
//else
//{
// ps.Add(contours[i].ToList());
//}
}
}
}
}
var listMax = lstEqualDiameter.OrderByDescending(x => x).ToList().Take(1).ToList();
var listMin = lstEqualDiameter.OrderBy(x => x).ToList().Take(1).ToList();
if (listMax.Count > 0)
{
maxEqualDiameter = listMax[0];//最大直径
minEqualDiameter = listMin[0];//最小直径
}
//spheroidizationAreaRate = totalAreaSum / picArea;//石墨含量
foreach (double Radius in lstEqualDiameter)
{
totalEqualDiameterSum += Radius;
if (Radius > maxEqualDiameter / 2)
{
largeMaxRadiusSum++; //直径大于最大半径石墨个数
totalLargeMaxRadius += Radius;//直径大于最大半径石墨总直径
}
}
if (lstEqualDiameter.Count > 0)
{
avgDiameter = totalEqualDiameterSum / lstEqualDiameter.Count;//平均直径
}
else
{
avgDiameter = 0;
}
if (largeMaxRadiusSum > 0)
{
largeMaxRadiusAvg = totalLargeMaxRadius / largeMaxRadiusSum;//直径大于最大半径平均直径
}
else
{
largeMaxRadiusAvg = 0;
}
//级别
string level = string.Empty;
if (largeMaxRadiusAvg > 250 && largeMaxRadiusAvg <= 500)
{
level = PdnResources.GetString("Menu.Level3.text");
}
else if (largeMaxRadiusAvg > 120 && largeMaxRadiusAvg <= 250)
{
level = PdnResources.GetString("Menu.Level4.text");
}
else if (largeMaxRadiusAvg > 60 && largeMaxRadiusAvg <= 120)
{
level = PdnResources.GetString("Menu.Level5.text");
}
else if (largeMaxRadiusAvg > 30 && largeMaxRadiusAvg <= 60)
{
level = PdnResources.GetString("Menu.Level6.text");
}
else if (largeMaxRadiusAvg > 15 && largeMaxRadiusAvg <= 30)
{
level = PdnResources.GetString("Menu.Level7.text");
}
else if (largeMaxRadiusAvg > 0 && largeMaxRadiusAvg <= 15)
{
level = PdnResources.GetString("Menu.Level8.text");
}
else
{
level = "-";
}
this.dataGridView1.Rows.Add($"{PdnResources.GetString("Menu.view.text")}{h}", lstPoint500_250.Count - prevLstPoint500_250, lstPoint250_120.Count - prevLstPoint250_120, lstPoint120_60.Count - prevLstPoint120_60, lstPoint60_30.Count - prevLstPoint60_30, lstPoint30_15.Count - prevLstPoint30_15, lstPoint0_15.Count - prevLstPoint0_15, maxEqualDiameter, minEqualDiameter, avgDiameter, lstEqualDiameter.Count, largeMaxRadiusSum, largeMaxRadiusAvg, level);
sumMaxEqualDiameter += maxEqualDiameter;//最大直径和
sumMinEqualDiameter += minEqualDiameter;//最小直径和
sumAvgDiameter += avgDiameter;//平均直径和
sumLstEqualDiameter += lstEqualDiameter.Count;//石墨总个数和
sumLargeMaxRadiusSum += largeMaxRadiusSum;//评级个数和
sumLargeMaxRadiusAvg += largeMaxRadiusAvg;//评级直径和
prevLstPoint500_250 = lstPoint500_250.Count;
prevLstPoint250_120 = lstPoint250_120.Count;
prevLstPoint120_60 = lstPoint120_60.Count;
prevLstPoint60_30 = lstPoint60_30.Count;
prevLstPoint30_15 = lstPoint30_15.Count;
prevLstPoint0_15 = lstPoint0_15.Count;
lstDiameter = lstDiameter.Concat(lstEqualDiameter).ToList();
}
if (sumFieldl > 1)
{
string avgLevel = string.Empty;
double avgLargeMaxRadiusAvg = sumLargeMaxRadiusAvg / sumFieldl;
if (avgLargeMaxRadiusAvg > 250 && avgLargeMaxRadiusAvg <= 500)
{
avgLevel = PdnResources.GetString("Menu.Level3.text");
}
else if (avgLargeMaxRadiusAvg > 120 && avgLargeMaxRadiusAvg <= 250)
{
avgLevel = PdnResources.GetString("Menu.Level4.text");
}
else if (avgLargeMaxRadiusAvg > 60 && avgLargeMaxRadiusAvg <= 120)
{
avgLevel = PdnResources.GetString("Menu.Level5.text");
}
else if (avgLargeMaxRadiusAvg > 30 && avgLargeMaxRadiusAvg <= 60)
{
avgLevel = PdnResources.GetString("Menu.Level6.text");
}
else if (avgLargeMaxRadiusAvg > 15 && avgLargeMaxRadiusAvg <= 30)
{
avgLevel = PdnResources.GetString("Menu.Level7.text");
}
else if (avgLargeMaxRadiusAvg > 0 && avgLargeMaxRadiusAvg <= 15)
{
avgLevel = PdnResources.GetString("Menu.Level8.text");
}
else
{
avgLevel = "-";
}
this.dataGridView1.Rows.Add(PdnResources.GetString("Menu.Image.Average.Text"), (double)prevLstPoint500_250 / sumFieldl, (double)prevLstPoint250_120 / sumFieldl, (double)prevLstPoint120_60 / sumFieldl, (double)prevLstPoint60_30 / sumFieldl, (double)prevLstPoint30_15 / sumFieldl, (double)prevLstPoint0_15 / sumFieldl, sumMaxEqualDiameter / sumFieldl, sumMinEqualDiameter / sumFieldl, sumAvgDiameter / sumFieldl, sumLstEqualDiameter / sumFieldl, sumLargeMaxRadiusSum / sumFieldl, sumLargeMaxRadiusAvg / sumFieldl, avgLevel);
}
}
else
{
lstEqualDiameter = new List();
OpenCvSharp.Point[][] contours;//原始轮廓信息
HierarchyIndex[] hierachy;
Mat tempCopy = BinaryClass.BGRA2GRAY(binarizationMat);
largeMaxRadiusSum = 0;
double totalEqualDiameterSum = 0;//直径和
double totalLargeMaxRadius = 0;//大于最大半径的直径和
Cv2.FindContours(BinaryClass.BGRA2GRAY(binarizationMat), out contours, out hierachy, RetrievalModes.CComp, ContourApproximationModes.ApproxNone);
for (int i = 0; i < hierachy.Length; i++)
{
if (hierachy[i].Parent == -1)
{
double area = appCommon.Area(tempCopy, contours[i][0]);
//double area = Math.Abs(Cv2.ContourArea(contours[i]));
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]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.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]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.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]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.Add(contours[i].ToList());
}
//}
//else
//{
// ps.Add(contours[i].ToList());
//}
}
}
else
{
OpenCvSharp.RotatedRect rect = OpenCvSharp.Cv2.FitEllipse(contours[i]);
//if (areaRatio >= 0 && areaRatio <= 1)
//{
if (equalDiameter > 0)
{
lstEqualDiameter.Add(equalDiameter);
}
pointList.Add(contours[i][0]);
leList.Add(Math.Round(double.Parse(string.IsNullOrEmpty(equalDiameter.ToString()) ? "0" :
equalDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)));
if (equalDiameter > 250 && equalDiameter <= 500)
{
lstPoint500_250.Add(contours[i].ToList());
}
else if (equalDiameter > 120 && equalDiameter <= 250)
{
lstPoint250_120.Add(contours[i].ToList());
}
else if (equalDiameter > 60 && equalDiameter <= 120)
{
lstPoint120_60.Add(contours[i].ToList());
}
else if (equalDiameter > 30 && equalDiameter <= 60)
{
lstPoint60_30.Add(contours[i].ToList());
}
else if (equalDiameter > 15 && equalDiameter <= 30)
{
lstPoint30_15.Add(contours[i].ToList());
}
else if (equalDiameter > 0 && equalDiameter <= 15)
{
lstPoint0_15.Add(contours[i].ToList());
}
//}
//else
//{
// ps.Add(contours[i].ToList());
//}
}
}
}
}
}
if (pointList.Count > 0)
{
var listMax = lstEqualDiameter.OrderByDescending(x => x).ToList().Take(1).ToList();
var listMin = lstEqualDiameter.OrderBy(x => x).ToList().Take(1).ToList();
if (listMax.Count > 0)
{
maxEqualDiameter = listMax[0];
minEqualDiameter = listMin[0];
}
//spheroidizationAreaRate = totalAreaSum / picArea;//石墨含量
foreach (double Radius in lstEqualDiameter)
{
totalEqualDiameterSum += Radius;
if (Radius > maxEqualDiameter / 2)
{
largeMaxRadiusSum++; //直径大于最大半径石墨个数
totalLargeMaxRadius += Radius;//直径大于最大半径石墨总直径
}
}
avgDiameter = totalEqualDiameterSum / lstEqualDiameter.Count;//平均直径
largeMaxRadiusAvg = totalLargeMaxRadius / largeMaxRadiusSum;//直径大于最大半径平均直径
lstDiameter = lstEqualDiameter;
//级别
string level = string.Empty;
if (largeMaxRadiusAvg > 250 && largeMaxRadiusAvg <= 500)
{
level = PdnResources.GetString("Menu.Level3.text");
}
else if (largeMaxRadiusAvg > 120 && largeMaxRadiusAvg <= 250)
{
level = PdnResources.GetString("Menu.Level4.text");
}
else if (largeMaxRadiusAvg > 60 && largeMaxRadiusAvg <= 120)
{
level = PdnResources.GetString("Menu.Level5.text");
}
else if (largeMaxRadiusAvg > 30 && largeMaxRadiusAvg <= 60)
{
level = PdnResources.GetString("Menu.Level6.text");
}
else if (largeMaxRadiusAvg > 15 && largeMaxRadiusAvg <= 30)
{
level = PdnResources.GetString("Menu.Level7.text");
}
else if (largeMaxRadiusAvg > 0 && largeMaxRadiusAvg <= 15)
{
level = PdnResources.GetString("Menu.Level8.text");
}
else
{
level = "-";
}
this.dataGridView1.Rows.Add(PdnResources.GetString("Menu.view.text")+"1", lstPoint500_250.Count, lstPoint250_120.Count, lstPoint120_60.Count, lstPoint60_30.Count, lstPoint30_15.Count, lstPoint0_15.Count, maxEqualDiameter, minEqualDiameter, avgDiameter, lstEqualDiameter.Count, largeMaxRadiusSum, largeMaxRadiusAvg, 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;
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()
{
//填充颜色
if (this.checkBox4.Checked)
{
Mat[] arr = temp.Split();
temp = temp.CvtColor(ColorConversionCodes.BGRA2BGR);
for (int i = 0; i < lstPoint500_250.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint500_250[i][lstPoint500_250[i].Count - 1], new Scalar(colour["panel6"].B, colour["panel6"].G, colour["panel6"].R));
}
for (int i = 0; i < lstPoint250_120.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint250_120[i][lstPoint250_120[i].Count - 1], new Scalar(colour["panel5"].B, colour["panel5"].G, colour["panel5"].R));
}
for (int i = 0; i < lstPoint120_60.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint120_60[i][lstPoint120_60[i].Count - 1], new Scalar(colour["panel4"].B, colour["panel4"].G, colour["panel4"].R));
}
for (int i = 0; i < lstPoint60_30.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint60_30[i][lstPoint60_30[i].Count - 1], new Scalar(colour["panel3"].B, colour["panel3"].G, colour["panel3"].R));
}
for (int i = 0; i < lstPoint30_15.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint30_15[i][lstPoint30_15[i].Count - 1], new Scalar(colour["panel2"].B, colour["panel2"].G, colour["panel2"].R));
}
for (int i = 0; i < lstPoint0_15.Count; i++)
{
int length = Cv2.FloodFill(temp, lstPoint0_15[i][lstPoint0_15[i].Count - 1], new Scalar(colour["panel1"].B, colour["panel1"].G, colour["panel1"].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 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]);
//}
}
//phaseModel.mat = temp;
if (!changeColor)
{
maxArea = maxArea * unitLength * unitLength;
minArea = minArea * unitLength * unitLength;
int maxNum = (int)Math.Ceiling(maxArea);//获取面积最大值
int minNum = (int)Math.Floor(minArea);//获取面积最小值
//先解绑事件以防数据赋值异常
this.numericUpDown4.ValueChanged -= numericUpDown4_ValueChanged;
this.numericUpDown5.ValueChanged -= numericUpDown5_ValueChanged;
this.trackBar2.Scroll -= trackBar2_Scroll;
this.trackBar4.Scroll -= trackBar4_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 (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.trackBar2.Scroll += new EventHandler(trackBar2_Scroll);
this.trackBar4.Scroll += new EventHandler(trackBar4_Scroll);
//RefreshDataGridView1();
}
}
else
{
this.trackBar2.Maximum = 0;
this.trackBar2.Minimum = 0;
this.trackBar4.Maximum = 0;
this.trackBar4.Minimum = 0;
this.numericUpDown4.Maximum = 0;
this.numericUpDown4.Minimum = 0;
this.numericUpDown5.Maximum = 0;
this.numericUpDown5.Minimum = 0;
}
}
}
///
/// 二值化颜色panel被点击
///
///
///
private void panel1_Click(object sender, EventArgs e)
{
//this.colorsForm1.UserPrimaryColor = ColorBgra.FromColor(this.panel1.BackColor);
//this.colorsForm1.setSaveBtn_Click(new System.EventHandler(this.colorsForm1Changed));
//this.colorsForm1.ShowDialog();
}
private void colorsForm1Changed(object sender, EventArgs e)
{
//this.panel1.BackColor = this.colorsForm1.UserPrimaryColor.ToColor();
//this.colorsForm1.Close();
//changeColor = true;
//ReLoadBinarization();
//this.documentWorkspace.Refresh();
}
///
/// 小数数字框值改变
///
///
///
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;
//if (this.checkBox10.Checked && this.checkBox3.Checked)
// ReloadDebrisSelection();
//if (this.checkBox10.Checked && !this.checkBox3.Checked)
//{
// ReLoadBinarization();
//}
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 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)
{
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)
{
//AddPictureBoxEvent();
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_1(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);
newBit.Tag = pantographRatio;
Graphics graphics = Graphics.FromImage(newBit);
graphics.DrawImage(processedBit, new PointF(0, 0));
if (this.checkBox4.Checked)
{
DisplayColor();
}
if (this.checkBox5.Checked)
{
Draw(graphics);
}
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"));
if (this.checkBox6.Checked)
{
columnName.Add(PdnResources.GetString("Menu.umisoproductcirclediameter.text"));
}
else
{
columnName.Add(PdnResources.GetString("Menu.Diameterofequalareacircle.text"));
}
dataList.Add(columnName);
if (this.lstDiameter.Count > 0)
{
for (int i = 0; i < this.lstDiameter.Count; i++)
{
List strList = new List();
strList.Add((i + 1).ToString());
strList.Add(this.lstDiameter[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 == 13)
{
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 lst500_250 = new List();
List lst250_120 = new List();
List lst120_60 = new List();
List lst60_30 = new List();
List lst30_15 = new List();
List lst0_15 = new List();
List lstMaxEqualDiameter = new List();
List lstMinEqualDiameter = new List();
List lstAvgDiameter = new List();
List lstLstEqualDiameter = new List();
List lstLargeMaxRadiusSum = new List();
List lstLargeMaxRadiusAvg = new List();
//综合平均值
double avglst500_250 = 0;
double avglst250_120 = 0;
double avglst120_60 = 0;
double avglst60_30 = 0;
double avglst30_15 = 0;
double avglst0_15 = 0;
double avglstMaxEqualDiameter = 0;
double avglstMinEqualDiameter = 0;
double avglstAvgDiameter = 0;
double avglstLstEqualDiameter = 0;
double avglstLargeMaxRadiusSum = 0;
double avglstLargeMaxRadiusAvg = 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 == 14)
{
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)
{
lst500_250.Add(double.Parse(row[j].ToString()));
}
if (j == 3)
{
lst250_120.Add(double.Parse(row[j].ToString()));
}
if (j == 4)
{
lst120_60.Add(double.Parse(row[j].ToString()));
}
if (j == 5)
{
lst60_30.Add(double.Parse(row[j].ToString()));
}
if (j == 6)
{
lst30_15.Add(double.Parse(row[j].ToString()));
}
if (j == 7)
{
lst0_15.Add(double.Parse(row[j].ToString()));
}
if (j == 8)
{
lstMaxEqualDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 9)
{
lstMinEqualDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 10)
{
lstAvgDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 11)
{
lstLstEqualDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 12)
{
lstLargeMaxRadiusSum.Add(double.Parse(row[j].ToString()));
}
if (j == 13)
{
lstLargeMaxRadiusAvg.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 == 14)
{
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)
{
lst500_250.Add(double.Parse(row[j].ToString()));
}
if (j == 3)
{
lst250_120.Add(double.Parse(row[j].ToString()));
}
if (j == 4)
{
lst120_60.Add(double.Parse(row[j].ToString()));
}
if (j == 5)
{
lst60_30.Add(double.Parse(row[j].ToString()));
}
if (j == 6)
{
lst30_15.Add(double.Parse(row[j].ToString()));
}
if (j == 7)
{
lst0_15.Add(double.Parse(row[j].ToString()));
}
if (j == 8)
{
lstMaxEqualDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 9)
{
lstMinEqualDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 10)
{
lstAvgDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 11)
{
lstLstEqualDiameter.Add(double.Parse(row[j].ToString()));
}
if (j == 12)
{
lstLargeMaxRadiusSum.Add(double.Parse(row[j].ToString()));
}
if (j == 13)
{
lstLargeMaxRadiusAvg.Add(double.Parse(row[j].ToString()));
}
}
}
h++;
}
}
}
}
}
}
if (dataGridView2.Rows.Count > 0)
{
if (lst500_250.Count > 0)
{
avglst500_250 = (double)lst500_250.Average();
}
if (lst250_120.Count > 0)
{
avglst250_120 = (double)lst250_120.Average();
}
if (lst120_60.Count > 0)
{
avglst120_60 = (double)lst120_60.Average();
}
if (lst60_30.Count > 0)
{
avglst60_30 = (double)lst60_30.Average();
}
if (lst30_15.Count > 0)
{
avglst30_15 = (double)lst30_15.Average();
}
if (lst0_15.Count > 0)
{
avglst0_15 = (double)lst0_15.Average();
}
if (lstMaxEqualDiameter.Count > 0)
{
avglstMaxEqualDiameter = (double)lstMaxEqualDiameter.Average();
}
if (lstMinEqualDiameter.Count > 0)
{
avglstMinEqualDiameter = (double)lstMinEqualDiameter.Average();
}
if (lstAvgDiameter.Count > 0)
{
avglstAvgDiameter = (double)lstAvgDiameter.Average();
}
if (lstLstEqualDiameter.Count > 0)
{
avglstLstEqualDiameter = (double)lstLstEqualDiameter.Average();
}
if (lstLargeMaxRadiusSum.Count > 0)
{
avglstLargeMaxRadiusSum = (double)lstLargeMaxRadiusSum.Average();
}
if (lstLargeMaxRadiusAvg.Count > 0)
{
avglstLargeMaxRadiusAvg = (double)lstLargeMaxRadiusAvg.Average();
}
//级别
string avgLevel = string.Empty;
if (avglstLargeMaxRadiusAvg > 250 && avglstLargeMaxRadiusAvg <= 500)
{
avgLevel = PdnResources.GetString("Menu.Level3.text");
}
else if (avglstLargeMaxRadiusAvg > 120 && avglstLargeMaxRadiusAvg <= 250)
{
avgLevel = PdnResources.GetString("Menu.Level4.text");
}
else if (avglstLargeMaxRadiusAvg > 60 && avglstLargeMaxRadiusAvg <= 120)
{
avgLevel = PdnResources.GetString("Menu.Level5.text");
}
else if (avglstLargeMaxRadiusAvg > 30 && avglstLargeMaxRadiusAvg <= 60)
{
avgLevel = PdnResources.GetString("Menu.Level6.text");
}
else if (avglstLargeMaxRadiusAvg > 15 && avglstLargeMaxRadiusAvg <= 30)
{
avgLevel = PdnResources.GetString("Menu.Level7.text");
}
else if (avglstLargeMaxRadiusAvg > 0 && avglstLargeMaxRadiusAvg <= 15)
{
avgLevel = PdnResources.GetString("Menu.Level8.text");
}
else
{
avgLevel = "-";
}
this.dataGridView3.Rows.Add(PdnResources.GetString("Menu.comprehensive.text"), PdnResources.GetString("Menu.Comprehensivaverage.text"), Math.Round(double.Parse(string.IsNullOrEmpty(avglst500_250.ToString()) ? "0" : avglst500_250.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglst250_120.ToString()) ? "0" : avglst250_120.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglst120_60.ToString()) ? "0" : avglst120_60.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglst60_30.ToString()) ? "0" : avglst60_30.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglst30_15.ToString()) ? "0" : avglst30_15.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglst0_15.ToString()) ? "0" : avglst0_15.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglstMaxEqualDiameter.ToString()) ? "0" : avglstMaxEqualDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglstMinEqualDiameter.ToString()) ? "0" : avglstMinEqualDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglstAvgDiameter.ToString()) ? "0" : avglstAvgDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglstLstEqualDiameter.ToString()) ? "0" : avglstLstEqualDiameter.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglstLargeMaxRadiusSum.ToString()) ? "0" : avglstLargeMaxRadiusSum.ToString()), Convert.ToInt32(this.numericUpDown1.Value)), Math.Round(double.Parse(string.IsNullOrEmpty(avglstLargeMaxRadiusAvg.ToString()) ? "0" : avglstLargeMaxRadiusAvg.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("500-250");
contentHead.Add("250-120");
contentHead.Add("120-60");
contentHead.Add("60-30");
contentHead.Add("30-15");
contentHead.Add("<=15");
contentHead.Add(PdnResources.GetString("Menu.Themaxdiameter.text"));
contentHead.Add(PdnResources.GetString("Menu.minimumdiameter.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text"));
contentHead.Add(PdnResources.GetString("Menu.levdel.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());
content.Add(item.Cells[4].Value.ToString());
content.Add(item.Cells[5].Value.ToString());
content.Add(item.Cells[6].Value.ToString());
content.Add(item.Cells[7].Value.ToString());
content.Add(item.Cells[8].Value.ToString());
content.Add(item.Cells[9].Value.ToString());
content.Add(item.Cells[10].Value.ToString());
content.Add(item.Cells[11].Value.ToString());
content.Add(item.Cells[12].Value.ToString());
content.Add(item.Cells[13].Value.ToString());
content.Add(item.Cells[14].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());
content.Add(item.Cells[4].Value.ToString());
content.Add(item.Cells[5].Value.ToString());
content.Add(item.Cells[6].Value.ToString());
content.Add(item.Cells[7].Value.ToString());
content.Add(item.Cells[8].Value.ToString());
content.Add(item.Cells[9].Value.ToString());
content.Add(item.Cells[10].Value.ToString());
content.Add(item.Cells[11].Value.ToString());
content.Add(item.Cells[12].Value.ToString());
content.Add(item.Cells[13].Value.ToString());
content.Add(item.Cells[14].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))
{
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("500-250");
contentHead.Add("250-120");
contentHead.Add("120-60");
contentHead.Add("60-30");
contentHead.Add("30-15");
contentHead.Add("<=15");
contentHead.Add(PdnResources.GetString("Menu.Themaxdiameter.text"));
contentHead.Add(PdnResources.GetString("Menu.minimumdiameter.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text"));
contentHead.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text"));
contentHead.Add(PdnResources.GetString("Menu.levdel.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());
content.Add(item.Cells[4].Value.ToString());
content.Add(item.Cells[5].Value.ToString());
content.Add(item.Cells[6].Value.ToString());
content.Add(item.Cells[7].Value.ToString());
content.Add(item.Cells[8].Value.ToString());
content.Add(item.Cells[9].Value.ToString());
content.Add(item.Cells[10].Value.ToString());
content.Add(item.Cells[11].Value.ToString());
content.Add(item.Cells[12].Value.ToString());
content.Add(item.Cells[13].Value.ToString());
content.Add(item.Cells[14].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());
content.Add(item.Cells[4].Value.ToString());
content.Add(item.Cells[5].Value.ToString());
content.Add(item.Cells[6].Value.ToString());
content.Add(item.Cells[7].Value.ToString());
content.Add(item.Cells[8].Value.ToString());
content.Add(item.Cells[9].Value.ToString());
content.Add(item.Cells[10].Value.ToString());
content.Add(item.Cells[11].Value.ToString());
content.Add(item.Cells[12].Value.ToString());
content.Add(item.Cells[13].Value.ToString());
content.Add(item.Cells[14].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);
exe.FileName = PdnResources.GetString("Menu.DedicatedAnalysis.BlackMetal.DuctileIron.Text")+"(GBT9441" + PdnResources.GetString("Menu.Sizeofgraphite.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("500-250");
dtb.Columns.Add("250-120");
dtb.Columns.Add("120-60");
dtb.Columns.Add("60-30");
dtb.Columns.Add("30-15");
dtb.Columns.Add("<=15");
dtb.Columns.Add(PdnResources.GetString("Menu.Themaxdiameter.text"));
dtb.Columns.Add(PdnResources.GetString("Menu.minimumdiameter.text"));
dtb.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text"));
dtb.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text"));
dtb.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text"));
dtb.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text"));
dtb.Columns.Add(PdnResources.GetString("Menu.levdel.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["500-250"] = this.dataGridView2.Rows[i].Cells[2].Value;
dataRow["250-120"] = this.dataGridView2.Rows[i].Cells[3].Value;
dataRow["120-60"] = this.dataGridView2.Rows[i].Cells[4].Value;
dataRow["60-30"] = this.dataGridView2.Rows[i].Cells[5].Value;
dataRow["30-15"] = this.dataGridView2.Rows[i].Cells[6].Value;
dataRow["<=15"] = this.dataGridView2.Rows[i].Cells[7].Value;
dataRow[PdnResources.GetString("Menu.Themaxdiameter.text")] = this.dataGridView2.Rows[i].Cells[8].Value;
dataRow[PdnResources.GetString("Menu.minimumdiameter.text")] = this.dataGridView2.Rows[i].Cells[9].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text")] = this.dataGridView2.Rows[i].Cells[10].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text")] = this.dataGridView2.Rows[i].Cells[11].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text")] = this.dataGridView2.Rows[i].Cells[12].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text")] = this.dataGridView2.Rows[i].Cells[13].Value;
dataRow[PdnResources.GetString("Menu.levdel.Text")] = this.dataGridView2.Rows[i].Cells[14].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["500-250"] = this.dataGridView3.Rows[i].Cells[2].Value;
dataRow["250-120"] = this.dataGridView3.Rows[i].Cells[3].Value;
dataRow["120-60"] = this.dataGridView3.Rows[i].Cells[4].Value;
dataRow["60-30"] = this.dataGridView3.Rows[i].Cells[5].Value;
dataRow["30-15"] = this.dataGridView3.Rows[i].Cells[6].Value;
dataRow["<=15"] = this.dataGridView3.Rows[i].Cells[7].Value;
dataRow[PdnResources.GetString("Menu.Themaxdiameter.text")] = this.dataGridView3.Rows[i].Cells[8].Value;
dataRow[PdnResources.GetString("Menu.minimumdiameter.text")] = this.dataGridView3.Rows[i].Cells[9].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text")] = this.dataGridView3.Rows[i].Cells[10].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text")] = this.dataGridView3.Rows[i].Cells[11].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text")] = this.dataGridView3.Rows[i].Cells[12].Value;
dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text")] = this.dataGridView3.Rows[i].Cells[13].Value;
dataRow[PdnResources.GetString("Menu.levdel.Text")] = this.dataGridView3.Rows[i].Cells[14].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("500-250");
//dtb1.Columns.Add("250-120");
//dtb1.Columns.Add("120-60");
//dtb1.Columns.Add("60-30");
//dtb1.Columns.Add("30-15");
//dtb1.Columns.Add("<=15");
//dtb1.Columns.Add(PdnResources.GetString("Menu.Themaxdiameter.text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.minimumdiameter.text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text"));
//dtb1.Columns.Add(PdnResources.GetString("Menu.levdel.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["500-250"] = this.dataGridView3.Rows[i].Cells[2].Value;
// dataRow["250-120"] = this.dataGridView3.Rows[i].Cells[3].Value;
// dataRow["120-60"] = this.dataGridView3.Rows[i].Cells[4].Value;
// dataRow["60-30"] = this.dataGridView3.Rows[i].Cells[5].Value;
// dataRow["30-15"] = this.dataGridView3.Rows[i].Cells[6].Value;
// dataRow["<=15"] = this.dataGridView3.Rows[i].Cells[7].Value;
// dataRow[PdnResources.GetString("Menu.Themaxdiameter.text")] = this.dataGridView3.Rows[i].Cells[8].Value;
// dataRow[PdnResources.GetString("Menu.minimumdiameter.text")] = this.dataGridView3.Rows[i].Cells[9].Value;
// dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Theaveragediameter.text")] = this.dataGridView3.Rows[i].Cells[10].Value;
// dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Totalnumberofgraphite.text")] = this.dataGridView3.Rows[i].Cells[11].Value;
// dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Numberofratings.text")] = this.dataGridView3.Rows[i].Cells[12].Value;
// dataRow[PdnResources.GetString("Menu.Dedicatedanalysis.blackmetal.Ratingdiameter.text")] = this.dataGridView3.Rows[i].Cells[13].Value;
// dataRow[PdnResources.GetString("Menu.levdel.Text")] = this.dataGridView3.Rows[i].Cells[14].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();
}
}
}
#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)Base.Dtryt.Boolean);//筛选
saveParamValue(ParamKey_ScreenMin, numericUpDown4 != null ? numericUpDown4.Value.ToString() : "", (int)Base.Dtryt.Decimal);//面积最小值
saveParamValue(ParamKey_ScreenMax, numericUpDown5 != null ? numericUpDown5.Value.ToString() : "", (int)Base.Dtryt.Decimal);//面积最大值
saveParamValue(ParamKey_Diameter, checkBox6.Checked ? "0" : "1", (int)Base.Dtryt.Boolean);//直径小于20um
saveParamValue(ParamKey_Colour, checkBox4.Checked ? "0" : "1", (int)Base.Dtryt.Boolean);//显示不同颜色
saveParamValue(ParamKey_AreaRatio, checkBox5.Checked ? "0" : "1", (int)Base.Dtryt.Boolean);//显示面积率
saveParamValue(ParamKey_DecimalPlace, numericUpDown1 != null ? numericUpDown1.Value.ToString() : "", (int)Base.Dtryt.Decimal);//保留小数位数
saveParamValue(ParamKey_Panel6, colour != null ? colour[ParamKey_Panel6].ToArgb().ToString() : Color.Orange.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_Panel5, colour != null ? colour[ParamKey_Panel5].ToArgb().ToString() : Color.Blue.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_Panel4, colour != null ? colour[ParamKey_Panel4].ToArgb().ToString() : Color.Green.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_Panel3, colour != null ? colour[ParamKey_Panel3].ToArgb().ToString() : Color.Pink.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_Panel2, colour != null ? colour[ParamKey_Panel2].ToArgb().ToString() : Color.Violet.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_Panel1, colour != null ? colour[ParamKey_Panel1].ToArgb().ToString() : Color.Yellow.ToArgb().ToString(), (int)PaintDotNet.Base.Dtryt.Color);//不同区间颜色
saveParamValue(ParamKey_FontSize, colourFont != null ? colourFont.Keys.First() : "12", (int)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_DecimalPlace:
numericUpDown1.Value = decimal.Parse(this.eachData[GetImgKey()].ListParam[i].param_value);
break;
case ParamKey_Panel6:
colour.Remove(ParamKey_Panel6);
colour.Add(ParamKey_Panel6, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_Panel5:
colour.Remove(ParamKey_Panel5);
colour.Add(ParamKey_Panel5, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_Panel4:
colour.Remove(ParamKey_Panel4);
colour.Add(ParamKey_Panel4, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_Panel3:
colour.Remove(ParamKey_Panel3);
colour.Add(ParamKey_Panel3, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_Panel2:
colour.Remove(ParamKey_Panel2);
colour.Add(ParamKey_Panel2, Color.FromArgb((int)this.eachData[GetImgKey()].ListParam[i].value));
break;
case ParamKey_Panel1:
colour.Remove(ParamKey_Panel1);
colour.Add(ParamKey_Panel1, 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 "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("panel6"))
{
value = colour["panel6"].ToArgb();
}
else
{
value = Color.Orange.ToArgb();
}
break;
case "parameter10":
if (colour.ContainsKey("panel5"))
{
value = colour["panel5"].ToArgb();
}
else
{
value = Color.Blue.ToArgb();
}
break;
case "parameter11":
if (colour.ContainsKey("panel4"))
{
value = colour["panel4"].ToArgb();
}
else
{
value = Color.Green.ToArgb();
}
break;
case "parameter12":
if (colour.ContainsKey("panel3"))
{
value = colour["panel3"].ToArgb();
}
else
{
value = Color.Pink.ToArgb();
}
break;
case "parameter13":
if (colour.ContainsKey("panel2"))
{
value = colour["panel2"].ToArgb();
}
else
{
value = Color.Purple.ToArgb();
}
break;
case "parameter14":
if (colour.ContainsKey("panel1"))
{
value = colour["panel1"].ToArgb();
}
else
{
value = Color.Yellow.ToArgb();
}
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
}
}