Shuxia Ning
2024-11-13 208ca42e1c20afafbe48d66259d553ee81eb48ed
WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/01-property/XhsProjectSimulationPropertyCtrl.cs
@@ -11,14 +11,21 @@
        public XhsProjectSimulationPropertyCtrl()
        {
            InitializeComponent();
            this.hydroVisualPropertyCtrl1.MatchingDbEvent += HydroParterPropertyCtrl1_MatchingDbEvent;
            this.hydroVisualPropertyCtrl1.SetCurveEvent += HydroParterPropertyCtrl1_SetCurveEvent;
            this.hydroVisualPropertyCtrl1.SetPatternEvent += HydroParterPropertyCtrl1_SetPatternEvent;
            this.hydroVisualPropertyCtrl1.BlinkLinkParterEvent += HydroParterPropertyCtrl1_BlinkLinkParterEvent;
            this.hydroVisualPropertyCtrl1.HydroViewEvent += HydroParterPropertyCtrl1_ViewParterEvent;
            this.hydroParterPropertyCtrl1.PropertyValueChangedEvent += HydroParterPropertyCtrl1_PropertyValueChangedEvent;
            this.hydroParterPropertyCtrl1.PropertyValueChangingEvent += HydroParterPropertyCtrl1_PropertyValueChangingEvent;
            this.hydroParterPropertyCtrl1.MatchingDbEvent += HydroParterPropertyCtrl1_MatchingDbEvent;
            this.hydroParterPropertyCtrl1.SetCurveEvent += HydroParterPropertyCtrl1_SetCurveEvent;
            this.hydroParterPropertyCtrl1.SetPatternEvent += HydroParterPropertyCtrl1_SetPatternEvent;
            this.hydroParterPropertyCtrl1.BlinkLinkParterEvent += HydroParterPropertyCtrl1_BlinkLinkParterEvent;
            this.hydroVisualPropertyCtrl1.PropertyValueChangedEvent += HydroParterPropertyCtrl1_PropertyValueChangedEvent;
            this.hydroVisualPropertyCtrl1.MarkPropertyValueChangedEvent += HydroParterPropertyCtrl1_MarkPropertyValueChangedEvent;
            this.hydroVisualPropertyCtrl1.GradingPropertyValueChangedEvent += HydroParterPropertyCtrl1_GradingPropertyValueChangedEvent;
            this.hydroVisualPropertyCtrl1.FlowDirectionPropertyValueChangedEvent += HydroParterPropertyCtrl1_FlowDirectionPropertyValueChangedEvent;
        }
        /// <summary>
@@ -31,7 +38,27 @@
        /// <summary>
        /// 属性值改变事件
        /// </summary>
        public event Func<Yw.Model.HydroParterInfo, bool> PropertyValueChangedEvent;
        public event Action<Yw.Model.HydroVisualInfo> PropertyValueChangedEvent;
        /// <summary>
        /// 标注属性值改变事件
        /// </summary>
        public event Action<Yw.Model.HydroVisualInfo> MarkPropertyValueChangedEvent;
        /// <summary>
        /// 分级属性值改变事件
        /// </summary>
        public event Action<Yw.Model.HydroVisualInfo> GradingPropertyValueChangedEvent;
        /// <summary>
        /// 流向属性值改变事件
        /// </summary>
        public event Action<Yw.Model.HydroVisualInfo> FlowDirectionPropertyValueChangedEvent;
        /// <summary>
        /// 查看构件事件
        /// </summary>
        public event Action<Yw.Model.HydroVisualInfo> ViewParterEvent;
        //水力信息方法
        private Func<Yw.Model.HydroModelInfo> _hydroInfoFunc = null;
@@ -44,7 +71,6 @@
        {
            _hydroInfoFunc = hydroInfoFunc;
            _allHydroCalcuResultListFunc = allHydroCalcuResultListFunc;
            this.hydroParterPropertyCtrl1.InitialData(hydroInfoFunc);
        }
        //获取水力信息
@@ -53,65 +79,33 @@
            var hydroInfo = _hydroInfoFunc?.Invoke();
            if (hydroInfo == null)
            {
                this.hydroParterPropertyCtrl1.SelectedObject = null;
                this.hydroVisualPropertyCtrl1.SelectedObject = null;
                return default;
            }
            return hydroInfo;
        }
        /// <summary>
        /// 选择组件
        /// </summary>
        public void SelectParter(long id)
        public HydroVisualViewModel SelectedObject
        {
            var hydroInfo = GetHydroInfo();
            if (hydroInfo == null)
            {
                return;
            }
            var allParterList = hydroInfo.GetAllParters();
            var parter = allParterList?.Find(x => x.ID == id);
            SelectParter(parter);
            get { return this.hydroVisualPropertyCtrl1.SelectedObject; }
            set { this.hydroVisualPropertyCtrl1.SelectedObject = value; }
        }
        /// <summary>
        /// 选择组件
        /// 更新行,样式不变
        /// </summary>
        public void SelectParter(string code)
        public void UpdateRows()
        {
            var hydroInfo = GetHydroInfo();
            if (hydroInfo == null)
            {
                return;
            }
            var allParterList = hydroInfo.GetAllParters();
            var parter = allParterList?.Find(x => x.Code == code);
            SelectParter(parter);
            this.hydroVisualPropertyCtrl1?.UpdateRows();
        }
        /// <summary>
        /// 选择组件
        /// 重新载入数据
        /// </summary>
        public void SelectParter(Yw.Model.HydroParterInfo parter)
        public void UpdateData()
        {
            var hydroInfo = GetHydroInfo();
            if (hydroInfo == null)
            {
                return;
            }
            if (parter != null)
            {
                var vm = Yw.WinFrmUI.HydroParterViewModelBuilder.CreateViewModel(parter, hydroInfo);
                this.hydroParterPropertyCtrl1.SelectedObject = vm;
            }
        }
        /// <summary>
        /// 取消选择组件
        /// </summary>
        public void CancelSelectParter()
        {
            this.hydroParterPropertyCtrl1.SelectedObject = null;
            this.hydroVisualPropertyCtrl1?.UpdateData();
        }
        /// <summary>
