From 7507591ef45cfa8f1080f6dbf68b411edcc7f086 Mon Sep 17 00:00:00 2001
From: lixiaojun <1287241240@qq.com>
Date: 星期日, 03 十一月 2024 15:42:56 +0800
Subject: [PATCH] 水力存储优化

---
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/02-bimface/XhsProjectSimulationBimfaceCtrl.cs |  523 ++++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 350 insertions(+), 173 deletions(-)

diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/02-bimface/XhsProjectSimulationBimfaceCtrl.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/02-bimface/XhsProjectSimulationBimfaceCtrl.cs
index 1bb0450..d305b90 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/02-bimface/XhsProjectSimulationBimfaceCtrl.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/02-bimface/XhsProjectSimulationBimfaceCtrl.cs
@@ -1,5 +1,4 @@
-锘縰sing DevExpress.Office.Utils;
-using DevExpress.Xpo.Helpers;
+锘縰sing DevExpress.Xpo.Helpers;
 using Yw.WinFrmUI.Bimface;
 
 namespace HStation.WinFrmUI
@@ -9,31 +8,130 @@
         public XhsProjectSimulationBimfaceCtrl()
         {
             InitializeComponent();
-            this.bimfaceInterop3dContainer1.LoadCompletedEvent += BimfaceInterop3dContainer1_LoadCompletedEvent;
-            this.bimfaceInterop3dContainer1.LoadViewCompletedEvent += BimfaceInterop3dContainer1_LoadViewCompletedEvent;
-            this.bimfaceInterop3dContainer1.ClickInEvent += BimfaceInterop3dContainer1_ClickInEvent;
-            this.bimfaceInterop3dContainer1.ClickOutEvent += BimfaceInterop3dContainer1_ClickOutEvent;
         }
 
         /// <summary>
-        /// 姘村姏鐐瑰嚮浜嬩欢
+        /// 姘村姏鐐瑰嚮浜嬩欢锛堝寘鍚乏閿拰鍙抽敭锛�
         /// </summary>
         public event Action<Yw.Model.HydroParterInfo> HydroClickEvent;
+        /// <summary>
+        /// 姘村姏鐐瑰嚮浜嬩欢锛堜粎宸﹂敭锛�
+        /// </summary>
+        public event Action<Yw.Model.HydroParterInfo> HydroMouseLeftClickEvent;
         /// <summary>
         /// 鍔犺浇瀹屾垚浜嬩欢
         /// </summary>
         public event Action LoadCompletedEvent;
 
-
+        //椤圭洰
         private HStation.Vmo.XhsProjectVmo _project = null;
+        //椤圭洰绔�
         private HStation.Vmo.XhsProjectSiteVmo _projectSite = null;
+        //鑾峰彇姘村姏淇℃伅鏂规硶
         private Func<Yw.Model.HydroModelInfo> _hydroInfoFunc = null;
 
