From 146ca8c7eefe74d3b73c00a73e99e94e903be401 Mon Sep 17 00:00:00 2001 From: lixiaojun <1287241240@qq.com> Date: 星期四, 06 二月 2025 15:04:21 +0800 Subject: [PATCH] 增加工况管理功能和计算结果自由压力与绝对压力切换 --- WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/05-function/SimulationFunctionCtrl.cs | 215 ++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 211 insertions(+), 4 deletions(-) diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/05-function/SimulationFunctionCtrl.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/05-function/SimulationFunctionCtrl.cs index 4ac3b54..fd16739 100644 --- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/05-function/SimulationFunctionCtrl.cs +++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/05-function/SimulationFunctionCtrl.cs @@ -12,6 +12,8 @@ this.layoutControl1.SetupLayoutControl(); } + #region 椤圭洰浜嬩欢 + /// <summary> /// 鏄剧ず椤圭洰绔欎俊鎭簨浠� /// </summary> @@ -20,10 +22,11 @@ /// 鏄剧ず椤圭洰绔欐ā鎷熶簨浠� /// </summary> public event Action<XhsProjectVmo, XhsProjectSiteVmo, XhsSchemeVmo, Yw.Model.HydroModelInfo, Dictionary<HydroWorkingVmo, bool>, SvgImage> ShowProjectSiteSimulationEvent; - /// <summary> - /// 椤圭洰绔欏伐鍐甸�夋嫨鏀瑰彉浜嬩欢 - /// </summary> - public event Action<XhsProjectVmo, XhsProjectSiteVmo, XhsSchemeVmo, HydroWorkingVmo, bool> ProjectSiteWorkingCheckedEvent; + + #endregion + + #region 宸ュ喌浜嬩欢 + /// <summary> /// 椤圭洰绔欏伐鍐靛鍔犱簨浠� /// </summary> @@ -36,6 +39,19 @@ /// 椤圭洰绔欏伐鍐电Щ闄や簨浠� /// </summary> public event Action<XhsProjectVmo, XhsProjectSiteVmo, XhsSchemeVmo, HydroWorkingVmo> ProjectSiteWorkingRemoveEvent; + /// <summary> + /// 椤圭洰绔欏伐鍐甸�夋嫨鏀瑰彉浜嬩欢 + /// </summary> + public event Action<XhsProjectVmo, XhsProjectSiteVmo, XhsSchemeVmo, HydroWorkingVmo, bool> ProjectSiteWorkingCheckedEvent; + /// <summary> + /// 椤圭洰绔欏伐鍐甸噸杞戒簨浠� + /// </summary> + public event Action<XhsProjectVmo, XhsProjectSiteVmo, XhsSchemeVmo, Dictionary<HydroWorkingVmo, bool>> ProjectSiteWorkingReloadEvent; + + #endregion + + #region 鏂规浜嬩欢 + /// <summary> /// 鍒涘缓椤圭洰绔欐柟妗堜簨浠� /// </summary> @@ -52,6 +68,8 @@ /// 椤圭洰绔欐柟妗堢Щ闄や簨浠� /// </summary> public event Action<XhsProjectVmo, XhsProjectSiteVmo, XhsSchemeVmo> ProjectSiteSchemeRemoveEvent; + + #endregion private XhsProjectVmo _project = null;//椤圭洰 private XhsProjectSiteVmo _projectSite = null;//椤圭洰绔� @@ -101,6 +119,7 @@ }); await ShowInfo(); overlay.Close(); + await Task.Delay(2000); this.accordionControl1.ExpandAll(); } @@ -761,6 +780,194 @@ this.ProjectSiteWorkingRemoveEvent?.Invoke(_project, _projectSite, scheme, working); } + /// <summary> + /// 閲嶈浇宸ュ喌 + /// 閲嶈浇锛屼細瑙﹀彂閲嶈浇浜嬩欢 + /// </summary> + public void ReloadWorking(XhsSchemeVmo scheme, Dictionary<HydroWorkingVmo, bool> dict) + { + if (_project == null) + { + return; + } + if (_projectSite == null) + { + return; + } + if (dict == null) + { + dict = new Dictionary<HydroWorkingVmo, bool>(); + } + if (scheme == null) + { + var elements = this.elementProjectSiteSimulation.Elements.ToList(); + //瀛樺湪鍒欐洿鏂帮紝涓嶅瓨鍦ㄥ垯鍒犻櫎 + foreach (var ele in elements) + { + var working = ele.Tag as HydroWorkingVmo; + if (working != null) + { + if (ele.HeaderControl != null) + { + this.accordionControl1.Controls.Remove(ele.HeaderControl); + } + ele.HeaderControl = null; + + var key = dict.Keys.FirstOrDefault(x => x.ID == working.ID); + if (key == null) + { + //绉婚櫎element + this.elementProjectSiteSimulation.Elements.Remove(ele); + } + else + { + var ckEdit = new CheckEdit(); + ckEdit.Properties.AutoWidth = true; + ckEdit.Properties.Caption = string.Empty; + ckEdit.Checked = dict[key]; + ckEdit.CheckedChanged += (sender, e) => + { + if (_allWorkingCheckedListDict != null) + { + if (_allWorkingCheckedListDict.ContainsKey(key)) + { + _allWorkingCheckedListDict[key] = ckEdit.Checked; + } + } + this.ProjectSiteWorkingCheckedEvent?.Invoke(_project, _projectSite, null, key, ckEdit.Checked); + }; + this.accordionControl1.Controls.Add(ckEdit); + ele.HeaderControl = ckEdit; + ele.Style = DevExpress.XtraBars.Navigation.ElementStyle.Item; + ele.Text = key.Name; + ele.Hint = key.Description; + ele.Tag = key; + ele.Click += (sender, e) => + { + + }; + } + } + } + //涓嶅瓨鍦ㄥ垯澧炲姞 + foreach (var item in dict) + { + var ele = elements.FirstOrDefault(x => (x.Tag is HydroWorkingVmo) && (x.Tag as HydroWorkingVmo).ID == item.Key.ID); + if (ele == null) + { + //娣诲姞element + //鐩墠涓嶅瓨鍦ㄦ坊鍔犵殑鎯呭喌 + } + } + + if (this.elementProjectSiteSimulation.Elements.Count < 1) + { + this.elementProjectSiteSimulation.Style = DevExpress.XtraBars.Navigation.ElementStyle.Item; + } + else + { + this.elementProjectSiteSimulation.Style = DevExpress.XtraBars.Navigation.ElementStyle.Group; + } + _allWorkingCheckedListDict = dict; + } + else + { + var elementScheme = this.elementProjectSiteSchemeList.Elements + .FirstOrDefault(x => (x.Tag is XhsSchemeVmo) && (x.Tag as XhsSchemeVmo).ID == scheme.ID); + if (elementScheme == null) + { + return; + } + var elements = elementScheme.Elements.ToList(); + //瀛樺湪鍒欐洿鏂帮紝涓嶅瓨鍦ㄥ垯鍒犻櫎 + foreach (var ele in elements) + { + var working = ele.Tag as HydroWorkingVmo; + if (working != null) + { + if (ele.HeaderControl != null) + { + this.accordionControl1.Controls.Remove(ele.HeaderControl); + } + ele.HeaderControl = null; + + var key = dict.Keys.FirstOrDefault(x => x.ID == working.ID); + if (key == null) + { + //绉婚櫎element + elementScheme.Elements.Remove(ele); + } + else + { + var ckEdit = new CheckEdit(); + ckEdit.Properties.AutoWidth = true; + ckEdit.Properties.Caption = string.Empty; + ckEdit.Checked = dict[key]; + ckEdit.CheckedChanged += (sender, e) => + { + if (_allSchemeWorkingCheckedListDict != null) + { + if (_allSchemeWorkingCheckedListDict.ContainsKey(scheme)) + { + var workingCheckedDict = _allSchemeWorkingCheckedListDict[scheme]; + if (workingCheckedDict.ContainsKey(key)) + { + workingCheckedDict[key] = ckEdit.Checked; + } + } + } + this.ProjectSiteWorkingCheckedEvent?.Invoke(_project, _projectSite, scheme, key, ckEdit.Checked); + }; + this.accordionControl1.Controls.Add(ckEdit); + ele.HeaderControl = ckEdit; + ele.Style = DevExpress.XtraBars.Navigation.ElementStyle.Item; + ele.Text = key.Name; + ele.Hint = key.Description; + ele.Tag = key; + ele.Click += (sender, e) => + { + + }; + + } + } + } + //涓嶅瓨鍦ㄥ澧炲姞 + foreach (var item in dict) + { + var ele = elements.FirstOrDefault(x => (x.Tag is HydroWorkingVmo) && (x.Tag as HydroWorkingVmo).ID == item.Key.ID); + if (ele == null) + { + //娣诲姞element + //鐩墠涓嶅瓨鍦ㄥ鍔犵殑鎯呭喌 + } + } + if (elementScheme.Elements.Count < 1) + { + elementScheme.Style = DevExpress.XtraBars.Navigation.ElementStyle.Item; + } + else + { + elementScheme.Style = DevExpress.XtraBars.Navigation.ElementStyle.Group; + } + if (_allSchemeWorkingCheckedListDict == null) + { + _allSchemeWorkingCheckedListDict = new Dictionary<XhsSchemeVmo, Dictionary<HydroWorkingVmo, bool>>(); + } + var schemeKey = _allSchemeWorkingCheckedListDict.Keys.FirstOrDefault(x => x.ID == scheme.ID); + if (schemeKey == null) + { + _allSchemeWorkingCheckedListDict.Add(scheme, dict); + } + else + { + _allSchemeWorkingCheckedListDict[schemeKey] = dict; + } + } + + this.ProjectSiteWorkingReloadEvent?.Invoke(_project, _projectSite, scheme, dict); + } + //鏄剧ず淇℃伅 private async Task ShowInfo() { -- Gitblit v1.9.3