@@ -119,13 +113,13 @@
        /// </summary>
        public void UpdateProperty()
        {
            var vm = this.hydroParterPropertyCtrl1.SelectedObject;
            var vm = this.hydroVisualPropertyCtrl1.SelectedObject;
            if (vm == null)
            {
                return;
            }
            vm.UpdateProperty();
            this.hydroParterPropertyCtrl1.UpdateRows();
            this.hydroVisualPropertyCtrl1.UpdateRows();
        }
        /// <summary>
@@ -137,13 +131,13 @@
            {
                return;
            }
            var vm = this.hydroParterPropertyCtrl1.SelectedObject;
            var vm = this.hydroVisualPropertyCtrl1.SelectedObject;
            if (vm == null)
            {
                return;
            }
            vm.UpdateCalcuProperty(calcuResult);
            this.hydroParterPropertyCtrl1.UpdateRows();
            this.hydroVisualPropertyCtrl1.UpdateRows();
        }
        //选择曲线
@@ -172,7 +166,7 @@
                            if (bol)
                            {
                                propViewModel.UpdateProperty();
                                this.hydroParterPropertyCtrl1.UpdateRows();
                                this.hydroVisualPropertyCtrl1.UpdateRows();
                            }
                            return bol;
                        };
@@ -192,8 +186,8 @@
                        return false;
                    }
                case Yw.WinFrmUI.HydroCurve.Valve:
                    {
                        return true;
                    {
                        return false;
                    }
                case Yw.WinFrmUI.HydroCurve.ValveQL:
                    {
@@ -225,18 +219,49 @@
        }
        //属性发生改变
        private bool HydroParterPropertyCtrl1_PropertyValueChangedEvent(HydroParterViewModel parterViewModel)
        private void HydroParterPropertyCtrl1_PropertyValueChangedEvent(HydroVisualViewModel vm)
        {
            if (parterViewModel == null)
            if (vm == null)
            {
                return false;
                return;
            }
            if (this.PropertyValueChangedEvent == null)
            {
                return false;
            }
            return this.PropertyValueChangedEvent.Invoke(parterViewModel.Vmo);
            this.PropertyValueChangedEvent?.Invoke(vm.Vmo);
        }
        //标注属性发生改变
        private void HydroParterPropertyCtrl1_MarkPropertyValueChangedEvent(HydroVisualViewModel vm)
        {
            if (vm == null)
            {
                return;
            }
            this.MarkPropertyValueChangedEvent?.Invoke(vm.Vmo);
        }
        //分级属性发生改变
        private void HydroParterPropertyCtrl1_GradingPropertyValueChangedEvent(HydroVisualViewModel vm)
        {
            if (vm == null)
            {
                return;
            }
            this.GradingPropertyValueChangedEvent?.Invoke(vm.Vmo);
        }
        //流向属性发生改变
        private void HydroParterPropertyCtrl1_FlowDirectionPropertyValueChangedEvent(HydroVisualViewModel vm)
        {
            if (vm == null)
            {
                return;
            }
            this.FlowDirectionPropertyValueChangedEvent?.Invoke(vm.Vmo);
        }
        //属性正在发生改变
        private bool HydroParterPropertyCtrl1_PropertyValueChangingEvent(HydroParterViewModel arg)
@@ -257,7 +282,7 @@
            {
                return bol;
            }
            var catalog = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogCode(propertyViewModel.Catalog);
            var catalog = Yw.WinFrmUI.HydroParterCatalogHelper.GetCode(propertyViewModel.Catalog);
            switch (catalog)
            {
                case Yw.Hydro.ParterCatalog.Pump://水泵
@@ -294,7 +319,12 @@
                        dlg.SetBindingData(input);
                        dlg.ReloadDataEvent += (rhs) =>
                        {
                            bol = AssetsMatchingParasHelper.Apply(hydroInfo, rhs);
                            var bol = AssetsMatchingParasHelper.Apply(hydroInfo, rhs);
                            if (bol)
                            {
                                propertyViewModel.UpdateProperty();
                                this.hydroVisualPropertyCtrl1.UpdateRows();
                            }
                        };
                        dlg.ShowDialog();
                    }
@@ -315,7 +345,12 @@
                        dlg.SetBindingData(input);
                        dlg.ReloadDataEvent += (output) =>
                        {
                            bol = AssetsMatchingParasHelper.Apply(hydroInfo, output);
                            var bol = AssetsMatchingParasHelper.Apply(hydroInfo, output);
                            if (bol)
                            {
                                propertyViewModel.UpdateProperty();
                                this.hydroVisualPropertyCtrl1.UpdateRows();
                            }
                        };
                        dlg.ShowDialog();
                    }
@@ -347,6 +382,16 @@
            this.BlinkLinkParterEvent?.Invoke(code, linkCode);
        }
        //查看构件
        private void HydroParterPropertyCtrl1_ViewParterEvent(HydroVisualViewModel vm)
        {
            if (vm == null)
            {
                return;
            }
            this.ViewParterEvent?.Invoke(vm.Vmo);
        }
    }
}