+        //鑾峰彇Bimface 浜や簰瀹瑰櫒
+        private BimfaceInterop3dContainer GetBimfaceInteropContainer()
+        {
+            if (_bimfaceInteropContainer == null)
+            {
+                _bimfaceInteropContainer = new BimfaceInterop3dContainer();
+                _bimfaceInteropContainer.Dock = DockStyle.Fill;
+                _bimfaceInteropContainer.LoadCompletedEvent += async () =>
+                {
+                    if (_projectSite == null)
+                    {
+                        return;
+                    }
+
+                    var relation = await BLLFactory<Yw.BLL.BimfaceFileRelation>.Instance
+                        .GetDefaultByObjectTypeAndObjectIDOfPurpose
+                            (HStation.Xhs.DataType.XhsProjectSite, _projectSite.ID, HStation.Xhs.Purpose.Simulation);
+                    if (relation == null)
+                    {
+                        return;
+                    }
+
+                    var bimfaceFile = await BLLFactory<Yw.BLL.BimfaceFile>.Instance.GetByID(relation.BimfaceFileID);
+                    if (bimfaceFile == null)
+                    {
+                        return;
+                    }
+
+                    var viewToken = await BimfaceHelper.GetViewToken(bimfaceFile.BimfaceId);
+                    if (string.IsNullOrEmpty(viewToken))
+                    {
+                        return;
+                    }
+                    await _bimfaceInteropContainer.LoadView(viewToken);
+                };
+                _bimfaceInteropContainer.LoadFailedEvent += () =>
+                {
+                    TipFormHelper.ShowError("涓夌淮妯″瀷瀹瑰櫒鍔犺浇澶辫触");
+                };
+                _bimfaceInteropContainer.LoadViewCompletedEvent += () =>
+                {
+                    this.LoadCompletedEvent?.Invoke();
+                };
+                _bimfaceInteropContainer.LoadViewFailedEvent += (obj) =>
+                {
+                    TipFormHelper.ShowError($"涓夌淮妯″瀷鍔犺浇澶辫触");
+                };
+                _bimfaceInteropContainer.ClickInEvent += (obj) =>
+                {
+                    if (obj == null)
+                    {
+                        return;
+                    }
+                    if (this.HydroClickEvent != null)
+                    {
+                        var hydroInfo = _hydroInfoFunc?.Invoke();
+                        if (hydroInfo == null)
+                        {
+                            return;
+                        }
+                        var allParterList = hydroInfo.GetAllParters();
+                        var parter = allParterList?.Find(x => x.Code == obj.ObjectId);
+                        this.HydroClickEvent.Invoke(parter);
+                    }
+                };
+                _bimfaceInteropContainer.ClickOutEvent += (obj) =>
+                {
+                    this.HydroClickEvent?.Invoke(null);
+                };
+                _bimfaceInteropContainer.MouseLeftClickInEvent += (obj) =>
+                {
+                    if (obj == null)
+                    {
+                        return;
+                    }
+                    if (this.HydroMouseLeftClickEvent != null)
+                    {
+                        var hydroInfo = _hydroInfoFunc?.Invoke();
+                        if (hydroInfo == null)
+                        {
+                            return;
+                        }
+                        var allParterList = hydroInfo.GetAllParters();
+                        var parter = allParterList?.Find(x => x.Code == obj.ObjectId);
+                        this.HydroMouseLeftClickEvent.Invoke(parter);
+                    }
+                };
+                _bimfaceInteropContainer.MouseLeftClickOutEvent += (obj) =>
+                {
+                    this.HydroMouseLeftClickEvent?.Invoke(null);
+                };
+            }
+            return _bimfaceInteropContainer;
+        }
+        //bimface 浜や簰瀹瑰櫒
+        private BimfaceInterop3dContainer _bimfaceInteropContainer = null;
 
         /// <summary>
-        /// 缁戝畾鏁版嵁
+        /// 鍒濆鍖栨暟鎹�
+        /// 浠呮敮鎸佽皟鐢ㄤ竴娆�
         /// </summary>
