轮胎外观检测添加思谋语义分割模型检测工具
C3204
2026-03-30 06c627ec032b3f3876fd7db8a3ff0ff1a6614fa2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
using LB_VisionControls;
using LB_VisionProcesses.Alogrithms;
using System.Data;
using System.Windows.Forms;
 
namespace LB_VisionProcesses.Processes
{
    public partial class ScriptToolEdit : TAlgorithmEdit
    {
        ScriptEditControl ScriptEditControl = new ScriptEditControl();
 
        public ScriptToolEdit(ScriptTool subject = null)
        {
            InitializeComponent();
            if (subject == null)
                subject = new ScriptTool();
 
            this.grpScript.Controls.Add(ScriptEditControl);
            ScriptEditControl.Dock = DockStyle.Fill;
 
            this.Subject = subject;
            this.ScriptEditControl.TabStop = false; // 避免焦点切换
            this.ScriptEditControl.Focus();// 确保控件可获得焦点
 
            // 设置高质量渲染模式
            SetStyle(ControlStyles.OptimizedDoubleBuffer, true);
            DataGridInputs.ForeColor = Color.Black;
            DataGridOutputs.ForeColor = Color.Black;
        }
 
        private void ScriptToolEdit_Load(object sender, EventArgs e)
        {
            LoadParas();
            this.ScriptEditControl.ScriptText = ProcessParams.ConvertToString(Subject.Params.Inputs["Scrip"]);
        }
 
        DataGridViewComboBoxColumn CreateComboBox(string[] items, string Name = "Type", string HeaderText = "类型"
            , string DataPropertyName = "Type")
        {
            DataGridViewComboBoxColumn column = new DataGridViewComboBoxColumn
            {
                Name = Name,
                HeaderText = HeaderText,
                DataPropertyName = DataPropertyName,
                //FlatStyle = FlatStyle.Flat,
                //Width = 120
            };
 
            column.Items.AddRange(items);
 
            return column;
        }
 
        /// <summary>
        /// 加载运行参数
        /// </summary>
        public override void LoadParas()
        {
            this.Invoke(new Action(() =>
            {
                // 绑定输入参数
                Dictionary<string, object> dicInputs = ((ScriptTool)Subject).GetInputs();
                DataGridInputs.Columns.Add("Key", "键");
                DataGridInputs.Columns.Add("Type", "类");
                if (DataGridOutputs.Columns.Contains("Type"))
                    DataGridOutputs.Columns["Type"].ReadOnly = true;
                //DataGridInputs.Columns.Add(CreateComboBox(((ScriptTool)Subject).SupportTypeArray));
                DataGridInputs.Columns.Add("Value", "值");
 
                DataGridInputs.Rows.Clear();
                foreach (var item in dicInputs)
                {
                    // 添加行并设置文本
                    string type = item.Value?.GetType().Name;
                    int rowIndex = DataGridInputs.Rows.Add(item.Key, type, item.Value);
                }
 
                // 绑定输出参数
                Dictionary<string, object> dicOutputs = Subject.Params.Outputs.GetAllByName();
                DataGridOutputs.Columns.Add("Key", "键");
                DataGridOutputs.Columns.Add("Type", "类");
                if (DataGridOutputs.Columns.Contains("Type"))
                    DataGridOutputs.Columns["Type"].ReadOnly = true;
                //DataGridOutputs.Columns.Add(CreateComboBox(((ScriptTool)Subject).SupportTypeArray));
                DataGridOutputs.Columns.Add("Value", "值");
 
                DataGridOutputs.Rows.Clear();
                foreach (var item in dicOutputs)
                {
                    // 添加行并设置文本
                    string type = item.Value?.GetType().Name;
                    int rowIndex = DataGridOutputs.Rows.Add(item.Key, type, item.Value);
                }
            }));
        }
 
        private void btnCompileCode_Click(object sender, EventArgs e)
        {
            Subject.Params.Inputs["Scrip"] = this.ScriptEditControl.ScriptText;
            ((ScriptTool)Subject).CompileCode();
            this.richTextBoxLog.Text = Subject.Msg;
        }
 
        private void btnRunCode_Click(object sender, EventArgs e)
        {
            //运行前需要更新输入参数Paras
            UpdataInputs();
 
            DateTime StartTime = DateTime.Now;
            Subject.Run();
 
            this.lblRunTime.Text = $"{(DateTime.Now - StartTime).TotalMilliseconds.ToString("F0")}ms";
            this.richTextBoxLog.Text = Subject.Msg;
 
            UpdataOutputs();
        }
 
        /// <summary>
        /// 更新运行参数
        /// </summary>
        public override void UpdataInputs()
        {
            //设置运行参数
            int iResult = 0;
            Subject.Params.Inputs["Scrip"] = this.ScriptEditControl.ScriptText;
 
            Dictionary<string, object> dicInputs = new Dictionary<string, object>();
            foreach (DataGridViewRow row in DataGridInputs.Rows)
            {
                // 使用 row.Cells["列名"] 或 row.Cells[索引]
                if (row.Cells["Key"].Value == null ||
                    string.IsNullOrEmpty(row.Cells["Key"].Value.ToString()))
                    continue;
 
                string key = row.Cells["Key"].Value?.ToString();
                object value = row.Cells["Value"].Value;
 
                if (!string.IsNullOrEmpty(key))
                    dicInputs.Add(key, value);
            }
            ((ScriptTool)Subject).SetInputs(dicInputs);
 
            ((ScriptTool)Subject).ClearOutputs();
            foreach (DataGridViewRow row in DataGridOutputs.Rows)
            {
                // 使用 row.Cells["列名"] 或 row.Cells[索引]
                if (row.Cells["Key"].Value == null ||
                    string.IsNullOrEmpty(row.Cells["Key"].Value.ToString()))
                    continue;
 
                string key = row.Cells["Key"].Value?.ToString();
                object value = row.Cells["Value"].Value;
 
                if (!string.IsNullOrEmpty(key))
                    Subject.Params.Outputs.Add(key, value);
            }
            return;
        }
 
        /// <summary>
        /// 更新输出结果
        /// </summary>
        public override void UpdataOutputs()
        {
            this.BeginInvoke(new Action(() =>
            {
                DataGridInputs.Rows.Clear();
                foreach (var item in ((ScriptTool)Subject).GetInputs())
                {
                    // 添加行并设置文本
                    string type = item.Value?.GetType().Name ?? "String";
                    int rowIndex = DataGridInputs.Rows.Add(item.Key, type, item.Value);
                }
 
                DataGridOutputs.Rows.Clear();
                foreach (var item in Subject.Params.Outputs.GetAllByName())
                {
                    // 添加行并设置文本
                    string type = item.Value?.GetType().Name ?? "String";
                    int rowIndex = DataGridOutputs.Rows.Add(item.Key, type, item.Value);
                }
            }));
        }
    }
}