lixiaojun
2025-03-20 5066a3d90ab19f8380dbb4159d57b0b8e3f17649
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
namespace Yw.WinFrmUI.Hydro
{
    /// <summary>
    /// 包围盒缓存辅助类
    /// </summary>
    internal class BoundingBox32dCacheHelper
    {
 
        /// <summary>
        /// 
        /// </summary>
        public BoundingBox32dCacheHelper(NetworkL3d nw, Vector32dCacheHelper vc)
        {
            _nw = nw;
            _vc = vc;
            Initial();
        }
 
        private NetworkL3d _nw = null;
        private Vector32dCacheHelper _vc = null;
        private Dictionary<string, BoundingBox3> _dict = new();
 
        //初始化
        private void Initial()
        {
            if (_nw == null)
            {
                return;
            }
            if (_vc == null)
            {
                return;
            }
            _dict.Clear();
            _nw.Nodes.ForEach(x =>
            {
                var pts = _vc.GetPositions(x.Id);
                if (pts != null && pts.Count > 0)
                {
                    var bx = BoundingBox3Helper.CalcuPointBoundingBox(pts[0], x.Style2d.Normal.Radiu);
                    _dict.Add(x.Id, bx);
                }
            });
            _nw.Links.ForEach((Action<LinkL3d>)(x =>
            {
                var pts = _vc.GetPositions(x.Id);
                if (pts != null && pts.Count > 0)
                {
                    var bx = BoundingBox3Helper.CalcuLineBoundingBox(pts[0], pts[1], x.Style2d.Normal.Width);
                    _dict.Add(x.Id, bx);
                }
            }));
        }
 
        /// <summary>
        /// 获取包围盒
        /// </summary>
        public BoundingBox3 GetBoundingBox(string id)
        {
            if (_dict.ContainsKey(id))
            {
                return _dict[id];
            }
            return default;
        }
 
    }
}