From 8f2d7a722b274344f58550374f4b09921f84eb83 Mon Sep 17 00:00:00 2001 From: duheng <2784771470@qq.com> Date: 星期五, 07 二月 2025 11:02:32 +0800 Subject: [PATCH] 修复过渡件匹配问题 --- WinFrmUI/HStation.WinFrmUI.Xhs.Core/03-simulation/05-function/SimulationFunctionCtrl.cs | 263 +++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 216 insertions(+), 47 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 5595451..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 @@ -1,10 +1,5 @@ -锘縰sing DevExpress.CodeParser; -using DevExpress.DataAccess.Native; -using DevExpress.Utils.Extensions; -using DevExpress.Utils.Svg; -using DevExpress.XtraCharts; +锘縰sing DevExpress.Utils.Svg; using System.Collections.Concurrent; -using Yw.DAL.Basic; using Yw.Vmo; namespace HStation.WinFrmUI @@ -17,6 +12,8 @@ this.layoutControl1.SetupLayoutControl(); } + #region 椤圭洰浜嬩欢 + /// <summary> /// 鏄剧ず椤圭洰绔欎俊鎭簨浠� /// </summary> @@ -25,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> @@ -42,9 +40,22 @@ /// </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> - public event Action<XhsProjectVmo, XhsProjectSiteVmo, Yw.Model.HydroModelInfo, SvgImage> CreateProjectSiteSchemeEvent; + public event Action<XhsProjectVmo, XhsProjectSiteVmo, Yw.Model.HydroModelInfo, List<XhsSchemeVmo>, SvgImage> CreateProjectSiteSchemeEvent; /// <summary> /// 椤圭洰绔欐柟妗堝鍔犱簨浠� /// </summary> @@ -57,6 +68,8 @@ /// 椤圭洰绔欐柟妗堢Щ闄や簨浠� /// </summary> public event Action<XhsProjectVmo, XhsProjectSiteVmo, XhsSchemeVmo> ProjectSiteSchemeRemoveEvent; + + #endregion private XhsProjectVmo _project = null;//椤圭洰 private XhsProjectSiteVmo _projectSite = null;//椤圭洰绔� @@ -106,6 +119,8 @@ }); await ShowInfo(); overlay.Close(); + await Task.Delay(2000); + this.accordionControl1.ExpandAll(); } //椤圭洰绔欐鍐� @@ -154,7 +169,8 @@ { return; } - this.CreateProjectSiteSchemeEvent?.Invoke(_project, _projectSite, hydroInfo, this.svgImg32[3]); + var allSchemeList = _allSchemeHydroInfoDict?.Keys.ToList(); + this.CreateProjectSiteSchemeEvent?.Invoke(_project, _projectSite, hydroInfo, allSchemeList, this.svgImg32[3]); } //鍙抽敭寮瑰嚭 @@ -764,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() { @@ -781,41 +985,6 @@ return; } this.ShowProjectSiteInfoEvent?.Invoke(_project, _projectSite, hydroInfo, this.svgImg32[0]); - } - - /// <summary> - /// 淇濆瓨 - /// </summary> - public async Task<Yw.Model.HydroModelInfo> SaveModel(XhsSchemeVmo scheme, Yw.Model.HydroModelInfo hydroInfo) - { - if (hydroInfo == null) - { - return default; - } - var id = await BLLFactory<Yw.BLL.HydroModelInfo>.Instance.Save(hydroInfo); - if (id < 1) - { - return default; - } - //var db = await HStation.BLL.XhsHydroInfo.GetByID(id); - if (scheme == null) - { - // _hydroInfo = db; - _hydroInfo = hydroInfo; - return _hydroInfo; - } - if (_allSchemeHydroInfoDict == null || _allSchemeHydroInfoDict.Count < 1) - { - return default; - } - var schemeKey = _allSchemeHydroInfoDict.Keys.FirstOrDefault(x => x.ID == scheme.ID); - if (schemeKey == null) - { - return default; - } - //_allSchemeHydroInfoDict[schemeKey] = db; - _allSchemeHydroInfoDict[schemeKey] = hydroInfo; - return _allSchemeHydroInfoDict[schemeKey]; } /// <summary> -- Gitblit v1.9.3