轮胎外观检测添加思谋语义分割模型检测工具
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
using HalconDotNet;
using LB_VisionProcesses.Alogrithms.Halcon;
using LB_VisionControls;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using OpenCvSharp;
 
namespace LB_VisionProcesses.Alogrithms
{
    public class CreateVerticalTool : TAlgorithm
    {
        public CreateVerticalTool()
        {
            strProcessClass = "LB_VisionProcesses.Alogrithms.CreateVerticalTool";
            strProcessName = "创建垂线工具";
 
            Params.Inputs.Add("X", 0);
            Params.Inputs.Add("Y", 0);
            Params.Inputs.Add("HSegment", new HSegment());
            Params.Inputs.Add("畸变关系", "");
            Params.Inputs.Add("是否畸变转换", false);
 
            Params.Outputs.Add("FeetX", 0.0);
            Params.Outputs.Add("FeetY", 0.0);
 
            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();
                HPoint HPoint_Base = new HPoint(Convert.ToDouble(Params.Inputs["X"]), Convert.ToDouble(Params.Inputs["Y"]));
                var OSegment_Base = Params.Inputs["HSegment"];
                if (!(OSegment_Base is HSegment))
                {
                    Msg = $"HSegment不存在";
                    Result = false;
                    return;
                }
                HSegment HSegment_Base = (HSegment)OSegment_Base;
                Point2f feetPoint2f = TAlgorithm.CalculateFootPoint(new Point2f(Convert.ToSingle(HPoint_Base.X), Convert.ToSingle(HPoint_Base.Y))
                    , new Point2f(Convert.ToSingle(HSegment_Base.StartX), Convert.ToSingle(HSegment_Base.StartY))
                    , new Point2f(Convert.ToSingle(HSegment_Base.EndX), Convert.ToSingle(HSegment_Base.EndY)));
 
                HPoint HPoint_Feet = new HPoint(feetPoint2f.X, feetPoint2f.Y);
 
                // XLD用原始坐标
                HOperatorSet.GenRegionLine(out HObject xld, HPoint_Base.Row, HPoint_Base.Column, HPoint_Feet.Row, HPoint_Feet.Column);
                Record.AddXld(xld);
 
                bool isCaltab = Convert.ToBoolean(Params.Inputs["是否畸变转换"]);
                if (isCaltab)
                {
                    string CaltabName = Params.Inputs["畸变关系"]?.ToString();
                    if (!dicHCaltabMaps.ContainsKey(CaltabName))
                    {
                        Msg = $"畸变关系{CaltabName}不存在";
                        Result = false;
                        return;
                    }
 
                    var HCaltabMap = dicHCaltabMaps[CaltabName];
                    HCaltabMap.GetCaltbPoint(HPoint_Base, out HPoint_Base);
                    HCaltabMap.GetCaltbPoint(HPoint_Feet, out HPoint_Feet);
                }
                HSegment HSegment_Vertical = new HSegment(HPoint_Base, HPoint_Feet);
 
                #endregion
 
                #region 结果处理
                Params.Outputs.Add("FeetX", HPoint_Feet.X);
                Params.Outputs.Add("FeetY", HPoint_Feet.Y);
 
                Params.Outputs.Add("CenterX", HSegment_Vertical.X);
                Params.Outputs.Add("CenterY", HSegment_Vertical.Y);
                Params.Outputs.Add("Phi", HSegment_Vertical.Phi);
                Params.Outputs.Add("Length", HSegment_Vertical.Length);
                Params.Outputs.Add("HSegment", HSegment_Vertical);
                #endregion
 
                #region 生成OutputImage给后续处理
                try
                {
                    OutputImage = InputImage;
                }
                catch (Exception ex)
                {
                    Msg = "生成OutputImage失败,原因是:" + ex.ToString();
                    Result = false;
                    return;
                }
                #endregion
 
                if (Msg == "运行超时")
                {
                    Result = false;
                    return;
                }
 
                return;
            }
            catch (Exception ex)
            {
                Msg = "运行失败,原因是:" + ex.ToString().TrimEnd();
                OutputImage = null;
                Result = false;
                return;
            }
            finally
            {
                bCompleted = true;
                #region 内存释放
                if (!Result)
                {
                    Params.Outputs.Add("FeetX", 0.0);
                    Params.Outputs.Add("FeetY", 0.0);
 
                    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());
                }
                #endregion
            }
        }
    }
}