-        public async Task SetBindingData
+        public async Task InitialData
             (
                 HStation.Vmo.XhsProjectVmo project,
                 HStation.Vmo.XhsProjectSiteVmo projectSite,
@@ -51,69 +149,10 @@
             {
                 _projectSite = await BLLFactory<HStation.BLL.XhsProjectSite>.Instance.GetDefaultByProjectID(_project.ID);
             }
-            await this.bimfaceInterop3dContainer1.InitialContainer();
-        }
-
-        //椤甸潰鍔犺浇瀹屾垚鍚庤Е鍙�
-        private async void BimfaceInterop3dContainer1_LoadCompletedEvent()
-        {
-            if (_projectSite == null)
-            {
-                return;
-            }
-
-            var relation = await BLLFactory<Yw.BLL.BimfaceFileRelation>.Instance
-                .GetDefaultByObjectTypeAndObjectIDOfPurpose
-                    (HStation.Xhs.DataType.XhsProjectSite, _projectSite.ID, HStation.Xhs.Purpose.Simulation);
-            if (relation == null)
-            {
-                return;
-            }
-
-            var bimfaceFile = await BLLFactory<Yw.BLL.BimfaceFile>.Instance.GetByID(relation.BimfaceFileID);
-            if (bimfaceFile == null)
-            {
-                return;
-            }
-
-            var viewToken = await BimfaceHelper.GetViewToken(bimfaceFile.BimfaceId);
-            if (string.IsNullOrEmpty(viewToken))
-            {
-                return;
-            }
-            await this.bimfaceInterop3dContainer1.LoadView(viewToken);
-        }
-
-        //椤甸潰瑙嗗浘鍔犺浇瀹屾垚鍚庤Е鍙�
-        private void BimfaceInterop3dContainer1_LoadViewCompletedEvent()
-        {
-            this.LoadCompletedEvent?.Invoke();
-        }
-
-        //鍐呴儴鐐瑰嚮
-        private void BimfaceInterop3dContainer1_ClickInEvent(Yw.WinFrmUI.Bimface.ClickIn3dInfo obj)
-        {
-            if (obj == null)
-            {
-                return;
-            }
-            if (HydroClickEvent != null)
-            {
-                var hydroInfo = _hydroInfoFunc?.Invoke();
-                if (hydroInfo == null)
-                {
-                    return;
-                }
-                var allParterList = hydroInfo.GetAllParters();
-                var parter = allParterList?.Find(x => x.Code == obj.ObjectId);
-                this.HydroClickEvent.Invoke(parter);
-            }
-        }
-
-        //澶栭儴鐐瑰嚮
-        private void BimfaceInterop3dContainer1_ClickOutEvent(ClickOut3dInfo obj)
-        {
-            this.HydroClickEvent?.Invoke(null);
+            var bimfaceInteropContainer = GetBimfaceInteropContainer();
+            this.Controls.Clear();
+            this.Controls.Add(bimfaceInteropContainer);
+            await bimfaceInteropContainer.InitialContainer();
         }
 
 
@@ -126,7 +165,11 @@
         /// <returns></returns>
         public async Task ShowComponents(List<string> elementIds)
         {
-            await this.bimfaceInterop3dContainer1.ShowComponents(elementIds);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.ShowComponents(elementIds);
         }
 
         /// <summary>
@@ -136,7 +179,11 @@
         /// <returns></returns>
         public async Task HideComponents(List<string> elementIds)
         {
-            await this.bimfaceInterop3dContainer1.HideComponents(elementIds);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.HideComponents(elementIds);
         }
 
         /// <summary>
@@ -145,7 +192,11 @@
         /// <returns></returns>
         public async Task ShowAllComponents()
         {
-            await this.bimfaceInterop3dContainer1.ShowAllComponents();
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.ShowAllComponents();
         }
 
         #endregion
@@ -159,7 +210,11 @@
         /// <returns></returns>
         public async Task TranslucentComponents(List<string> elementIds)
         {
-            await this.bimfaceInterop3dContainer1.TranslucentComponents(elementIds);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.TranslucentComponents(elementIds);
         }
 
         /// <summary>
@@ -169,7 +224,11 @@
         /// <returns></returns>
         public async Task OpaqueComponents(List<string> elementIds)
         {
-            await this.bimfaceInterop3dContainer1.OpaqueComponents(elementIds);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.OpaqueComponents(elementIds);
         }
 
         #endregion
@@ -182,7 +241,11 @@
         /// <returns></returns>
         public async Task SetSelectedComponents(List<string> elements)
         {
-            await this.bimfaceInterop3dContainer1.SetSelectedComponents(elements);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.SetSelectedComponents(elements);
         }
 
         /// <summary>
@@ -192,7 +255,11 @@
         /// <returns></returns>
         public async Task AddSelectedComponents(List<string> elements)
         {
-            await this.bimfaceInterop3dContainer1.AddSelectedComponents(elements);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.AddSelectedComponents(elements);
         }
 
         /// <summary>
