global using Yw.EPAnet; using DevExpress.Mvvm.Native; using DevExpress.XtraRichEdit.Layout; using DevExpress.XtraSpreadsheet.Commands; using HStation.WinFrmUI.PhartRelation; using Yw.Pump; 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); var allCalcuResultList = GetAllCalcuResultList(); if (allCalcuResultList != null && allCalcuResultList.Count > 0) { var calcuResult = allCalcuResultList.Find(x => x.Code == _parter.Code); if (calcuResult != null) { _propertyCtrl?.UpdateCalcuProperty(calcuResult); } } } #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 { if (_hydroInfo == null) { return; } var dlg = new HydroBluntheadBulkSetListDlg(); dlg.ShowDialog(); }; //弯头 this.barBtnSetElbowsList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroElbowBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //三通 this.barBtnSetThreelinkList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroThreelinkBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //四通 this.barBtnSetFourlinkList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroFourlinkBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //水表 this.barBtnSetMeterList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroMeterBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //流量计 this.barBtnSetFlowmeterList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroFlowmeterBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //压力表 this.barBtnSetPressmeterList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroPressmeterBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //管道 this.barBtnSetPipeList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroPipeBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //水泵 this.barBtnSetPumpList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroPumpBulkSetListDlg(); dlg.SetBindingData(_hydroInfo); dlg.ShowDialog(); }; //阀门 this.barBtnSetValveList.ItemClick += delegate { if (_hydroInfo == null) { return; } var dlg = new HydroValveBulkSetListDlg(); 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 = 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 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); } }); ShowProperty(); return true; }; dlg.ShowDialog(); } #endregion #region 水力计算 #region 前提条件 //显示计算前提条件窗体 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) { GetAllCalcuResultList(false); await _bimfaceCtrl?.SetLogicCalcuCustomLabels(_calcuResult); TipFormHelper.ShowSucceed("计算成功!"); } else { ShowCalcuFailedCtrl(); TipFormHelper.ShowError("计算失败!"); } }; 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; } #endregion #region 计算结果 //所有计算结果列表 private List _allCalcuResultList = null; //获取计算结果 //true 使用缓存,false 不使用缓存 private List GetAllCalcuResultList(bool isCache = true) { if (_hydroInfo == null) { return default; } if (_calcuResult == null) { return default; } if (!_calcuResult.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 = _calcuResult.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 = _calcuResult.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) { 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.Cancel) { 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 } }