global using Yw.EPAnet; using DevExpress.Mvvm.Native; using DevExpress.Office.Utils; using DevExpress.Utils.Extensions; using DevExpress.Xpo.Helpers; using DevExpress.XtraBars.Ribbon; using DevExpress.XtraRichEdit.Layout; using DevExpress.XtraSpreadsheet.Commands; using HStation.WinFrmUI.PhartRelation; using System.Diagnostics; using System.Windows.Media; using System.Windows.Media.Media3D; using Yw.Hydro; using Yw.Pump; using Yw.Vmo; using Yw.WinFrmUI.Bimface; using Yw.WinFrmUI.Hydro; namespace HStation.WinFrmUI { public partial class XhsProjectSimulationCorePage : DocumentPage { public XhsProjectSimulationCorePage() { InitializeComponent(); this.PageTitle.Caption = "水力模拟"; this.PageTitle.HeaderSvgImage = this.svgImg32[0]; this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Hidden; RegistBulkSetEvents(); } private HStation.Vmo.XhsProjectVmo _project = null;//项目 private HStation.Vmo.XhsProjectSiteVmo _projectSite = null;//项目站 private Yw.Model.HydroModelInfo _hydroInfo = null;//水力信息 /// /// 绑定数据 /// public async Task SetBindingData ( HStation.Vmo.XhsProjectVmo project, HStation.Vmo.XhsProjectSiteVmo projectSite, Yw.Model.HydroModelInfo hydroInfo ) { if (project == null) { return; } _project = project; _projectSite = projectSite; _hydroInfo = hydroInfo; if (_projectSite == null) { _projectSite = await BLLFactory.Instance.GetDefaultByProjectID(_project.ID); } if (_hydroInfo == null) { var hydroRelation = await BLLFactory.Instance .GetDefaultByObjectTypeAndObjectIDOfPurpose(HStation.Xhs.DataType.XhsProjectSite, _projectSite.ID, HStation.Xhs.Purpose.Simulation); _hydroInfo = await BLLFactory.Instance.GetByID(hydroRelation.ModelID); } } /// /// 初始化数据 /// public override void InitialDataSource() { base.InitialDataSource(); if (_project == null) { return; } this.PageTitle.Caption = $"{_project.Name}\r\n水力模拟"; ShowBimfaceCtrl(); ShowQ3dCtrl(); ShowPropertyCtrl(); } #region Bimface //bimface控件 private XhsProjectSimulationBimfaceCtrl _bimfaceCtrl = null; //获取 bimface 控件 private async Task GetBimfaceCtrl() { if (_bimfaceCtrl == null) { _bimfaceCtrl = new XhsProjectSimulationBimfaceCtrl(); _bimfaceCtrl.Dock = DockStyle.Fill; await _bimfaceCtrl.InitialData(_project, _projectSite, () => _hydroInfo); _bimfaceCtrl.LoadCompletedEvent += () => {//view加载完成事件 if (_hydroInfo == null) { return; } ApplyGrading(); }; _bimfaceCtrl.HydroMouseLeftClickEvent += (obj) => {//鼠标左键点击事件 if (_hydroInfo == null) { return; } _selectedVisual = obj; ShowSelectedProperty(); }; } return _bimfaceCtrl; } //显示 bimface 控件 private async void ShowBimfaceCtrl() { var bimfaceCtrl = await GetBimfaceCtrl(); this.tabPageBimface.Controls.Clear(); this.tabPageBimface.Controls.Add(bimfaceCtrl); } private void SelectBimfaceParter() { } #endregion #region Q3d //Q3d 控件 private XhsProjectSimulationQ3dCtrl _q3dCtrl = null; //获取 Q3d 控件 private XhsProjectSimulationQ3dCtrl GetQ3dCtrl() { if (_q3dCtrl == null) { _q3dCtrl = new XhsProjectSimulationQ3dCtrl(); _q3dCtrl.Dock = DockStyle.Fill; _q3dCtrl.InitialData(() => _hydroInfo); _q3dCtrl.SelectedPartersChangedEvent += (obj) => { if (_hydroInfo == null) { return; } var allParterList = _hydroInfo.GetAllVisuals(); _selectedVisual = allParterList?.Find(x => x.Code == obj?.FirstOrDefault()); ShowSelectedProperty(); }; } return _q3dCtrl; } //显示 Q3d 控件 private void ShowQ3dCtrl() { var q3dCtrl = GetQ3dCtrl(); this.tabPageQ3d.Controls.Clear(); this.tabPageQ3d.Controls.Add(q3dCtrl); } #endregion #region 属性控件 //属性控件 private XhsProjectSimulationPropertyCtrl _propertyCtrl = null; //获取属性控件 private XhsProjectSimulationPropertyCtrl GetPropertyCtrl() { if (_propertyCtrl == null) { _propertyCtrl = new XhsProjectSimulationPropertyCtrl(); _propertyCtrl.Dock = DockStyle.Fill; _propertyCtrl.InitialData(() => _hydroInfo, () => GetCalcuResultList()); _propertyCtrl.BlinkLinkParterEvent += async (code, linkCode) => { //强调连接组件 if (string.IsNullOrEmpty(code)) { return; } if (string.IsNullOrEmpty(linkCode)) { return; } if (_hydroInfo == null) { return; } var allVisualList = _hydroInfo.GetAllVisuals(); if (allVisualList == null || allVisualList.Count < 1) { return; } var linkParter = allVisualList.Find(x => x.Code == linkCode); if (linkParter == null) { return; } var blinkCodes = new List(); if (linkParter.GetType() == typeof(Yw.Model.HydroJunctionInfo)) { var allLinkList = _hydroInfo.GetAllLinks(); if (allLinkList == null || allLinkList.Count < 1) { return; } var linkList = allLinkList.Where(x => (x.StartCode == linkParter.Code || x.EndCode == linkParter.Code) && x.Code != code).ToList(); if (linkList == null || linkList.Count < 1) { return; } blinkCodes.AddRange(linkList.Select(x => x.Code)); } else { blinkCodes.Add(linkCode); } await _bimfaceCtrl?.SetBlinkComponents(blinkCodes); await Task.Delay(5000); await _bimfaceCtrl?.ClearBlinkComponents(); }; _propertyCtrl.ViewParterEvent += (parter) => { if (parter == null) { return; } _bimfaceCtrl?.ZoomToComponent(parter.Code); }; _propertyCtrl.PropertyValueChangedEvent += (parter) => { if (parter == null) { return; } UpdateVisualListCtrl(); AutoApplyGrading(); }; _propertyCtrl.MarkPropertyValueChangedEvent += (parter) => { //标注属性发生改变 //判断当前是否有标注展示,若有则更新标注,最好是更新单个标注 }; _propertyCtrl.GradingPropertyValueChangedEvent += (parter) => { //分级属性发生改变 //判断当前是否有分级展示,若有则更新分级,最好是更新单个分级 }; _propertyCtrl.FlowDirectionPropertyValueChangedEvent += (visual) => { //流向属性发生改变 //判断流向是否加载,如果加载则更新流向,最好是更新单个流向 UpdateFlowEffect(visual); }; } return _propertyCtrl; } //属性控件是否可见 private bool IsPropertyCtrlVisible { get { if (this.docPnlRight.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Visible) { if (this.controlContainerRight.Controls.Count > 0) { if (this.controlContainerRight.Controls[0] is XhsProjectSimulationPropertyCtrl) { return true; } } } return false; } } //显示属性控件 private void ShowPropertyCtrl() { if (IsPropertyCtrlVisible) { return; } var propertyCtrl = GetPropertyCtrl(); this.controlContainerRight.Controls.Clear(); this.controlContainerRight.Controls.Add(propertyCtrl); this.docPnlRight.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlRight.Text = "属性"; this.docPnlRight.Width = 300; } //显示选择属性 private void ShowSelectedProperty() { ShowSelectedProperty(_selectedVisual); } //显示选择属性 private void ShowSelectedProperty(Yw.Model.HydroVisualInfo visual) { if (_hydroInfo == null) { return; } ShowPropertyCtrl(); _selectedVisual = visual; if (_selectedVisual == null) { _propertyCtrl.SelectedObject = null; return; } _propertyCtrl.SelectedObject = GetVisualViewModel(_selectedVisual); } //更新选择属性 private void UpdateSelectedProperty() { if (!IsPropertyCtrlVisible) { return; } if (_selectedVisual == null) { return; } _propertyCtrl?.UpdateRows(); } #endregion #region 自动匹配 //获取匹配列表控件 private XhsProjectSimulationMatchingListCtrl GetMatchingListCtrl() { if (_matchingListCtrl == null) { _matchingListCtrl = new XhsProjectSimulationMatchingListCtrl(); _matchingListCtrl.Dock = DockStyle.Fill; _matchingListCtrl.HydroClickEvent += async (code) => { if (_hydroInfo == null) { return; } var allParterList = _hydroInfo.GetAllVisuals(); _selectedVisual = allParterList?.Find(x => x.Code == code); var elementIds = new List(); if (_selectedVisual != null) { elementIds.Add(_selectedVisual.Code); } await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); ShowSelectedProperty(); }; _matchingListCtrl.ApplyMatchingEvent += (output) => { if (_hydroInfo == null) { return false; } return AssetsMatchingParasHelper.Apply(_hydroInfo, output); }; } return _matchingListCtrl; } //匹配列表控件 private XhsProjectSimulationMatchingListCtrl _matchingListCtrl = null; //自动匹配 private void barBtnMatchingList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } this.controlContainerBottom.Controls.Clear(); var matchingListCtrl = GetMatchingListCtrl(); var input = AssetsMatchingParasHelper.Create(_hydroInfo, GetCalcuResultList()); matchingListCtrl.SetBindingData(input); this.controlContainerBottom.Controls.Add(matchingListCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "匹配列表"; this.docPnlBottom.Height = 350; } #endregion #region 未匹配列表 //获取未匹配列表控件 private XhsProjectSimulationUnMatchingListCtrl GetUnMatchingListCtrl() { if (_unMatchingListCtrl == null) { _unMatchingListCtrl = new XhsProjectSimulationUnMatchingListCtrl(); _unMatchingListCtrl.Dock = DockStyle.Fill; _unMatchingListCtrl.HydroClickEvent += async (parter) =>//行点击 { if (parter == null) { return; } if (_hydroInfo == null) { return; } var allParterList = _hydroInfo.GetAllVisuals(); _selectedVisual = allParterList?.Find(x => x.Code == parter.Code); var elementIds = new List() { parter.Code }; await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); ShowSelectedProperty(); }; _unMatchingListCtrl.ViewModelEvent += async (parters) =>//查看模型 { var codes = parters?.Select(x => x.Code).Distinct().ToList(); await _bimfaceCtrl?.ZoomAndSelectComponents(codes); _selectedVisual = null; ShowSelectedProperty(); }; } return _unMatchingListCtrl; } private XhsProjectSimulationUnMatchingListCtrl _unMatchingListCtrl = null;//未匹配列表 //未匹配列表 private void barBtnUnMatchingList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } this.controlContainerBottom.Controls.Clear(); var unMatchingListCtrl = GetUnMatchingListCtrl(); unMatchingListCtrl.SetBindingData(_hydroInfo); this.controlContainerBottom.Controls.Add(unMatchingListCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "未匹配列表"; this.docPnlBottom.Height = 350; } #endregion #region 一键显隐 //显隐编码列表 private List _fastShowHiddenCodeList = null; //一键显隐 private async void FastShowHidden() { if (_hydroInfo == null) { return; } if (_hydroInfo.Decorators == null || _hydroInfo.Decorators.Count < 1) { return; } if (_fastShowHiddenCodeList == null) { _fastShowHiddenCodeList = _hydroInfo.Decorators.Select(x => x.Code).ToList(); await _bimfaceCtrl?.HideComponents(_fastShowHiddenCodeList); } else { await _bimfaceCtrl?.ShowComponents(_fastShowHiddenCodeList); _fastShowHiddenCodeList = null; } } //触发一键显隐 private void barBtnFastShowHidden_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { FastShowHidden(); } #endregion #region 保存信息 //保存 private async void barBtnSave_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } Stopwatch sw = new Stopwatch(); sw.Start(); var id = await BLLFactory.Instance.Save(_hydroInfo); //耗时巨大的代码 sw.Stop(); TimeSpan ts2 = sw.Elapsed; Console.WriteLine("Stopwatch总共花费{0}ms.", ts2.TotalMilliseconds); if (id < 1) { TipFormHelper.ShowError("保存失败!"); return; } _hydroInfo = await BLLFactory.Instance.GetByID(id); TipFormHelper.ShowSucceed("保存成功!"); } #endregion #region 批量配置 //注册批量配置事件 private void RegistBulkSetEvents() { //水库 this.barBtnSetReservoirList.ItemClick += delegate { //var dlg = new HydroReservoirBulkSetListDlg(); //dlg.ShowDialog(); }; //水池 this.barBtnSetTankList.ItemClick += delegate { //var dlg = new HydroTankBulkSetListDlg(); //dlg.ShowDialog(); }; //水箱 this.barBtnSetWaterboxList.ItemClick += delegate { //if (_hydroInfo == null) //{ // return; //} //var dlg = new SetHydroWaterboxListDlg(); //dlg.SetBindingData(_hydroInfo); //dlg.HydroClickEvent += async (obj) => //{ // if (obj == null) // { // return; // } // _selectedParter = obj; // await _bimfaceCtrl?.ZoomAndSelectComponent(obj.Code); // ShowProperty(); //}; //dlg.HydroChangedEvent += (obj) => //{ //}; //dlg.ShowDialog(); }; //连接节点 this.barBtnSetJunctionList.ItemClick += delegate { //var dlg = new HydroJunctionBulkSetListDlg(); //dlg.ShowDialog(); }; //闷头 this.barBtnSetBluntheadList.ItemClick += delegate { //if (_hydroInfo == null) //{ // return; //} //var dlg = new SetHydroBluntheadListDlg(); //dlg.SetBindingData(_hydroInfo); //dlg.HydroClickEvent += async (obj) => //{ // if (obj == null) // { // return; // } // _selectedParter = obj; // await _bimfaceCtrl?.ZoomAndSelectComponent(obj.Code); // ShowProperty(); //}; //dlg.HydroChangedEvent += (obj) => //{ //}; //dlg.ShowDialog(); }; //弯头 this.barBtnSetElbowsList.ItemClick += delegate { //if (_hydroInfo == null) //{ // return; //} //var dlg = new SetHydroElbowListDlg(); //dlg.SetBindingData(_hydroInfo); //dlg.HydroClickEvent += async (obj) => //{ // if (obj == null) // { // return; // } // _selectedParter = obj; // await _bimfaceCtrl?.ZoomAndSelectComponent(obj.Code); // ShowProperty(); //}; //dlg.HydroChangedEvent += (obj) => //{ //}; //dlg.ShowDialog(); }; //三通 this.barBtnSetThreelinkList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroThreelinkListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //四通 this.barBtnSetFourlinkList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroFourlinkListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //水表 this.barBtnSetMeterList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroMeterListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //流量计 this.barBtnSetFlowmeterList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroFlowmeterListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //压力表 this.barBtnSetPressmeterList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroPressmeterListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //管道 this.barBtnSetPipeList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroPipeListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //水泵 this.barBtnSetPumpList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroPumpListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //阀门 this.barBtnSetValveList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new SetHydroValveListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; } //显示RadialMenu private void barBtnSetList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { this.rmSet.ShowPopup(MousePosition, true); } //弹出前 private void rmSet_BeforePopup(object sender, CancelEventArgs e) { if (_hydroInfo == null) { e.Cancel = true; return; } //水库 if (_hydroInfo.Reservoirs == null || _hydroInfo.Reservoirs.Count < 1) { this.barBtnSetReservoirList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetReservoirList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //水池 if (_hydroInfo.Tanks == null || _hydroInfo.Tanks.Count < 1) { this.barBtnSetTankList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetTankList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //水箱 if (_hydroInfo.Waterboxs == null || _hydroInfo.Waterboxs.Count < 1) { this.barBtnSetWaterboxList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetWaterboxList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //连接节点 if (_hydroInfo.Junctions == null || _hydroInfo.Junctions.Count < 1) { this.barBtnSetJunctionList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetJunctionList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //喷嘴 if (_hydroInfo.Nozzles == null || _hydroInfo.Nozzles.Count < 1) { this.barBtnSetNozzleList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetNozzleList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //消火栓 if (_hydroInfo.Hydrants == null || _hydroInfo.Hydrants.Count < 1) { this.barBtnSetHydrantList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetHydrantList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //闷头 if (_hydroInfo.Bluntheads == null || _hydroInfo.Bluntheads.Count < 1) { this.barBtnSetBluntheadList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetBluntheadList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //弯头 if (_hydroInfo.Elbows == null || _hydroInfo.Elbows.Count < 1) { this.barBtnSetElbowsList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetElbowsList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //三通 if (_hydroInfo.Threelinks == null || _hydroInfo.Threelinks.Count < 1) { this.barBtnSetThreelinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetThreelinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //四通 if (_hydroInfo.Fourlinks == null || _hydroInfo.Fourlinks.Count < 1) { this.barBtnSetFourlinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetFourlinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //水表 if (_hydroInfo.Meters == null || _hydroInfo.Meters.Count < 1) { this.barBtnSetMeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetMeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //流量计 if (_hydroInfo.Flowmeters == null || _hydroInfo.Flowmeters.Count < 1) { this.barBtnSetFlowmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetFlowmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //压力表 if (_hydroInfo.Pressmeters == null || _hydroInfo.Pressmeters.Count < 1) { this.barBtnSetPressmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetPressmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //管道 if (_hydroInfo.Pipes == null || _hydroInfo.Pipes.Count < 1) { this.barBtnSetPipeList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetPipeList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //过渡件 if (_hydroInfo.Translations == null || _hydroInfo.Translations.Count < 1) { this.barBtnSetTranslationList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetTranslationList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //换热器 if (_hydroInfo.Exchangers == null || _hydroInfo.Exchangers.Count < 1) { this.barBtnSetExchangerList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetExchangerList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //空压机 if (_hydroInfo.Compressors == null || _hydroInfo.Compressors.Count < 1) { this.barBtnSetCompressorList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetCompressorList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //水泵 if (_hydroInfo.Pumps == null || _hydroInfo.Pumps.Count < 1) { this.barBtnSetPumpList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetPumpList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } //阀门 if (_hydroInfo.Valves == null || _hydroInfo.Valves.Count < 1) { this.barBtnSetValveList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { this.barBtnSetValveList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } } #endregion #region 并联分析 //并联分析 private void barBtnAnaly_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } if (_hydroInfo.Pumps == null || _hydroInfo.Pumps.Count < 1) { return; } var allCalcuResultList = GetCalcuResultList(); var vmList = new List(); foreach (var pump in _hydroInfo.Pumps) { if (!pump.RatedN.HasValue) { continue; } var qh = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQH)?.CurveData; var qe = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQE)?.CurveData; var qp = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQP)?.CurveData; if (qh == null) { continue; } var qhPtList = qh.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList(); var qePtList = qe?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList(); var qpPtList = qp?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList(); var vm = new XhsSinglePumpViewModel(); vmList.Add(vm); vm.ID = pump.ID; vm.Name = pump.Name; vm.Code = pump.Code; vm.IsBp = true; vm.RunStatus = pump.LinkStatus == Yw.Hydro.LinkStatus.Open; vm.RatedHz = pump.RatedHz; vm.CurrentHz = Math.Round(pump.RatedHz * pump.SpeedRatio, 1); vm.RatedSpeed = pump.RatedN.Value; vm.CurrentSpeed = Math.Round(pump.RatedN.Value * pump.SpeedRatio); vm.CurveQH = qhPtList; vm.CurveQE = qePtList; vm.CurveQP = qpPtList; if (allCalcuResultList != null && allCalcuResultList.Count > 0) { var calcuResult = allCalcuResultList.Find(x => x.Code == pump.Code) as HydroCalcuLinkResult; if (calcuResult != null) { if (calcuResult.CalcuFlow.HasValue) { vm.CalcuQ = Math.Abs(calcuResult.CalcuFlow.Value); } var calcuResultStart = allCalcuResultList.Find(x => x.Code == pump.StartCode) as HydroCalcuNodeResult; var calcuResultEnd = allCalcuResultList.Find(x => x.Code == pump.EndCode) as HydroCalcuNodeResult; if (calcuResultStart != null && calcuResultEnd != null) { if (calcuResultStart.CalcuHead.HasValue && calcuResultEnd.CalcuHead.HasValue) { vm.CalcuH = Math.Round(Math.Abs(calcuResultStart.CalcuHead.Value - calcuResultEnd.CalcuHead.Value), 4); } } } } } var dlg = new PumpParallelAnalyDlg(); dlg.SetBindingData(vmList); dlg.ReloadDataEvent += (list) => { list?.ForEach(x => { var pump = _hydroInfo.Pumps?.Find(t => t.Code == x.Code); if (pump != null) { pump.LinkStatus = x.RunStatus ? Yw.Hydro.PumpStatus.Open : Yw.Hydro.PumpStatus.Closed; pump.SpeedRatio = Math.Round(x.CurrentHz / pump.RatedHz, 1); } }); ShowSelectedProperty(); return true; }; dlg.ShowDialog(); } #endregion #region 构件查询 //查询组件 private HydroVisualSearchListCtrl _searchCtrl = null; //获取查询组件 private HydroVisualSearchListCtrl GetSearchCtrl() { if (_searchCtrl == null) { _searchCtrl = new HydroVisualSearchListCtrl(); _searchCtrl.Dock = DockStyle.Fill; var allVisualViewModelList = GetVisualViewModelList(); _searchCtrl.InitialData(allVisualViewModelList); _searchCtrl.HydroClickInfoEvent += async (visual) => { ShowSelectedProperty(visual); await _bimfaceCtrl?.ZoomAndSelectComponent(visual?.Code); }; _searchCtrl.HydroSearchInfoEvent += async (list) => { var elementIds = new List(); if (list != null && list.Count > 0) { _selectedVisual = list.First(); list.ForEach(x => elementIds.Add(x.Code)); } else { _selectedVisual = null; } ShowSelectedProperty(); await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); }; } return _searchCtrl; } //查询控件是否可见 private bool IsSearchCtrlVisible { get { if (this.docPnlBottom.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Visible) { if (this.controlContainerBottom.Controls.Count > 0) { if (this.controlContainerBottom.Controls[0] is HydroVisualSearchListCtrl) { return true; } } } return false; } } //显示查询控件 private void ShowSearchCtrl(string content) { if (IsSearchCtrlVisible) { return; } var searchCtrl = GetSearchCtrl(); searchCtrl.SetBindingData(content); this.controlContainerBottom.Controls.Clear(); this.controlContainerBottom.Controls.Add(searchCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "构件查询"; this.docPnlBottom.Height = 350; } //显示查询窗体 private void ShowSearchDlg() { if (IsSearchCtrlVisible) { return; } var dlg = new InputHydroVisualSearchListDlg(); dlg.SearchEvent += (content) => { if (string.IsNullOrEmpty(content)) { return; } ShowSearchCtrl(content); }; dlg.SetBindingData(); dlg.ShowDialog(); } //查询 private void barBtnSearch_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowSearchDlg(); } #endregion #region 模型标注 #region 标注设置 //所有标注设置列表 private List _allMarkSetList = null; //获取标注设置列表 private List GetMarkSetList() { if (_hydroInfo == null) { return default; } if (_allMarkSetList == null) { _allMarkSetList = HydroMarkHelper.GetSetList(_hydroInfo); } return _allMarkSetList; } #endregion #region 标注结果 //所有标注结果列表 private List _allMarkResultList = null; //获取标注结果列表 private List GetMarkResultList() { if (_hydroInfo == null) { return default; } var allSetList = GetMarkSetList(); _allMarkResultList = HydroMarkHelper.GetResultList(_hydroInfo, allSetList); return _allMarkResultList; } #endregion #region 标注显示 //标注是否显示 private bool _isMarkVisible = false; //应用标注列表 private async void ApplyMarkList() { if (_isMarkVisible) { var allResultList = GetMarkResultList(); var leadLabels = allResultList?.Select(x => new LogicMarkLeadLabel(x.Code, x.Text, 100000)).ToList(); await _bimfaceCtrl?.SetLogicMarkLeadLabels(leadLabels); } else { await _bimfaceCtrl?.ClearLogicMarkLeadLabels(); } } //显示标注设置窗体 private void ShowSetMarkDlg() { if (_hydroInfo == null) { return; } var allMarkSetList = GetMarkSetList(); var dlg = new SetHydroMarkDlg(); dlg.SetBindingData(allMarkSetList); dlg.ReloadDataEvent += (list) => { _allMarkSetList = list; ApplyMarkList(); }; dlg.ShowDialog(); } //设置标注 private void barBtnSetMark_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowSetMarkDlg(); } //是否显示 private void barCkMark_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { _isMarkVisible = this.barCkMark.Checked; ApplyMarkList(); } #endregion #endregion #region 颜色分级 #region 颜色配置 //所有分级列表 private List _allGradingList = null; //获取分级列表 private async Task> GetGradingList() { if (_hydroInfo == null) { return default; } if (_allGradingList == null) { _allGradingList = await BLLFactory.Instance.GetByModelID(_hydroInfo.ID); if (_allGradingList == null || _allGradingList.Count < 1) { var config = Yw.Settings.HydroParasHelper.Hydro.Grading; if (config != null && config.Items != null && config.Items.Count > 0) { _allGradingList = new List(); config.Items.ForEach(x => { var vmo = new HydroGradingVmo() { ModelID = _hydroInfo.ID, Catalog = x.Catalog, PropName = x.PropName, SetValue = x.SetValue, MinValue = x.MinValue, MaxValue = x.MaxValue, Color = x.Color, SortCode = config.Items.IndexOf(x) }; _allGradingList.Add(vmo); }); } } } return _allGradingList; } //显示配置颜色分级窗体 private async void ShowSetGradingDlg() { if (_hydroInfo == null) { return; } var allGradingList = await GetGradingList(); var dlg = new SetHydroGradingTreeDlg(); dlg.SetBindingData(_hydroInfo, allGradingList); dlg.ReloadDataEvent += (list) => { _allGradingList = list; }; dlg.ApplyDataEvent += (catalog, propName) => { ApplyGrading(catalog, propName); }; dlg.ShowDialog(); } //配置颜色分级 private void barBtnGradingSet_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowSetGradingDlg(); } #endregion #region 应用分级 //颜色分级应用列表 private List _allGradingApplyList = null; //获取颜色分级应用列表 private List GetGradingApplyList() { if (_allGradingApplyList == null) { _allGradingApplyList = new List(); if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0) { _allGradingApplyList.Add(new HydroGradingApplyViewModel() { Code = Yw.Hydro.ParterCatalog.Pump, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Pump), PropName = Yw.Hydro.ParterProp.LinkStatus }); } if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0) { _allGradingApplyList.Add(new HydroGradingApplyViewModel() { Code = Yw.Hydro.ParterCatalog.Valve, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Valve), PropName = Yw.Hydro.ParterProp.LinkStatus }); } if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0) { _allGradingApplyList.Add(new HydroGradingApplyViewModel() { Code = Yw.Hydro.ParterCatalog.Pipe, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Pipe), PropName = HydroVisualCalcuProp.CalcuFlow }); } } return _allGradingApplyList; } //获取颜色分级应用结果列表 private async Task> GetGradingApplyResultList() { if (_hydroInfo == null) { return default; } //所有分级列表 var allGradingList = await GetGradingList(); if (allGradingList == null || allGradingList.Count < 1) { return default; } //所有分级应用列表 var allGradingApplyList = GetGradingApplyList(); if (allGradingApplyList == null || allGradingApplyList.Count < 1) { return default; } //所有计算结果列表 var allCalcuResultList = GetCalcuResultList(); //所有应用结果列表 var allGradingApplyResultList = new List(); allGradingApplyList.ForEach(x => { var allCatalogGradingList = allGradingList.Where(t => t.Catalog == x.Code).ToList(); if (allCatalogGradingList != null || allCatalogGradingList.Count > 0) { switch (x.Code) { case Yw.Hydro.ParterCatalog.Pump: { if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0) { foreach (var pump in _hydroInfo.Pumps) { switch (x.PropName) { case Yw.Hydro.ParterProp.LinkStatus: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var grading = gradingList.Meet(pump.LinkStatus); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } break; case HydroVisualCalcuProp.CalcuFlow: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuFlow.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuVelocity: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuVelocity.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuHeadLoss: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuHeadLoss.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; default: break; } } } } break; case Yw.Hydro.ParterCatalog.Valve: { if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0) { foreach (var valve in _hydroInfo.Valves) { switch (x.PropName) { case Yw.Hydro.ParterProp.LinkStatus: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var grading = gradingList.Meet(valve.LinkStatus); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } break; case HydroVisualCalcuProp.CalcuFlow: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuFlow.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuVelocity: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuVelocity.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuHeadLoss: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuHeadLoss.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; default: break; } } } } break; case Yw.Hydro.ParterCatalog.Pipe: { if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0) { foreach (var pipe in _hydroInfo.Pipes) { switch (x.PropName) { case HydroVisualCalcuProp.CalcuFlow: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuFlow.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pipe.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuVelocity: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuVelocity.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pipe.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuHeadLoss: { var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuHeadLoss.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pipe.Code, Color = grading.Color }; allGradingApplyResultList.Add(result); } } } } } break; default: break; } } } } break; default: break; } } }); return allGradingApplyResultList; } //获取颜色分级应用结果列表 private async Task> GetGradingApplyResultList(string catalog, string propName) { if (_hydroInfo == null) { return default; } //所有分级列表 var allGradingList = await GetGradingList(); if (allGradingList == null || allGradingList.Count < 1) { return default; } var currentGradingList = allGradingList.Where(x => x.Catalog == catalog).ToList(); if (currentGradingList.Count < 1) { return default; } //所有分级应用列表 var allGradingApplyList = GetGradingApplyList(); if (allGradingApplyList == null || allGradingApplyList.Count < 1) { return default; } //当前分级应用 var gradingApply = allGradingApplyList.Find(x => x.Code == catalog); if (gradingApply == null) { return default; } gradingApply.PropName = propName; //所有计算结果 var allCalcuResultList = GetCalcuResultList(); //应用结果列表 var gradingApplyResultList = new List(); switch (catalog) { case Yw.Hydro.ParterCatalog.Pump: { if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0) { foreach (var pump in _hydroInfo.Pumps) { switch (propName) { case Yw.Hydro.ParterProp.LinkStatus: { var gradingList = currentGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var grading = gradingList.Meet(pump.LinkStatus); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } break; case HydroVisualCalcuProp.CalcuFlow: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuFlow.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuVelocity: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuVelocity.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuHeadLoss: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuHeadLoss.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pump.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; default: break; } } } } break; case Yw.Hydro.ParterCatalog.Valve: { if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0) { foreach (var valve in _hydroInfo.Valves) { switch (propName) { case Yw.Hydro.ParterProp.LinkStatus: { var gradingList = currentGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var grading = gradingList.Meet(valve.LinkStatus); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } break; case HydroVisualCalcuProp.CalcuFlow: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuFlow.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuVelocity: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuVelocity.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuHeadLoss: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuHeadLoss.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = valve.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; default: break; } } } } break; case Yw.Hydro.ParterCatalog.Pipe: { if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0) { foreach (var pipe in _hydroInfo.Pipes) { switch (propName) { case HydroVisualCalcuProp.CalcuFlow: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuFlow.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pipe.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuVelocity: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuVelocity.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pipe.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; case HydroVisualCalcuProp.CalcuHeadLoss: { var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList(); if (gradingList != null && gradingList.Count > 0) { var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code); if (calcuResult is HydroCalcuLinkResult calcuLinkResult) { if (calcuLinkResult.CalcuHeadLoss.HasValue) { var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value)); if (grading != null) { var result = new HydroGradingApplyResultViewModel() { Code = pipe.Code, Color = grading.Color }; gradingApplyResultList.Add(result); } } } } } break; default: break; } } } } break; default: break; } return gradingApplyResultList; } //颜色分级是否应用了 private bool _isGradingApply = false; //颜色分级应用编码列表 private List _allGradingApplyCodeList = null; //应用颜色分级 private async void ApplyGrading() { if (_hydroInfo == null) { return; } _isGradingApply = true; var allGradingApplyResultList = await GetGradingApplyResultList(); if (allGradingApplyResultList == null || allGradingApplyResultList.Count < 1) { CancelApplyGrading(); return; } var objGroupList = allGradingApplyResultList.GroupBy(x => x.Color).ToList(); objGroupList.ForEach(async x => { await _bimfaceCtrl?.OverrideComponentsColor(x.Select(t => t.Code).Distinct().ToList(), x.Key, 1); }); _allGradingApplyCodeList = allGradingApplyResultList.Select(x => x.Code).Distinct().ToList(); } //应用颜色分级 private async void ApplyGrading(string catalog, string propName) { if (_hydroInfo == null) { return; } _isGradingApply = true; var allGradingApplyResultList = await GetGradingApplyResultList(catalog, propName); if (allGradingApplyResultList == null || allGradingApplyResultList.Count < 1) { return; } var objGroupList = allGradingApplyResultList.GroupBy(x => x.Color).ToList(); objGroupList.ForEach(async x => { await _bimfaceCtrl?.OverrideComponentsColor(x.Select(t => t.Code).Distinct().ToList(), x.Key, 1); }); var codeList = allGradingApplyResultList.Select(x => x.Code); if (_allGradingApplyCodeList == null) { _allGradingApplyCodeList = new List(); } _allGradingApplyCodeList.AddRange(codeList); _allGradingApplyCodeList = _allGradingApplyCodeList.Distinct().ToList(); } //自动应用颜色分级 private void AutoApplyGrading() { if (!_isGradingApply) { return; } ApplyGrading(); } //取消应用颜色分级 private async void CancelApplyGrading() { if (_hydroInfo == null) { return; } _isGradingApply = false; if (_allGradingApplyCodeList != null && _allGradingApplyCodeList.Count > 0) { await _bimfaceCtrl?.RestoreComponentsColor(_allGradingApplyCodeList); } } //显示应用颜色分级窗体 private void ShowApplyGradingDlg() { if (_hydroInfo == null) { return; } var allGradingApplyList = GetGradingApplyList(); if (allGradingApplyList == null || allGradingApplyList.Count < 1) { return; } var dlg = new ApplyHydroGradingDlg(); dlg.SetBindingData(allGradingApplyList); dlg.ReloadDataEvent += (obj) => { _allGradingApplyList = obj; ApplyGrading(); }; dlg.ShowDialog(); } //应用颜色分级 private void barBtnGradingApply_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowApplyGradingDlg(); } //取消应用分级 private void batBtnCancelGradingApply_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { CancelApplyGrading(); } #endregion #endregion #region 人工刷新 //刷新 private async void barBtnRefresh_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (XtraMessageBox.Show("刷新后将丢失当前水力信息更改,是否继续刷新?", "询问", MessageBoxButtons.YesNo) == DialogResult.Yes) { if (_project == null) { return; } if (_projectSite == null) { return; } var hydroRelation = await BLLFactory.Instance .GetDefaultByObjectTypeAndObjectIDOfPurpose(HStation.Xhs.DataType.XhsProjectSite, _projectSite.ID, HStation.Xhs.Purpose.Simulation); Stopwatch sw = new Stopwatch(); sw.Start(); _hydroInfo = await BLLFactory.Instance.GetByID(hydroRelation.ModelID); sw.Stop(); TimeSpan ts2 = sw.Elapsed; Console.WriteLine("Stopwatch总共花费{0}ms.", ts2.TotalMilliseconds); _selectedVisual = null; await _bimfaceCtrl?.ZoomAndSelectComponents(null); ShowSelectedProperty(); TipFormHelper.ShowSucceed("数据已刷新"); } } #endregion #region 水流动画 //水流动画是否可见 private bool _isFlowEffectVisible = false; //所有水流动画列表 private List _allFlowEffectList = null; //获取流向列表 private List GetFlowEffectList() { if (_hydroInfo == null) { return default; } if (_allFlowEffectList == null) { _allFlowEffectList = new List(); var allCalcuResultList = GetCalcuResultList(); if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0) { foreach (var parter in _hydroInfo.Pipes) { var flowEffect = new LogicFlowEffect(); _allFlowEffectList.Add(flowEffect); flowEffect.Id = parter.Code; flowEffect.Rotation = 90; flowEffect.SpeedX = 0.1; if (parter.FlowDirectionX == Yw.Hydro.FlowDirection.None) { flowEffect.SpeedX = 0; } else if (parter.FlowDirectionX == Yw.Hydro.FlowDirection.Positive) { flowEffect.SpeedX = 0.1; } else { flowEffect.SpeedX = -0.1; } if (parter.FlowDirectionY == Yw.Hydro.FlowDirection.None) { flowEffect.SpeedY = 0; } else if (parter.FlowDirectionY == Yw.Hydro.FlowDirection.Positive) { flowEffect.SpeedY = 0.1; } else { flowEffect.SpeedY = -0.1; } var calcuResult = allCalcuResultList?.Find(x => x.Code == parter.Code) as HydroCalcuLinkResult; if (calcuResult != null) { if (calcuResult.CalcuVelocity < 0) { flowEffect.SpeedX = -flowEffect.SpeedX; } } } } } return _allFlowEffectList; } //加载水流动画 private async void LoadFlowEffect() { if (_hydroInfo == null) { return; } var allFlowEffectList = GetFlowEffectList(); await _bimfaceCtrl?.LoadFlowEffect(allFlowEffectList); } //卸载水流动画 private async void UnloadFlowEffect() { if (_hydroInfo == null) { return; } await _bimfaceCtrl?.UnloadFlowEffect(); } //设置水力动画 private void SetFlowEffect() { if (_isFlowEffectVisible) { LoadFlowEffect(); } else { UnloadFlowEffect(); } } //更新水流动画 private async void UpdateFlowEffect(Yw.Model.HydroVisualInfo visual) { if (_hydroInfo == null) { return; } var allFlowEffectList = GetFlowEffectList(); var flowEffect = _allFlowEffectList?.Find(x => x.Id == visual.Code); if (flowEffect == null) { return; } if (visual.FlowDirectionX == Yw.Hydro.FlowDirection.None) { flowEffect.SpeedX = 0; } else if (visual.FlowDirectionX == Yw.Hydro.FlowDirection.Positive) { flowEffect.SpeedX = 0.1; } else { flowEffect.SpeedX = -0.1; } if (visual.FlowDirectionY == Yw.Hydro.FlowDirection.None) { flowEffect.SpeedY = 0; } else if (visual.FlowDirectionY == Yw.Hydro.FlowDirection.Positive) { flowEffect.SpeedY = 0.1; } else { flowEffect.SpeedY = -0.1; } var allCalcuResultList = GetCalcuResultList(); var calcuResult = allCalcuResultList?.Find(x => x.Code == visual.Code) as HydroCalcuLinkResult; if (calcuResult != null) { if (calcuResult.CalcuVelocity < 0) { flowEffect.SpeedX = -flowEffect.SpeedX; } } if (_isFlowEffectVisible) { await _bimfaceCtrl?.UpdateFlowEffect(flowEffect); } } //水流动画是否可见 private void barCkFlowEffect_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { _isFlowEffectVisible = this.barCkFlowEffect.Checked; SetFlowEffect(); } #endregion #region 选择构件 //选择构件 private Yw.Model.HydroVisualInfo _selectedVisual = null; //选择构件 private Yw.Model.HydroVisualInfo SelectedVisual { get { return _selectedVisual; } set { _selectedVisual = value; if (_selectedVisual == null) { this.barBtnSetMonitor.Enabled = false; } else { this.barBtnSetMonitor.Enabled = true; } } } #endregion #region 构件明细 #region 构件列表 //所有构件视图列表 private List _allVisualViewModelList = null; //获取构件视图列表 private List GetVisualViewModelList() { if (_hydroInfo == null) { return default; } if (_allVisualViewModelList == null) { _allVisualViewModelList = new List(); var allVisualList = _hydroInfo.GetAllVisuals(); if (allVisualList != null && allVisualList.Count > 0) { var allCalcuResultList = GetCalcuResultList(); allVisualList.ForEach(x => { var vm = HydroVisualViewModelBuilder.CreateVisualViewModel(x, _hydroInfo); var calcuResult = allCalcuResultList?.Find(x => x.Code == x.Code); if (calcuResult != null) { vm.UpdateCalcuProperty(calcuResult); } _allVisualViewModelList.Add(vm); }); } } return _allVisualViewModelList; } //更新可见视图属性 private void UpdateVisualViewModelProperty() { var allVisualViewModelList = GetVisualViewModelList(); if (allVisualViewModelList != null && allVisualViewModelList.Count > 0) { allVisualViewModelList.ForEach(x => { x.UpdateProperty(); }); } } //更新可见视图属性 private void UpdateVisualViewModelProperty(List codes) { if (codes == null || codes.Count < 1) { return; } var allVisualViewModelList = GetVisualViewModelList(); if (allVisualViewModelList != null && allVisualViewModelList.Count > 0) { allVisualViewModelList.ForEach(x => { if (codes.Contains(x.Code)) { x.UpdateProperty(); } }); } } //更新可见视图属性 private void UpdateVisualViewModelProperty(List visualList) { if (visualList == null || visualList.Count < 1) { return; } var allVisualViewModelList = GetVisualViewModelList(); if (allVisualViewModelList != null && allVisualViewModelList.Count > 0) { allVisualViewModelList.ForEach(x => { if (visualList.Exists(t => t.Code == x.Code)) { x.UpdateProperty(); } }); } } //更新可见视图计算属性 private void UpdateVisualViewModelCalcuProperty() { var allVisualViewModelList = GetVisualViewModelList(); if (allVisualViewModelList != null && allVisualViewModelList.Count > 0) { var allCalcuResultList = GetCalcuResultList(); if (allCalcuResultList != null && allCalcuResultList.Count > 0) { allVisualViewModelList.ForEach(x => { var calcuResult = allCalcuResultList.Find(t => t.Code == x.Code); if (calcuResult != null) { x.UpdateCalcuProperty(calcuResult); } }); } } } //获取构件视图 private HydroVisualViewModel GetVisualViewModel(string code) { if (string.IsNullOrEmpty(code)) { return default; } var allVisualViewModelList = GetVisualViewModelList(); return allVisualViewModelList?.Find(x => x.Code == code); } //获取可见视图 private HydroVisualViewModel GetVisualViewModel(Yw.Model.HydroVisualInfo visual) { if (visual == null) { return default; } var allVisualViewModelList = GetVisualViewModelList(); return allVisualViewModelList?.Find(x => x.Code == visual.Code); } #endregion #region 构件明细控件 //构件明细控件 private Yw.WinFrmUI.HydroVisualListCtrl _visualListCtrl = null; //获取构件明细控件 private Yw.WinFrmUI.HydroVisualListCtrl GetVisualListCtrl() { if (_visualListCtrl == null) { _visualListCtrl = new HydroVisualListCtrl(); _visualListCtrl.Dock = DockStyle.Fill; _visualListCtrl.HydroClickInfoEvent += async (visual) => { ShowSelectedProperty(visual); await _bimfaceCtrl?.ZoomAndSelectComponent(_selectedVisual?.Code); }; _visualListCtrl.HydroChangedInfoEvent += (visualList) => { UpdateSelectedProperty(); AutoApplyGrading(); }; } return _visualListCtrl; } //构件明细控件是否可见 private bool IsVisualListCtrlVisible { get { if (this.docPnlBottom.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Visible) { if (this.controlContainerBottom.Controls.Count > 0) { if (this.controlContainerBottom.Controls[0] is HydroVisualListCtrl) { return true; } } } return false; } } //显示构件明细控件 private void ShowVisualListCtrl() { if (_hydroInfo == null) { return; } if (IsVisualListCtrlVisible) { return; } var visualListCtrl = GetVisualListCtrl(); var allVisualViewModelList = GetVisualViewModelList(); visualListCtrl.SetBindingData(allVisualViewModelList); var allCalcuResultList = GetCalcuResultList(); if (allCalcuResultList == null || allCalcuResultList.Count < 1) { visualListCtrl.SetNormalView(); } else { visualListCtrl.SetCalcuView(); } this.controlContainerBottom.Controls.Clear(); this.controlContainerBottom.Controls.Add(visualListCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "构件明细"; this.docPnlBottom.Height = 350; } //更新构件明细控件 private void UpdateVisualListCtrl() { if (!IsVisualListCtrlVisible) { return; } _visualListCtrl?.UpdateBindingData(); } //构件明细 private void barBtnHydroVisualList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowVisualListCtrl(); } #endregion #endregion #region 监测列表 #region 测点列表 //所有监测点列表 private List _allMonitorList = null; //获取监测点列表 private async Task> GetMonitorList() { if (_hydroInfo == null) { return default; } if (_allMonitorList == null) { _allMonitorList = await BLLFactory.Instance.GetByModelID(_hydroInfo.ID); if (_allMonitorList == null) { _allMonitorList = new List(); } } return _allMonitorList; } //更新监测点列表 private async void UpdateMonitorList(string code) { if (_hydroInfo == null) { return; } if (string.IsNullOrEmpty(code)) { return; } var allMonitorList = await GetMonitorList(); allMonitorList.RemoveAll(x => x.Relation == code); var monitorList = await BLLFactory.Instance.GetByRelation(_hydroInfo.ID, code); if (monitorList != null && monitorList.Count > 0) { allMonitorList.AddRange(monitorList); } UpdateMonitorValueList(code, monitorList); SetLogicMonitorList(); } //设置选择构件监测点列表 private async void SetSelectVisualMonitorList() { if (_hydroInfo == null) { return; } if (_selectedVisual == null) { return; } var allMonitorList = await GetMonitorList(); var dlg = new SetHydroVisualMonitorDlg(); dlg.SetBindingData(_hydroInfo, _selectedVisual, allMonitorList); dlg.ReloadDataEvent += async (hydroInfo, visual, list) => { if (hydroInfo == null) { return; } if (visual == null) { return; } var bol = await BLLFactory.Instance.Save(hydroInfo.ID, visual.Code, list); if (!bol) { TipFormHelper.ShowError("设置失败"); return; } TipFormHelper.ShowSucceed("设置成功"); UpdateMonitorList(visual.Code); }; dlg.ShowDialog(); } //设置监测点 private void barBtnSetMonitor_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { SetSelectVisualMonitorList(); } #endregion #region 监测值列表 //所有监测值列表 private List _allMonitorValueList = null; //获取监测值列表 private async Task> GetMonitorValueList() { if (_allMonitorValueList == null) { _allMonitorValueList = new List(); var allMonitorList = await GetMonitorList(); var allVisualViewModelList = GetVisualViewModelList(); allMonitorList.ForEach(x => { var visual = allVisualViewModelList.Find(t => t.Code == x.Relation); if (visual != null) { var vm = new HydroVisualMonitorValueViewModel(visual.Vmo, x); _allMonitorValueList.Add(vm); } }); } return _allMonitorValueList; } //更新监测值列表 private async void UpdateMonitorValueList(string code, List monitorList) { if (string.IsNullOrEmpty(code)) { return; } var visual = GetVisualViewModel(code)?.Vmo; if (visual == null) { return; } var allMonitorValueList = await GetMonitorValueList(); var monitorValueList = allMonitorValueList.Where(x => x.Vmo.Relation == code).ToList(); monitorValueList?.ForEach(x => { var result = monitorList?.Exists(t => t.Relation == x.Vmo.Relation && t.PropName == x.Vmo.PropName); if (!(result.HasValue && result.Value)) { allMonitorValueList.Remove(x); } }); monitorList?.ForEach(x => { var result = monitorValueList?.Exists(t => t.Vmo.Relation == x.Relation && t.Vmo.PropName == x.PropName); if (!(result.HasValue && result.Value)) { var vm = new HydroVisualMonitorValueViewModel(visual, x); allMonitorValueList.Add(vm); } }); } #endregion #region 监测值列表控件 //监测值列表控件 private HydroVisualMonitorValueListCtrl _monitorValueListCtrl = null; //获取监测值列表控件 private HydroVisualMonitorValueListCtrl GetMonitorValueListCtrl() { if (_monitorValueListCtrl == null) { _monitorValueListCtrl = new HydroVisualMonitorValueListCtrl(); _monitorValueListCtrl.Dock = DockStyle.Fill; _monitorValueListCtrl.HydroViewEvent += (code) => { _bimfaceCtrl?.ZoomToComponent(code); }; } return _monitorValueListCtrl; } //显示监测值列表控件 private async void ShowMonitorValueListCtrl() { var monitorValueListCtrl = GetMonitorValueListCtrl(); var allMonitorValueList = await GetMonitorValueList(); monitorValueListCtrl.SetBindingData(allMonitorValueList); this.controlContainerBottom.Controls.Clear(); this.controlContainerBottom.Controls.Add(monitorValueListCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "监测值"; this.docPnlBottom.Height = 350; } //设置监测值 private void barBtnSetMonitorValue_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowMonitorValueListCtrl(); } #endregion #region 监测列表显示 //监测是否显示 private bool _isMonitorVisible = false; //获取业务监测列表 private async Task> GetLogicMonitorList() { var allMonitorList = await GetMonitorList(); var allLogicMonitorList = allMonitorList.Select(x => { var logicMonitor = new LogicMonitor(); logicMonitor.Id = x.Relation; logicMonitor.PropName = x.PropName; logicMonitor.Description = x.Description; return logicMonitor; }).ToList(); return allLogicMonitorList; } //设置业务监测列表 private async void SetLogicMonitorList() { if (_isMonitorVisible) { var allLogicMonitorList = await GetLogicMonitorList(); await _bimfaceCtrl?.SetLogicMonitors(allLogicMonitorList); } else { await _bimfaceCtrl?.ClearLogicMonitors(); } } //显示状态改变 private void barCkMonitor_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { _isMonitorVisible = this.barCkMonitor.Checked; SetLogicMonitorList(); } #endregion #endregion #region 水力检查 #region 检查结果 //检查结果缓存 private HydroCheckResult _checkResult = null; //获取检查结果 //needCheckAgain 用于确定是否需要重新检查 private HydroCheckResult GetCheckResult(bool needCheckAgain = false) { if (_hydroInfo == null) { return default; } if (needCheckAgain) { _checkResult = _hydroInfo.Check(); } if (_checkResult == null) { _checkResult = _hydroInfo.Check(); } return _checkResult; } #endregion #region 检查控件 //检查控件 private HydroCheckResultCtrl _checkCtrl = null; //获取检查控件 private HydroCheckResultCtrl GetCheckCtrl() { if (_checkCtrl == null) { _checkCtrl = new HydroCheckResultCtrl(); _checkCtrl.Dock = DockStyle.Fill; _checkCtrl.HydroClickEvent += async (code) => { if (_hydroInfo == null) { return; } var elementIds = new List(); if (string.IsNullOrEmpty(code)) { this.SelectedVisual = null; } else { var allVisualViewModelList = GetVisualViewModelList(); this.SelectedVisual = allVisualViewModelList?.Find(x => x.Code == code)?.Vmo; if (this.SelectedVisual != null) { elementIds.Add(this.SelectedVisual.Code); } } await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); ShowSelectedProperty(); }; } return _checkCtrl; } //显示检查控件 //needCheckAgain 用于确定是否需要重新检查 private void ShowCheckCtrl(bool needCheckAgain = false) { var checkResult = GetCheckResult(needCheckAgain); if (checkResult == null) { return; } var checkCtrl = GetCheckCtrl(); checkCtrl.SetBindingData(checkResult); this.controlContainerBottom.Controls.Clear(); this.controlContainerBottom.Controls.Add(checkCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "检查结果"; this.docPnlBottom.Height = 350; } #endregion //检查 private void barBtnCheck_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowCheckCtrl(true); } #endregion #region EPA计算结果 //EPA计算结果 private Yw.EPAnet.CalcuResult _epaCalcuResult = null; //获取EPA计算结果 //CalcuMode 在 Yw.EPANet.Calcu.Core 中定义 //NeedCalcuAgain 是否需要重新计算 private Yw.EPAnet.CalcuResult GetEpaCalcuResult(string calcuMode, bool needCalcuAgain = false) { if (_hydroInfo == null) { return default; } if (needCalcuAgain) { var network = _hydroInfo.ToNetwork(); _epaCalcuResult = network.Calcu(calcuMode); } if (_epaCalcuResult == null) { var network = _hydroInfo.ToNetwork(); _epaCalcuResult = network.Calcu(calcuMode); } return _epaCalcuResult; } #endregion #region 计算失败 //计算失败控件 private HydroCalcuFailedCtrl _calcuFailedCtrl = null; //获取计算失败控件 private HydroCalcuFailedCtrl GetCalcuFailedCtrl() { if (_calcuFailedCtrl == null) { _calcuFailedCtrl = new HydroCalcuFailedCtrl(); _calcuFailedCtrl.Dock = DockStyle.Fill; } return _calcuFailedCtrl; } //显示计算失败控件 private void ShowCalcuFailedCtrl(Yw.EPAnet.CalcuResult calcuResult) { if (_hydroInfo == null) { return; } if (calcuResult == null) { return; } if (calcuResult.Succeed) { return; } var calcuFailedCtrl = GetCalcuFailedCtrl(); calcuFailedCtrl.SetBindingData(calcuResult.FailedList); this.controlContainerBottom.Controls.Clear(); this.controlContainerBottom.Controls.Add(calcuFailedCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "计算失败原因"; this.docPnlBottom.Height = 350; } //显示计算失败控件 private void ShowCalcuFailedCtrl() { ShowCalcuFailedCtrl(_epaCalcuResult); } #endregion #region 管网修复 //修复管网 private void Repair() { if (_hydroInfo == null) { return; } var checkResult = GetCheckResult(true); if (checkResult == null) { return; } if (!checkResult.Succeed) { ShowCheckCtrl(false); TipFormHelper.ShowWarn("检查失败导致无法进行试算,停止修复!"); return; } var calcuResult = GetEpaCalcuResult(Yw.EPAnet.CalcuMode.Simple, true); if (calcuResult == null || !calcuResult.Succeed) { ShowCalcuFailedCtrl(calcuResult); TipFormHelper.ShowWarn("试算失败,停止修复!"); return; } var allLinks = _hydroInfo.GetAllLinks(); if (allLinks != null && allLinks.Count < 1) { TipFormHelper.ShowError("模型中未包含管段信息,停止修复!"); return; } int count = 0; foreach (var link in allLinks) { var calcuLink = calcuResult.LinkList?.Find(x => x.Id == link.Code); if (calcuLink == null) { continue; } if (calcuLink.Flow < 0) { var tempCode = link.StartCode; link.StartCode = link.EndCode; link.EndCode = tempCode; count++; } } UpdateVisualViewModelProperty(); UpdateVisualListCtrl(); UpdateSelectedProperty(); TipFormHelper.ShowSucceed($"修复完成,共修复管段({count})个!"); } //管网修复 private void barBtnRepair_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { Repair(); } #endregion #region 导出INP文件 //导出INP文件 private void barBtnExportInp_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } var fileName = FileDialogHelper.SaveInp("导出Inp文件"); if (string.IsNullOrEmpty(fileName)) { return; } var netWork = Yw.Hydro.ParseHelper.ToNetwork(_hydroInfo); var result = netWork.ToInpString(); File.WriteAllText(fileName, result); TipFormHelper.ShowSucceed("导出成功"); } #endregion #region 并联分析 //并联分析 private void ParallelAnalysis() { if (_hydroInfo == null) { return; } var pumps = _hydroInfo.Pumps; if (pumps == null || pumps.Count < 1) { XtraMessageBox.Show("无水泵信息"); return; } var vmList = new List(); foreach (var pump in pumps) { if (!pump.RatedN.HasValue) { continue; } var qh = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQH)?.CurveData; var qe = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQE)?.CurveData; var qp = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQP)?.CurveData; if (qh == null) { continue; } var qhPtList = qh.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList(); var qePtList = qe?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList(); var qpPtList = qp?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList(); var vm = new XhsSinglePumpViewModel(); vmList.Add(vm); vm.ID = pump.ID; vm.Name = pump.Name; vm.Code = pump.Code; vm.IsBp = true; vm.RunStatus = pump.LinkStatus == Yw.Hydro.LinkStatus.Open; vm.RatedHz = pump.RatedHz; vm.CurrentHz = Math.Round(pump.RatedHz * pump.SpeedRatio, 1); vm.RatedSpeed = pump.RatedN.Value; vm.CurrentSpeed = Math.Round(pump.RatedN.Value * pump.SpeedRatio, 1); vm.CurveQH = qhPtList; vm.CurveQE = qePtList; vm.CurveQP = qpPtList; } var dlg = new PumpParallelAnalyDlg(); dlg.SetBindingData(vmList); dlg.ReloadDataEvent += (list) => { list?.ForEach(x => { var pump = pumps.Find(t => t.Code == x.Code); if (pump != null) { pump.LinkStatus = x.RunStatus ? Yw.Hydro.PumpStatus.Open : Yw.Hydro.PumpStatus.Closed; pump.SpeedRatio = x.CurrentHz / pump.RatedHz; } }); var codes = list?.Select(x => x.Code).ToList(); UpdateVisualViewModelProperty(codes); ShowSelectedProperty(); UpdateVisualListCtrl(); return true; }; dlg.ShowDialog(); } //并联分析 private void barBtnParallel_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ParallelAnalysis(); } #endregion #region 工况计算 //所有工况元组列表 private Tuple _allWorkingTupleList = null; #region 工况 //显示工况计算窗体 private void ShowWorkingCalcuDlg() { var dlg = new SetHydroWorkingDlg(); dlg.HydroViewEvent += async (parter) => { _selectedVisual = parter as Yw.Model.HydroVisualInfo; if (_selectedVisual != null) { await _bimfaceCtrl?.ZoomAndSelectComponents(new List() { _selectedVisual.Code }); } ShowSelectedProperty(); }; dlg.HydroCalcuEvent += async (hydroInfo, workingInfo) => { if (_hydroInfo == null) { return; } _hydroInfo.UpdateWorkingInfo(workingInfo); //校验 _checkResult = _hydroInfo.Check(); if (!_checkResult.Succeed) { ShowCheckCtrl(); TipFormHelper.ShowWarn("校验失败,请检查后重试"); return; } WaitFormHelper.ShowWaitForm(this, "正在计算分析中,请稍候..."); //await Task.Delay(5000); var netWork = Yw.Hydro.ParseHelper.ToNetwork(_hydroInfo); _epaCalcuResult = netWork.CalcuMinorLoss(); WaitFormHelper.HideWaitForm(); if (_epaCalcuResult.Succeed) { GetCalcuResultList(false); UpdateVisualViewModelProperty(); UpdateVisualViewModelCalcuProperty(); UpdateVisualListCtrl(); UpdateSelectedProperty(); await _bimfaceCtrl?.SetLogicCalcuCustomLabels(_epaCalcuResult); TipFormHelper.ShowSucceed("计算成功!"); var codes = _hydroInfo.Pumps.Select(x => x.Code).ToList(); await _bimfaceCtrl?.ZoomAndSelectComponents(codes); } else { ShowCalcuFailedCtrl(); TipFormHelper.ShowError("计算失败!"); } AutoApplyGrading(); UpdateVisualListCtrl(); ShowSelectedProperty(); }; dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); } #endregion #region 计算结果 //所有计算结果列表 private List _allCalcuResultList = null; //获取计算结果 //true 使用缓存,false 不使用缓存 private List GetCalcuResultList(bool isCache = true) { if (_hydroInfo == null) { return default; } if (_epaCalcuResult == null) { return default; } if (!_epaCalcuResult.Succeed) { return default; } if (isCache) { return _allCalcuResultList; } _allCalcuResultList = new List(); //节点 var allNodeList = _hydroInfo.GetAllNodes(); if (allNodeList != null && allNodeList.Count > 0) { foreach (var node in allNodeList) { var calcuNode = _epaCalcuResult.NodeList?.Find(x => x.Id == node.Code); if (calcuNode != null) { var calcuResult = new HydroCalcuNodeResult() { Code = node.Code, CalcuPress = calcuNode.Press, CalcuHead = calcuNode.Head, CalcuDemand = calcuNode.Demand }; _allCalcuResultList.Add(calcuResult); } } } //管段 var allLinkList = _hydroInfo.GetAllLinks(); if (allLinkList != null && allLinkList.Count > 0) { foreach (var link in allLinkList) { var calcuLink = _epaCalcuResult.LinkList?.Find(x => x.Id == link.Code); if (calcuLink != null) { var calcuResult = new HydroCalcuLinkResult() { Code = link.Code, CalcuFlow = calcuLink.Flow, CalcuVelocity = calcuLink.Velocity, CalcuHeadLoss = calcuLink.Headloss }; _allCalcuResultList.Add(calcuResult); } } } //流量计 var allFlowmeterList = _hydroInfo.Flowmeters; if (allFlowmeterList != null && allFlowmeterList.Count > 0) { foreach (var flowmeter in allFlowmeterList) { var calcuFlowmeterResult = _allCalcuResultList.Find(x => x.Code == flowmeter.Code) as HydroCalcuNodeResult; if (calcuFlowmeterResult != null) { var calcuFlowmeterNewResult = new HydroCalcuFlowmeterResult(calcuFlowmeterResult); var calcuFlowmeterLinkResultList = new List(); var flowmeterLinkList = allLinkList?.Where(x => x.StartCode == flowmeter.Code || x.EndCode == flowmeter.Code).ToList(); if (flowmeterLinkList != null && flowmeterLinkList.Count > 0) { foreach (var flowmeterLink in flowmeterLinkList) { var calcuFlowmeterLinkResult = _allCalcuResultList.Find(x => x.Code == flowmeterLink.Code) as HydroCalcuLinkResult; if (calcuFlowmeterLinkResult != null) { calcuFlowmeterLinkResultList.Add(calcuFlowmeterLinkResult); } } } if (calcuFlowmeterLinkResultList.Exists(x => x.CalcuFlow.HasValue)) { calcuFlowmeterNewResult.CalcuQ = calcuFlowmeterLinkResultList.Where(x => x.CalcuFlow.HasValue).Average(x => x.CalcuFlow.Value); } _allCalcuResultList.Remove(calcuFlowmeterResult); _allCalcuResultList.Add(calcuFlowmeterNewResult); } } } //压力表 var allPressmeterList = _hydroInfo.Pressmeters; if (allPressmeterList != null && allPressmeterList.Count > 0) { foreach (var pressmeter in allPressmeterList) { var calcuPressmeterResult = _allCalcuResultList.Find(x => x.Code == pressmeter.Code) as HydroCalcuNodeResult; if (calcuPressmeterResult != null) { var calcuPressmeterNewResult = new HydroCalcuPressmeterResult(calcuPressmeterResult); calcuPressmeterNewResult.CalcuPr = calcuPressmeterResult.CalcuPress; _allCalcuResultList.Remove(calcuPressmeterResult); _allCalcuResultList.Add(calcuPressmeterNewResult); } } } //水泵 var allPumpList = _hydroInfo.Pumps; if (allPumpList != null && allPumpList.Count > 0) { foreach (var pump in allPumpList) { var calcuPumpResult = _allCalcuResultList.Find(x => x.Code == pump.Code) as HydroCalcuLinkResult; if (calcuPumpResult != null) { var calcuPumpNewResult = new HydroCalcuPumpResult(calcuPumpResult); calcuPumpNewResult.CalcuQ = calcuPumpResult.CalcuFlow; if (calcuPumpNewResult.CalcuQ.HasValue) { var calcuNodeStartResult = _allCalcuResultList.Find(x => x.Code == pump.StartCode) as HydroCalcuNodeResult; var calcuNodeEndResult = _allCalcuResultList.Find(x => x.Code == pump.EndCode) as HydroCalcuNodeResult; if (calcuNodeStartResult != null && calcuNodeEndResult != null) { if (calcuNodeStartResult.CalcuPress.HasValue && calcuNodeEndResult.CalcuPress.HasValue) { calcuPumpNewResult.CalcuH = Math.Abs(calcuNodeStartResult.CalcuPress.Value - calcuNodeEndResult.CalcuPress.Value); } if (pump.LinkStatus == Yw.Hydro.PumpStatus.Open && pump.RatedN.HasValue) { var curveqp = _hydroInfo.Curves?.Find(x => x.Code == pump.CurveQP); if (curveqp != null) { if (curveqp.CurveData != null && curveqp.CurveData.Count > 3) { var point2dList = curveqp.CurveData.Select(x => new Yw.Geometry.Point2d(x.X, x.Y)).ToList(); var point2dSimularList = point2dList.GetQPPointListByN(pump.RatedN.Value, pump.RatedN.Value * pump.SpeedRatio); var pumpCurveQp = new Yw.Pump.CurveQP(eFeatType.Cubic, point2dSimularList); calcuPumpNewResult.CalcuP = pumpCurveQp.FeatCurve.GetPointY(calcuPumpNewResult.CalcuQ.Value); } } } if (calcuPumpNewResult.CalcuH.HasValue && calcuPumpNewResult.CalcuP.HasValue) { calcuPumpNewResult.CalcuE = Yw.Pump.CalculationHelper.CalcuE(calcuPumpNewResult.CalcuQ.Value, calcuPumpNewResult.CalcuH.Value, calcuPumpNewResult.CalcuP.Value); } } } _allCalcuResultList.Remove(calcuPumpResult); _allCalcuResultList.Add(calcuPumpNewResult); } } } return _allCalcuResultList; } #endregion //水力计算 private void barBtnHydroCalcu_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowWorkingCalcuDlg(); } #endregion } }