@@ -202,7 +269,11 @@
         /// <returns></returns>
         public async Task RemoveSelectedComponents(List<string> elements)
         {
-            await this.bimfaceInterop3dContainer1.RemoveSelectedComponents(elements);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.RemoveSelectedComponents(elements);
         }
 
         /// <summary>
@@ -212,7 +283,11 @@
         /// <returns></returns>
         public async Task ClearSelectedComponents()
         {
-            await this.bimfaceInterop3dContainer1.ClearSelectedComponents();
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.ClearSelectedComponents();
         }
 
         #endregion
@@ -224,7 +299,11 @@
         /// </summary>
         public async Task ZoomToComponent(string elementId)
         {
-            await this.bimfaceInterop3dContainer1.ZoomToComponent(elementId);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.ZoomToComponent(elementId);
         }
 
         /// <summary>
@@ -232,7 +311,11 @@
         /// </summary>
         public async Task ZoomToSelectedComponents()
         {
-            await this.bimfaceInterop3dContainer1.ZoomToSelectedComponents();
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.ZoomToSelectedComponents();
         }
 
         /// <summary>
@@ -240,27 +323,42 @@
         /// </summary>
         public async Task ZoomAndSelectComponents(List<string> elementIds)
         {
-            await this.bimfaceInterop3dContainer1.ZoomAndSelectComponents(elementIds);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.ZoomAndSelectComponents(elementIds);
         }
 
         #endregion
 
         #region 寮鸿皟鏋勪欢
 
+        private const string _blinkColor = "#32D3A6";//寮鸿皟鏋勪欢棰滆壊
+        private const double _blinkTransparency = 0.8d; //寮鸿皟鏋勪欢閫忔槑搴�
+
         /// <summary>
         /// 璁剧疆寮鸿皟鏋勪欢
         /// </summary>
         public async Task SetBlinkComponents(List<string> elementIds, string color, double transparency)
         {
-            await this.bimfaceInterop3dContainer1.SetBlinkComponents(elementIds, color, transparency);
+            await _bimfaceInteropContainer?.SetBlinkComponents(elementIds, color, transparency);
+        }
+
+        /// <summary>
+        /// 璁剧疆寮鸿皟鏋勪欢
+        /// </summary>
+        public async Task SetBlinkComponents(List<string> elementIds)
+        {
+            await _bimfaceInteropContainer?.SetBlinkComponents(elementIds, _blinkColor, _blinkTransparency);
         }
 
         /// <summary>
         /// 娓呴櫎寮鸿皟鏋勪欢
         /// </summary>
-        public async Task SetBlinkComponents()
+        public async Task ClearBlinkComponents()
         {
-            await this.bimfaceInterop3dContainer1.ClearBlinkComponents();
+            await _bimfaceInteropContainer?.ClearBlinkComponents();
         }
 
         #endregion
@@ -272,98 +370,33 @@
         /// </summary>
         public async Task OverrideComponentsColor(List<string> elementIds, string color, double transparency)
         {
-            await this.bimfaceInterop3dContainer1.OverrideComponentsColor(elementIds, color, transparency);
+            if (_bimfaceInteropContainer == null)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer.OverrideComponentsColor(elementIds, color, transparency);
         }
 
         /// <summary>
         /// 鎭㈠鏋勪欢棰滆壊
         /// </summary>
