global using Yw.EPAnet; using DevExpress.Mvvm.Native; using DevExpress.XtraRichEdit.Layout; using HStation.WinFrmUI.PhartRelation; 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;//水力信息 private Yw.Model.HydroParterInfo _parter = null; private Yw.WinFrmUI.HydroCheckResult _checkResult = null; private Yw.EPAnet.CalcuResult _calcuResult = 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; } }; _bimfaceCtrl.HydroMouseLeftClickEvent += (obj) => {//鼠标左键点击事件 if (_hydroInfo == null) { return; } _parter = obj; ShowProperty(); }; } return _bimfaceCtrl; } //显示 bimface 控件 private async void ShowBimfaceCtrl() { var bimfaceCtrl = await GetBimfaceCtrl(); this.tabPageBimface.Controls.Clear(); this.tabPageBimface.Controls.Add(bimfaceCtrl); } #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.GetAllParters(); _parter = allParterList?.Find(x => x.Code == obj?.FirstOrDefault()); ShowProperty(); }; } 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, () => GetAllCalcuResultList()); _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(); }; } return _propertyCtrl; } //显示属性面板 private void ShowPropertyCtrl() { 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 barBtnProperty_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowPropertyCtrl(); } //显示属性 private void ShowProperty() { if (_hydroInfo == null) { return; } if (this.docPnlRight.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Hidden) { ShowPropertyCtrl(); } if (_parter == null) { _propertyCtrl?.SelectParter(null); return; } _propertyCtrl?.SelectParter(_parter.Code); if (_calcuResult != null) { if (_calcuResult.Succeed) { var allCalcuParterList = _calcuResult.GetParterList(); var calcuParter = allCalcuParterList.Find(x => x.Id == _parter.Code); if (calcuParter != null) { IHydroCalcuResult calcuProperty = null; if (calcuParter is Yw.EPAnet.CalcuNode calcuNode) { var calcuNodeProperty = new Yw.WinFrmUI.HydroCalcuNodeResult(); calcuNodeProperty.Code = _parter.Code; calcuNodeProperty.CalcuPress = calcuNode.Press; calcuNodeProperty.CalcuDemand = calcuNode.Demand; calcuNodeProperty.CalcuHead = calcuNode.Head; calcuProperty = calcuNodeProperty; } else if (calcuParter is Yw.EPAnet.CalcuLink calcuLink) { var calcuLinkProperty = new Yw.WinFrmUI.HydroCalcuLinkResult(); calcuLinkProperty.Code = _parter.Code; calcuLinkProperty.CalcuHeadLoss = calcuLink.Headloss; calcuLinkProperty.CalcuFlow = calcuLink.Flow; calcuLinkProperty.CalcuVelocity = calcuLink.Velocity; calcuProperty = calcuLinkProperty; } if (calcuProperty != null) { _propertyCtrl?.UpdateCalcuProperty(calcuProperty); } } } } } #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.GetAllParters(); _parter = allParterList?.Find(x => x.Code == code); var elementIds = new List(); if (_parter != null) { elementIds.Add(_parter.Code); } await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); ShowProperty(); }; _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, GetAllCalcuResultList()); 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.GetAllParters(); _parter = allParterList?.Find(x => x.Code == parter.Code); var elementIds = new List() { parter.Code }; await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); ShowProperty(); }; _unMatchingListCtrl.ViewModelEvent += async (parters) =>//查看模型 { var codes = parters?.Select(x => x.Code).Distinct().ToList(); await _bimfaceCtrl?.ZoomAndSelectComponents(codes); _parter = null; ShowProperty(); }; } 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 async Task 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 List _fastShowHiddenCodeList = null; //触发一键显隐 private async void barBtnFastShowHidden_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { await FastShowHidden(); } #endregion #region 水力校验 //校验控件 private XhsProjectSimulationHydroCheckResultCtrl _checkCtrl = null; //获取校验控件 private XhsProjectSimulationHydroCheckResultCtrl GetCheckCtrl() { if (_checkCtrl == null) { _checkCtrl = new XhsProjectSimulationHydroCheckResultCtrl(); _checkCtrl.Dock = DockStyle.Fill; _checkCtrl.HydroClickEvent += async (code) => { if (_hydroInfo == null) { return; } var elementIds = new List(); if (string.IsNullOrEmpty(code)) { _parter = null; } else { var allParterList = _hydroInfo.GetAllParters(); _parter = allParterList?.Find(x => x.Code == code); if (_parter != null) { elementIds.Add(_parter.Code); } } await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); ShowProperty(); }; } return _checkCtrl; } //显示校验控件 private void ShowCheckCtrl() { 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; } //水力验证 private void barBtnHydroCheck_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } _checkResult = _hydroInfo.Check(); ShowCheckCtrl(); } #endregion #region 保存信息 //保存 private async void barBtnSave_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } var id = await BLLFactory.Instance.Save(_hydroInfo); if (id < 1) { TipFormHelper.ShowError("保存失败!"); return; } _hydroInfo = await BLLFactory.Instance.GetByID(id); TipFormHelper.ShowSucceed("保存成功!"); } #endregion #region 构件明细 //构件明细控件 private Yw.WinFrmUI.HydroParterListCtrl _parterListCtrl = null; //获取构件明细控件 private Yw.WinFrmUI.HydroParterListCtrl GetParterListCtrl() { if (_parterListCtrl == null) { _parterListCtrl = new HydroParterListCtrl(); _parterListCtrl.Dock = DockStyle.Fill; _parterListCtrl.HydroClickEvent += async (parter) => { if (_hydroInfo == null) { return; } var allParterList = _hydroInfo.GetAllParters(); _parter = allParterList?.Find(x => x.Code == parter.Code); await _bimfaceCtrl?.ZoomAndSelectComponents(new List() { _parter.Code }); ShowProperty(); }; } return _parterListCtrl; } //显示构件明细控件 private void ShowParterListCtrl() { if (_hydroInfo == null) { return; } var parterListCtrl = GetParterListCtrl(); parterListCtrl.SetBindingData(_hydroInfo, GetAllCalcuResultList()); this.controlContainerBottom.Controls.Clear(); this.controlContainerBottom.Controls.Add(parterListCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "构件明细"; this.docPnlBottom.Height = 350; } //构件明细 private void barBtnHydroParterList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowParterListCtrl(); } #endregion #region INP导出 //导出水力INP文件 private void barBtnHydroExportInp_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } var fileName = Yw.WinFrmUI.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 INP导出 #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 HydroWaterboxBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //连接节点 this.barBtnSetJunctionList.ItemClick += delegate { var dlg = new HydroJunctionBulkSetListDlg(); dlg.ShowDialog(); }; //闷头 this.barBtnSetBluntheadList.ItemClick += delegate { var dlg = new HydroBluntheadBulkSetListDlg(); dlg.ShowDialog(); }; //弯头 this.barBtnSetElbowsList.ItemClick += delegate { var dlg = new HydroElbowBulkSetListDlg(); dlg.ShowDialog(); }; //三通 this.barBtnSetThreelinkList.ItemClick += delegate { var dlg = new HydroThreelinkBulkSetListDlg(); dlg.ShowDialog(); }; //四通 this.barBtnSetFourlinkList.ItemClick += delegate { }; } //显示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 = GetAllCalcuResultList(); 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 PumpParallelChartDlg(); 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); } }); ShowProperty(); return true; }; dlg.ShowDialog(); } #endregion #region 水力计算 //计算失败控件 private HydroCalcuFailedCtrl _calcuFailedCtrl = null; //获取计算失败控件 private HydroCalcuFailedCtrl GetCalcuFailedCtrl() { if (_calcuFailedCtrl == null) { _calcuFailedCtrl = new HydroCalcuFailedCtrl(); _calcuFailedCtrl.Dock = DockStyle.Fill; } return _calcuFailedCtrl; } //显示计算失败控件 private void ShowCalcuFailedCtrl() { 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 List GetAllCalcuResultList() { if (_hydroInfo == null) { return default; } if (_calcuResult == null) { return default; } if (!_calcuResult.Succeed) { return default; } var list = new List(); var allNodeList = _hydroInfo.GetAllNodes(); if (allNodeList != null && allNodeList.Count > 0) { var allCalcuNodeList = _calcuResult.NodeList; if (allCalcuNodeList != null && allCalcuNodeList.Count > 0) { foreach (var node in allNodeList) { var calcuNode = allCalcuNodeList.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 }; list.Add(calcuResult); } } } } var allListList = _hydroInfo.GetAllLinks(); if (allListList != null && allListList.Count > 0) { var allCalcuLinkList = _calcuResult.LinkList; if (allCalcuLinkList != null && allCalcuLinkList.Count > 0) { foreach (var link in allListList) { var calcuLink = allCalcuLinkList.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 }; list.Add(calcuResult); } } } } return list; } //显示计算前提窗体 private async void ShowCalcuPrefixDlg() { if (_hydroInfo == null) { return; } var dlg = new SetHydroCalcuPrefixDlg(); dlg.SetBindingData(_hydroInfo); dlg.HydroViewEvent += async (parter) => { _parter = parter; if (_parter != null) { await _bimfaceCtrl?.ZoomAndSelectComponents(new List() { _parter.Code }); } ShowProperty(); }; dlg.HydroCalcuEvent += async () => { if (_hydroInfo == null) { return; } //校验 _checkResult = _hydroInfo.Check(); if (!_checkResult.Succeed) { ShowCheckCtrl(); TipFormHelper.ShowWarn("校验失败,请检查后重试"); return; } var netWork = Yw.Hydro.ParseHelper.ToNetwork(_hydroInfo); _calcuResult = netWork.Calcu(); if (_calcuResult.Succeed) { await _bimfaceCtrl?.SetLogicCalcuCustomLabels(_calcuResult); TipFormHelper.ShowSucceed("计算成功!"); } else { ShowCalcuFailedCtrl(); TipFormHelper.ShowError("计算失败!"); } }; if (dlg.ShowDialog() == DialogResult.Cancel) { await _bimfaceCtrl?.ClearLogicCalcuCustomLabels(); } } //水力计算 private void barBtnHydroCalcu_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowCalcuPrefixDlg(); } #endregion #region 构件查询 //查询组件 private XhsProjectSimulationSearchCtrl _searchCtrl = null; //获取查询组件 private XhsProjectSimulationSearchCtrl GetSearchCtrl() { if (_searchCtrl == null) { _searchCtrl = new XhsProjectSimulationSearchCtrl(); _searchCtrl.Dock = DockStyle.Fill; _searchCtrl.InitialData(() => _hydroInfo); _searchCtrl.ApplySearchEvent += async (list) => { if (_hydroInfo == null) { return; } var elementIds = new List(); if (list != null && list.Count > 0) { var first = list.First(); var allParterList = _hydroInfo.GetAllParters(); _parter = allParterList?.Find(x => x.Code == first.Code); list.ForEach(x => elementIds.Add(x.Code)); } else { _parter = null; } await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds); ShowProperty(); }; } return _searchCtrl; } //显示查询控件 private void ShowSearchCtrl() { if (_hydroInfo == null) { return; } var searchCtrl = GetSearchCtrl(); 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 barBtnSearch_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowSearchCtrl(); } #endregion #region 模型标注 //所有标注列表 private List _allMarkList = null; //显示标注窗体 private async void ShowMarkDlg() { if (_hydroInfo == null) { return; } if (_allMarkList == null) { _allMarkList = new List(); if (_hydroInfo.Waterboxs != null && _hydroInfo.Waterboxs.Count > 0) { _allMarkList.Add(new HydroMarkSetViewModel() { Code = Yw.Hydro.ParterCatalog.Waterbox, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Waterbox), MarkType = (int)eWaterboxMarkType.None }); } if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0) { _allMarkList.Add(new HydroMarkSetViewModel() { Code = Yw.Hydro.ParterCatalog.Pump, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Pump), MarkType = (int)eWaterboxMarkType.None }); } if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0) { _allMarkList.Add(new HydroMarkSetViewModel() { Code = Yw.Hydro.ParterCatalog.Valve, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Valve), MarkType = (int)eWaterboxMarkType.None }); } if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0) { _allMarkList.Add(new HydroMarkSetViewModel() { Code = Yw.Hydro.ParterCatalog.Pipe, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Pipe), MarkType = (int)eWaterboxMarkType.None }); } if (_hydroInfo.Nozzles != null && _hydroInfo.Nozzles.Count > 0) { _allMarkList.Add(new HydroMarkSetViewModel() { Code = Yw.Hydro.ParterCatalog.Nozzle, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Nozzle), MarkType = (int)eWaterboxMarkType.None }); } } var dlg = new SetHydroMarkDlg(); dlg.InitialData(() => _hydroInfo); dlg.SetBindingData(_allMarkList); dlg.ReloadDataEvent += async (allResultList) => { var leadLabels = allResultList?.Select(x => new LogicMarkLeadLabel(x.Code, x.Text)).ToList(); await _bimfaceCtrl?.SetLogicMarkLeadLabels(leadLabels); }; if (dlg.ShowDialog() != DialogResult.OK) { await _bimfaceCtrl?.ClearLogicMarkLeadLabels(); } } //设置标注 private void barBtnSetMark_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowMarkDlg(); } #endregion #region 颜色分级 //颜色分级应用列表 private List _allGradingApplyList = null; //颜色分级编码列表 private List _allGradingCodeList = null; //设置颜色分级 private void SetGrading() { if (_hydroInfo == null) { return; } var dlg = new SetHydroGradingModelDlg(); dlg.SetBindingData(_hydroInfo.ID); dlg.ShowDialog(); } //应用颜色分级 private async void ApplyGrading() { if (_hydroInfo == null) { return; } 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.GetCatalogName(Yw.Hydro.ParterCatalog.Pump), PropName = string.Empty }); } if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0) { _allGradingApplyList.Add(new HydroGradingApplyViewModel() { Code = Yw.Hydro.ParterCatalog.Valve, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Valve), PropName = string.Empty }); } if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0) { _allGradingApplyList.Add(new HydroGradingApplyViewModel() { Code = Yw.Hydro.ParterCatalog.Pipe, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Pipe), PropName = string.Empty }); } } var dlg = new ApplyHydroGradingDlg(); dlg.SetBindingData(() => _hydroInfo, _allGradingApplyList, GetAllCalcuResultList()); dlg.ReloadDataEvent += (obj) => { _allGradingCodeList = obj?.Select(x => x.Code).Distinct().ToList(); var objGroupList = obj?.GroupBy(x => x.Color).ToList(); objGroupList.ForEach(async x => { await _bimfaceCtrl?.OverrideComponentsColor(x.Select(t => t.Code).Distinct().ToList(), x.Key, 1); }); }; if (dlg.ShowDialog() != DialogResult.OK) { await _bimfaceCtrl?.RestoreComponentsColor(_allGradingCodeList); } } //设置 private void barBtnGradingSet_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { SetGrading(); } //应用 private void barBtnGradingApply_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ApplyGrading(); } #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); _hydroInfo = await BLLFactory.Instance.GetByID(hydroRelation.ModelID); _parter = null; await _bimfaceCtrl?.ZoomAndSelectComponents(null); ShowProperty(); TipFormHelper.ShowSucceed("数据已刷新"); } } #endregion } }