yangyin
2024-08-20 98e49c0dd42840a094837f7acae532bc237a719a
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
namespace HStation.Service.PhartRelation
{
    /// <summary>
    /// 特性曲线辅助类
    /// </summary>
    public class PerformCurveHelper
    { 
        /// <summary>
        /// 获取性能点列表
        /// </summary>
        public static List<Yw.Geometry.Point2d> GetFeatPointList(eGraphType graphType, string geometryInfo, int pointNumber = 12, double minSpace = 0.0001)
        {
            if (string.IsNullOrEmpty(geometryInfo))
            {
                return default;
            }
            List<Yw.Geometry.Point2d> pts = null;
            switch (graphType)
            {
                case eGraphType.PumpQH:
                    {
                        var curveQH = Yw.Pump.CurveQHHelper.ToModel(geometryInfo);
                        if (curveQH != null)
                        {
                            pts = curveQH.FeatCurve.GetPointList(pointNumber, minSpace);
                        }
                    }
                    break;
                case eGraphType.PumpQP:
                    {
                        var curveQP = Yw.Pump.CurveQPHelper.ToModel(geometryInfo);
                        if (curveQP != null)
                        {
                            pts = curveQP.FeatCurve.GetPointList(pointNumber, minSpace);
                        }
                    }
                    break;
                case eGraphType.PumpQE:
                    {
                        var curveQE = Yw.Pump.CurveQEHelper.ToModel(geometryInfo);
                        if (curveQE != null)
                        {
                            pts = curveQE.FeatCurve.GetPointList(pointNumber, minSpace);
                        }
                    }
                    break;  
                default: break;
            }
            return pts;
        }
 
        /// <summary>
        /// to 存储字符串
        /// </summary>
        public static string ToDbString(eGraphType graphType, Yw.Pump.eFeatType featType, List<Yw.Geometry.Point2d> pts)
        {
            var dbString = string.Empty;
            if (pts == null || pts.Count < 1)
            {
                return dbString;
            }
            Yw.Pump.IFeatCurve featCurve = null;
            switch (featType)
            {
                case Yw.Pump.eFeatType.Polynomial:
                    {
                        featCurve = new Yw.Pump.PolynomialCurve(pts);
                    }
                    break;
                case Yw.Pump.eFeatType.Cubic:
                    {
                        featCurve = new Yw.Pump.CubicCurve(pts);
                    }
                    break;
                default: break;
            }
            if (featCurve == null || featCurve.IsInvalid())
            {
                return dbString;
            }
 
            switch (graphType)
            {
                case eGraphType.PumpQH:
                    {
                        var curveQH = new Yw.Pump.CurveQH(featType, featCurve);
                        dbString = curveQH.ToDbString();
                    }
                    break;
                case eGraphType.PumpQP:
                    {
                        var curveQP = new Yw.Pump.CurveQP(featType, featCurve);
                        dbString = curveQP.ToDbString();
                    }
                    break;
                case eGraphType.PumpQE:
                    {
                        var curveQE = new Yw.Pump.CurveQE(featType, featCurve);
                        dbString = curveQE.ToDbString();
                    }
                    break;
                default: break;
            }
            return dbString;
        }
 
 
 
    }
}