-        public async Task SetBlinkComponents(List<string> elementIds)
+        public async Task RestoreComponentsColor(List<string> elementIds)
         {
-            await this.bimfaceInterop3dContainer1.RestoreComponentsColor(elementIds);
-        }
-
-        #endregion
-
-        #region 鑷畾涔夋爣绛�
-
-        /// <summary>
-        /// 璁剧疆鑷畾涔夋爣绛�
-        /// </summary>
-        public async Task SetCustomLabels(List<CustomLabel> obj)
-        {
-            await this.bimfaceInterop3dContainer1.SetCustomLabels(obj);
-        }
-
-        /// <summary>
-        /// 娓呴櫎鑷畾涔夋爣绛�
-        /// </summary>
-        public async Task ClearCustomLabels()
-        {
-            await this.bimfaceInterop3dContainer1.ClearCustomLabels();
-        }
-
-
-        #endregion
-
-        #region 涓氬姟
-
-        #region 杩炴帴鏋勪欢棰滆壊
-
-        private const string _linkComponentColor = "#008B00";
-        private const double _linkComponentTransparency = 0.8;
-        private List<string> _linkComponentIds = null;//杩炴帴鏋勪欢id鍒楄〃
-
-        /// <summary>
-        /// 璁剧疆杩炴帴鏋勪欢棰滆壊
-        /// </summary>
-        public async Task SetLinkComponentsColor(List<string> elementIds)
-        {
-            if (_linkComponentIds != null && _linkComponentIds.Count > 0)
-            {
-                await this.bimfaceInterop3dContainer1.RestoreComponentsColor(_linkComponentIds);
-            }
-            _linkComponentIds = elementIds;
-            if (elementIds == null || elementIds.Count < 1)
+            if (_bimfaceInteropContainer == null)
             {
                 return;
             }
-            await this.bimfaceInterop3dContainer1.OverrideComponentsColor(elementIds, _linkComponentColor, _linkComponentTransparency);
+            await _bimfaceInteropContainer.RestoreComponentsColor(elementIds);
         }
 
         #endregion
 
-        #region 璁剧疆Open鏋勪欢棰滆壊
-
-        private const string _openComponentColor = "#2E8B57";
-        private const double _openComponentTransparency = 0.8;
-        private List<string> _openComponentIds = null;//Open鏋勪欢id鍒楄〃
+        #region 涓氬姟璁$畻鑷畾涔夋爣绛�
 
         /// <summary>
-        /// 璁剧疆Open鏋勪欢棰滆壊
+        /// 鏄剧ず涓氬姟璁$畻鑷畾涔夋爣绛�
         /// </summary>
-        public async Task SetOpenComponentsColor(List<string> elementIds)
-        {
-            if (_openComponentIds != null && _openComponentIds.Count > 0)
-            {
-                await this.bimfaceInterop3dContainer1.RestoreComponentsColor(_openComponentIds);
-            }
-            _openComponentIds = elementIds;
-            if (elementIds == null || elementIds.Count < 1)
-            {
-                return;
-            }
-            await this.bimfaceInterop3dContainer1.OverrideComponentsColor(elementIds, _openComponentColor, _openComponentTransparency);
-        }
-
-        #endregion
-
-        #region 鑷畾涔夋爣绛�
-
-        /// <summary>
-        /// 鏄剧ず璁$畻鑷畾涔夋爣绛�
-        /// </summary>
-        public async Task ShowCalcuCustomLabels(CalcuResult calcuResult)
+        public async Task SetLogicCalcuCustomLabels(CalcuResult calcuResult)
         {
             var hydroInfo = _hydroInfoFunc?.Invoke();
             if (hydroInfo == null)
@@ -376,39 +409,183 @@
             }
             if (!calcuResult.Succeed)
             {
-                await this.bimfaceInterop3dContainer1.ClearCustomLabels();
+                await _bimfaceInteropContainer?.ClearLogicCalcuCustomLabels();
                 return;
             }
