轮胎外观检测添加思谋语义分割模型检测工具
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
using HalconDotNet;
using LB_SmartVisionCommon;
using LB_VisionControls;
using LB_VisionProcesses.Alogrithms.Halcon;
using OpenCvSharp;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace LB_VisionProcesses.Alogrithms
{
    public class CreateSegmentTool : TAlgorithm
    {
        public CreateSegmentTool()
        {
            strProcessClass = "LB_VisionProcesses.Alogrithms.CreateSegmentTool";
            strProcessName = "创建线段工具";
 
            Params.Inputs.Add("P1X", 0);
            Params.Inputs.Add("P1Y", 0);
            Params.Inputs.Add("P2X", 0);
            Params.Inputs.Add("P2Y", 0);
            Params.Inputs.Add("畸变关系", "");
            Params.Inputs.Add("是否畸变转换", false);
 
            Params.Outputs.Add("CenterX", 0.0);
            Params.Outputs.Add("CenterY", 0.0);
            Params.Outputs.Add("Phi", 0.0);
            Params.Outputs.Add("Length", 0.0);
            Params.Outputs.Add("HSegment", new HSegment());
        }
 
        /// <summary>
        /// 算子逻辑
        /// </summary>
        public override void TAlgorithmMain()
        {
            #region 初始化变量
 
            #endregion
 
            try
            {
                #region 裁剪区域
 
                #endregion
 
                #region 算子逻辑
                Record = new ObjectRecord();
                var P1 = new HPoint(Convert.ToDouble(Params.Inputs["P1X"]), Convert.ToDouble(Params.Inputs["P1Y"]));
                var P2 = new HPoint(Convert.ToDouble(Params.Inputs["P2X"]), Convert.ToDouble(Params.Inputs["P2Y"]));
 
                bool isCaltab = Convert.ToBoolean(Params.Inputs["是否畸变转换"]);
                if (isCaltab)
                {
                    string CaltabName = Params.Inputs["畸变关系"]?.ToString();
                    if (!dicHCaltabMaps.ContainsKey(CaltabName))
                    {
                        Msg = $"畸变关系{CaltabName}不存在";
                        Result = false;
                        AsyncLogHelper.Error(Msg);
                        return;
                    }
 
                    var HCaltabMap = dicHCaltabMaps[CaltabName];
                    HCaltabMap.GetCaltbPoint(P1, out P1);
                    HCaltabMap.GetCaltbPoint(P2, out P2);
                }
                HSegment HSegment = new HSegment(P1, P2);
 
                // XLD用原始坐标
                HOperatorSet.GenRegionLine(out HObject xld, Convert.ToDouble(Params.Inputs["P1Y"]), Convert.ToDouble(Params.Inputs["P1X"])
                    , Convert.ToDouble(Params.Inputs["P2Y"]), Convert.ToDouble(Params.Inputs["P2X"]));
                Record.AddRecord(xld);
                #endregion
 
                #region 结果处理
                Params.Outputs.Add("CenterX", HSegment.MidX);
                Params.Outputs.Add("CenterY", HSegment.MidY);
                Params.Outputs.Add("Phi", HSegment.Phi);
                Params.Outputs.Add("Length", HSegment.Length);
                Params.Outputs.Add("HSegment", HSegment);
                #endregion
 
                #region 生成OutputImage给后续处理
                try
                {
                    OutputImage = InputImage;
                }
                catch (Exception ex)
                {
                    Msg = "生成OutputImage失败,原因是:" + ex.ToString();
                    Result = false;
                    AsyncLogHelper.Error(Msg);
                    return;
                }
                #endregion
 
                if (Msg == "运行超时")
                {
                    Result = false;
                    return;
                }
 
                return;
            }
            catch (Exception ex)
            {
                Msg = "运行失败,原因是:" + ex.ToString().TrimEnd();
                OutputImage = null;
                Result = false;
                AsyncLogHelper.Error(Msg);
                return;
            }
            finally
            {
                bCompleted = true;
                #region 内存释放
                if (!Result)
                {
                    Params.Outputs.Add("CenterX", 0);
                    Params.Outputs.Add("CenterY", 0);
                    Params.Outputs.Add("Phi", 0);
                    Params.Outputs.Add("Length", 0);
                    Params.Outputs.Add("HSegment", new HSegment());
                }
                #endregion
            }
        }
    }
}