-            var obj = new List<CustomLabel>();
+            var obj = new List<LogicCalcuCustomLabel>();
             var allParterList = hydroInfo.GetAllParters();
             allParterList?.ForEach(x =>
             {
                 if (x is Yw.Model.HydroPumpInfo pump)
                 {
+                    var hz = Math.Round(pump.RatedHz * pump.SpeedRatio);
                     var calcuPump = calcuResult.LinkList.Find(x => x.Id == pump.Code);
                     var calcuPumpStart = calcuResult.NodeList.Find(x => x.Id == pump.StartCode);
                     var calcuPumpEnd = calcuResult.NodeList.Find(x => x.Id == pump.EndCode);
-                    var pumpCustomLabel = new CustomLabel();
+                    var pumpCustomLabel = new LogicCalcuCustomLabel();
                     pumpCustomLabel.Id = pump.Code;
-                    pumpCustomLabel.Data = new List<CustomLabelItem>()
+                    pumpCustomLabel.Distance = 10000;
+                    pumpCustomLabel.Data = new List<LogicCalcuCustomLabelItem>()
                     {
-                        new CustomLabelItem(){ Name="娴侀噺",Value=Math.Round(calcuPump.Flow,1).ToString(),Unit="m鲁/h"},
-                        new CustomLabelItem(){ Name="杩涘彛鍘嬪姏",Value=Math.Round(calcuPumpStart.Head,4).ToString(),Unit="m"},
-                        new CustomLabelItem(){ Name="鍑哄彛鍘嬪姏",Value=Math.Round(calcuPumpEnd.Head,4).ToString(),Unit="m"},
+                        new LogicCalcuCustomLabelItem(){ Name="鐘舵��",Value=HydroLinkStatusHelper.GetStatusName(pump.LinkStatus),Unit=string.Empty},
+                        new LogicCalcuCustomLabelItem(){ Name="棰戠巼",Value=hz.ToString(),Unit=string.Empty},
+                        new LogicCalcuCustomLabelItem(){ Name="娴侀噺",Value=Math.Round(calcuPump.Flow,1).ToString(),Unit="m鲁/h"},
+                        new LogicCalcuCustomLabelItem(){ Name="杩涘彛鍘嬪姏",Value=Math.Round(calcuPumpStart.Head,4).ToString(),Unit="m"},
+                        new LogicCalcuCustomLabelItem(){ Name="鍑哄彛鍘嬪姏",Value=Math.Round(calcuPumpEnd.Head,4).ToString(),Unit="m"},
                     };
                     obj.Add(pumpCustomLabel);
                 }
                 else if (x is Yw.Model.HydroEmitterInfo emitter)
                 {
-
+                    var calcuEmitter = calcuResult.NodeList.Find(x => x.Id == emitter.Code);
+                    var emitterCustomLabel = new LogicCalcuCustomLabel();
+                    emitterCustomLabel.Id = emitter.Code;
+                    emitterCustomLabel.Distance = 10000;
+                    emitterCustomLabel.Data = new List<LogicCalcuCustomLabelItem>()
+                    {
+                        new LogicCalcuCustomLabelItem(){ Name="娴侀噺",Value=Math.Round(calcuEmitter.Demand,1).ToString(),Unit="m鲁/h"},
+                        new LogicCalcuCustomLabelItem(){ Name="鍘嬪姏",Value=Math.Round(calcuEmitter.Head,4).ToString(),Unit="m"}
+                    };
+                    obj.Add(emitterCustomLabel);
                 }
             });
+            await _bimfaceInteropContainer?.SetLogicCalcuCustomLabels(obj);
+        }
 
-            await this.bimfaceInterop3dContainer1.SetCustomLabels(obj);
+        /// <summary>
+        /// 娓呴櫎涓氬姟璁$畻鑷畾涔夋爣绛�
+        /// </summary>
+        public async Task ClearLogicCalcuCustomLabels()
+        {
+            await _bimfaceInteropContainer?.ClearLogicCalcuCustomLabels();
         }
 
         #endregion
 
+        #region 涓氬姟鏍囨敞寮曠嚎鏍囩
+
+        /// <summary>
+        /// 璁剧疆涓氬姟鏍囨敞寮曠嚎鏍囩
+        /// </summary>
+        public async Task SetLogicMarkLeadLabels(List<LogicMarkLeadLabel> obj)
+        {
+            await _bimfaceInteropContainer?.SetLogicMarkLeadLabels(obj);
+        }
+
+        /// <summary>
+        /// 娓呴櫎涓氬姟鏍囨敞寮曠嚎鏍囩
+        /// </summary>
+        public async Task ClearLogicMarkLeadLabels()
+        {
+            await _bimfaceInteropContainer?.ClearLogicMarkLeadLabels();
+        }
+
+        #endregion
+
+        #region 涓氬姟姘存祦鍔ㄧ敾
+
+        /// <summary>
+        /// 鍔犺浇姘存祦鍔ㄧ敾
+        /// </summary>
+        public async Task LoadFlowEffect(LogicFlowEffect obj)
+        {
+            await _bimfaceInteropContainer?.LoadFlowEffect(obj);
+        }
+
+        /// <summary>
+        /// 鍔犺浇姘存祦鍔ㄧ敾
+        /// </summary>
+        public async Task LoadFlowEffect(List<LogicFlowEffect> obj)
+        {
+            await _bimfaceInteropContainer?.LoadFlowEffectList(obj);
+        }
+
+        /// <summary>
+        /// 鍗歌浇姘存祦鍔ㄧ敾
+        /// </summary>
+        public async Task UnloadFlowEffect()
+        {
+            await _bimfaceInteropContainer?.UnloadFlowEffect();
+        }
+
+        /// <summary>
+        /// 閫氳繃Id鍗歌浇姘存祦鍔ㄧ敾
+        /// </summary>
+        public async Task UnloadFlowEffectById(string Id)
+        {
+            await _bimfaceInteropContainer?.UnloadFlowEffectById(Id);
+        }
+
+        #endregion
+
+        #region 杩炴帴鏋勪欢棰滆壊
+
+        private const string _linkComponentColor = "#008B00";//杩炴帴鏋勪欢棰滆壊
+        private const string _linkStartComponentColor = "#094EF7";//杩炴帴寮�濮嬫瀯浠堕鑹�
+        private const string _linkEndComponentColor = "#ECBF08";//杩炴帴缁撴潫鏋勪欢棰滆壊
+        private const double _linkComponentTransparency = 0.8;
+        private List<string> _linkComponentIds = null;//杩炴帴鏋勪欢id鍒楄〃
+
+        /// <summary>
+        /// 璁剧疆杩炴帴鏋勪欢棰滆壊
+        /// </summary>
+        public async Task SetLinkComponentsColor(List<string> elementIds)
+        {
+            await RestoreLinkComponentsColor();
+            _linkComponentIds = elementIds;
+            if (_linkComponentIds == null || _linkComponentIds.Count < 1)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer?.OverrideComponentsColor(_linkComponentIds, _linkComponentColor, _linkComponentTransparency);
+        }
+
+        /// <summary>
+        /// 鎭㈠杩炴帴鏋勪欢棰滆壊
+        /// </summary>
+        public async Task RestoreLinkComponentsColor()
+        {
+            if (_linkComponentIds == null || _linkComponentIds.Count < 1)
+            {
+                return;
+            }
+            await _bimfaceInteropContainer?.RestoreComponentsColor(_linkComponentIds);
+        }
+
+        /// <summary>
+        /// 璁剧疆杩炴帴寮�濮嬫瀯浠堕鑹�
+        /// </summary>
+        public async Task SetLinkStartComponentsColor(List<string> elementIds)
+        {
+            if (elementIds == null || elementIds.Count < 1)
+            {
+                return;
+            }
+            if (_linkComponentIds == null)
+            {
+                _linkComponentIds = new List<string>();
+            }
+            _linkComponentIds.AddRange(elementIds);
+            await _bimfaceInteropContainer?.OverrideComponentsColor(elementIds, _linkStartComponentColor, _linkComponentTransparency);
+        }
+
+        /// <summary>
+        /// 璁剧疆杩炴帴缁撴潫鏋勪欢棰滆壊
+        /// </summary>
+        public async Task SetLinkEndComponentsColor(List<string> elementIds)
+        {
+            if (elementIds == null || elementIds.Count < 1)
+            {
+                return;
+            }
+            if (_linkComponentIds == null)
+            {
+                _linkComponentIds = new List<string>();
+            }
+            _linkComponentIds.AddRange(elementIds);
+            await _bimfaceInteropContainer?.OverrideComponentsColor(elementIds, _linkEndComponentColor, _linkComponentTransparency);
+        }
+
         #endregion
 
 

--
Gitblit v1.9.3