global using Yw.EPAnet; using DevExpress.Mvvm.Native; using DevExpress.Xpo.Helpers; using DevExpress.XtraRichEdit.Layout; using DevExpress.XtraSpreadsheet.Commands; using HStation.WinFrmUI.PhartRelation; using System.Diagnostics; using System.Windows.Media.Media3D; 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;//水力信息 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; } _selectedParter = obj; ShowProperty(); }; } 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.GetAllParters(); _selectedParter = 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, () => 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.PropertyValueChangedEvent += (parter) => { if (parter == null) { return; } UpdateParterListProperty(parter); }; _propertyCtrl.ViewParterEvent += (parter) => { if (parter == null) { return; } _bimfaceCtrl?.ZoomToComponent(parter.Code); }; } 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 ShowProperty() { if (_hydroInfo == null) { return; } if (this.docPnlRight.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Hidden) { ShowPropertyCtrl(); } if (_selectedParter == null) { _propertyCtrl?.CancelSelectParter(); return; } _propertyCtrl?.SelectParter(_selectedParter.Code); var allCalcuResultList = GetCalcuResultList(); if (allCalcuResultList != null && allCalcuResultList.Count > 0) { var calcuResult = allCalcuResultList.Find(x => x.Code == _selectedParter.Code); if (calcuResult != null) { _propertyCtrl?.UpdateCalcuProperty(calcuResult); } } } #endregion #region 选择构件 //选择构件 private Yw.Model.HydroParterInfo _selectedParter = null; //更新选择组件属性 private void UpdateSelectedParterProperty() { if (_selectedParter == null) { return; } _propertyCtrl?.UpdateProperty(); } //更新选择组件计算属性 private void UpdateSelectedParterCalcuProperty() { if (_selectedParter == null) { return; } var allCalcuResultList = GetCalcuResultList(); if (allCalcuResultList == null || allCalcuResultList.Count < 1) { return; } var calcuResult = allCalcuResultList.Find(x => x.Code == _selectedParter.Code); if (calcuResult == null) { return; } _propertyCtrl?.UpdateCalcuProperty(calcuResult); } //更新构件列表属性 private void UpdateParterListProperty() { if (this.docPnlBottom.Visibility != DevExpress.XtraBars.Docking.DockVisibility.Visible) { return; } var parterListCtrl = this.controlContainerBottom.Controls[0] as Yw.WinFrmUI.HydroParterListCtrl; if (parterListCtrl == null) { return; } parterListCtrl.UpdateProperty(); } //更新构件列表属性 private void UpdateParterListProperty(Yw.Model.HydroParterInfo parter) { if (this.docPnlBottom.Visibility != DevExpress.XtraBars.Docking.DockVisibility.Visible) { return; } var parterListCtrl = this.controlContainerBottom.Controls[0] as Yw.WinFrmUI.HydroParterListCtrl; if (parterListCtrl == null) { return; } parterListCtrl.UpdateProperty(parter); } //更新构件列表属性 private void UpdateParterListProperty(List parterList) { if (this.docPnlBottom.Visibility != DevExpress.XtraBars.Docking.DockVisibility.Visible) { return; } var parterListCtrl = this.controlContainerBottom.Controls[0] as Yw.WinFrmUI.HydroParterListCtrl; if (parterListCtrl == null) { return; } parterListCtrl.UpdateProperty(parterList); } //更新构件列表计算属性 private void UpdateParterListCalcuProperty() { if (this.docPnlBottom.Visibility != DevExpress.XtraBars.Docking.DockVisibility.Visible) { return; } var parterListCtrl = this.controlContainerBottom.Controls[0] as Yw.WinFrmUI.HydroParterListCtrl; if (parterListCtrl == null) { return; } var allCalcuResultList = GetCalcuResultList(); parterListCtrl.UpdateCalcuProperty(allCalcuResultList); } #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(); _selectedParter = allParterList?.Find(x => x.Code == code); var elementIds = new List(); if (_selectedParter != null) { elementIds.Add(_selectedParter.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, 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.GetAllParters(); _selectedParter = 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); _selectedParter = 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)) { _selectedParter = null; } else { var allParterList = _hydroInfo.GetAllParters(); _selectedParter = allParterList?.Find(x => x.Code == code); if (_selectedParter != null) { elementIds.Add(_selectedParter.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; } 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 Yw.WinFrmUI.HydroParterListCtrl _parterListCtrl = null; //获取构件明细控件 private Yw.WinFrmUI.HydroParterListCtrl GetParterListCtrl() { if (_parterListCtrl == null) { _parterListCtrl = new HydroParterListCtrl(); _parterListCtrl.Dock = DockStyle.Fill; _parterListCtrl.HydroClickEvent += async (parter) => { _selectedParter = parter; await _bimfaceCtrl?.ZoomAndSelectComponent(_selectedParter.Code); ShowProperty(); }; _parterListCtrl.HydroChangedEvent += (parterList) => { UpdateSelectedParterProperty(); }; } return _parterListCtrl; } //显示构件明细控件 private void ShowParterListCtrl() { if (_hydroInfo == null) { return; } var allCalcuResultList = GetCalcuResultList(); var parterListCtrl = GetParterListCtrl(); parterListCtrl.SetBindingData(_hydroInfo, allCalcuResultList); if (allCalcuResultList == null || allCalcuResultList.Count < 1) { parterListCtrl.SetNormalView(); } else { parterListCtrl.SetCalcuView(); } 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 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); } }); ShowProperty(); return true; }; dlg.ShowDialog(); } #endregion #region 水力计算 #region 前提条件 //显示计算前提条件窗体 private void ShowCalcuPrefixDlg() { if (_hydroInfo == null) { return; } var dlg = new HStation.WinFrmUI.SetHydroCalcuPrefixDlg1(); dlg.SetBindingData(_hydroInfo); dlg.HydroViewEvent += async (parter) => { _selectedParter = parter; if (_selectedParter != null) { await _bimfaceCtrl?.ZoomAndSelectComponents(new List() { _selectedParter.Code }); } ShowProperty(); }; dlg.HydroCalcuEvent += async () => { if (_hydroInfo == null) { return; } //校验 _checkResult = _hydroInfo.Check(); if (!_checkResult.Succeed) { ShowCheckCtrl(); TipFormHelper.ShowWarn("校验失败,请检查后重试"); return; } WaitFormHelper.ShowWaitForm(this, "正在计算分析中,请稍候..."); //await Task.Delay(5000); var netWork = Yw.Hydro.ParseHelper.ToNetwork(_hydroInfo); _calcuResult = netWork.Calcu(); WaitFormHelper.HideWaitForm(); if (_calcuResult.Succeed) { GetCalcuResultList(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 GetCalcuResultList(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(); _selectedParter = allParterList?.Find(x => x.Code == first.Code); list.ForEach(x => elementIds.Add(x.Code)); } else { _selectedParter = 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 _allMarkSetList = null; //获取标注设置列表 private List GetMarkSetList() { if (_allMarkSetList == null) { _allMarkSetList = new List(); if (_hydroInfo.Waterboxs != null && _hydroInfo.Waterboxs.Count > 0) { _allMarkSetList.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) { _allMarkSetList.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) { _allMarkSetList.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) { _allMarkSetList.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) { _allMarkSetList.Add(new HydroMarkSetViewModel() { Code = Yw.Hydro.ParterCatalog.Nozzle, Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetCatalogName(Yw.Hydro.ParterCatalog.Nozzle), MarkType = (int)eWaterboxMarkType.None }); } } return _allMarkSetList; } //所有标注结果列表 private List _allMarkResultList = null; //获取标注结果列表 private List GetMarkResultList() { if (_hydroInfo == null) { return default; } _allMarkResultList = new List(); var allMarkSetList = GetMarkSetList(); foreach (var markSet in allMarkSetList) { switch (markSet.Code) { case Yw.Hydro.ParterCatalog.Waterbox: { if (_hydroInfo.Waterboxs != null && _hydroInfo.Waterboxs.Count > 0) { switch ((eWaterboxMarkType)markSet.MarkType) { case eWaterboxMarkType.None: { } break; case eWaterboxMarkType.PoolElev: { _hydroInfo.Waterboxs.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"池底标高:{Math.Round(t.PoolElev, 4)}m" }); }); } break; case eWaterboxMarkType.InitLevel: { _hydroInfo.Waterboxs.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"初始水位:{Math.Round(t.InitLevel, 4)}m" }); }); } break; case eWaterboxMarkType.MinLevel: { _hydroInfo.Waterboxs.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"最小水位:{Math.Round(t.MinLevel, 4)}m" }); }); } break; case eWaterboxMarkType.MaxLevel: { _hydroInfo.Waterboxs.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"最高水位:{Math.Round(t.MaxLevel, 4)}m" }); }); } break; case eWaterboxMarkType.DN: { _hydroInfo.Waterboxs.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"直径:{Math.Round(t.DN, 4)}m" }); }); } break; case eWaterboxMarkType.MinVol: { _hydroInfo.Waterboxs.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"最小容积:{Math.Round(t.MinVol, 1)}m" }); }); } break; default: break; } } } break; case Yw.Hydro.ParterCatalog.Pump: { if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0) { switch ((ePumpMarkType)markSet.MarkType) { case ePumpMarkType.None: { } break; case ePumpMarkType.PumpStatus: { _hydroInfo.Pumps.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"开机状态:{Yw.WinFrmUI.HydroLinkStatusHelper.GetStatusName(t.LinkStatus)}" }); }); } break; case ePumpMarkType.RatedP: { _hydroInfo.Pumps.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"额定功率:{t.RatedP}kW" }); }); } break; case ePumpMarkType.RatedQ: { _hydroInfo.Pumps.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"额定流量:{t.RatedQ}m³/h" }); }); } break; case ePumpMarkType.RatedH: { _hydroInfo.Pumps.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"额定扬程:{t.RatedH}m" }); }); } break; case ePumpMarkType.RatedN: { _hydroInfo.Pumps.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"额定转速:{t.RatedN}r/min" }); }); } break; case ePumpMarkType.RatedHz: { _hydroInfo.Pumps.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"额定频率:{t.RatedHz}" }); }); } break; case ePumpMarkType.CurrentN: { _hydroInfo.Pumps.ForEach(t => { if (t.RatedN.HasValue) { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"设定转速:{Math.Round(t.RatedN.Value * t.SpeedRatio, 1)}r/min" }); } }); } break; case ePumpMarkType.CurrentHz: { _hydroInfo.Pumps.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"设定频率:{Math.Round(t.RatedHz * t.SpeedRatio, 1)}hz" }); }); } break; default: break; } } } break; case Yw.Hydro.ParterCatalog.Valve: { if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0) { switch ((eValveMarkType)markSet.MarkType) { case eValveMarkType.None: { } break; case eValveMarkType.ValveStatus: { _hydroInfo.Valves.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"阀门状态:{HydroLinkStatusHelper.GetStatusName(t.LinkStatus)}" }); }); } break; case eValveMarkType.ValveType: { _hydroInfo.Valves.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"阀门类型:{HydroValveTypeHelper.GetTypeName(t.ValveType)}" }); }); } break; case eValveMarkType.Diameter: { _hydroInfo.Valves.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"直径:{t.Diameter}mm" }); }); } break; case eValveMarkType.MinorLoss: { _hydroInfo.Valves.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"局阻系数:{t.MinorLoss}" }); }); } break; default: break; } } } break; case Yw.Hydro.ParterCatalog.Pipe: { if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0) { switch ((ePipeMarkType)markSet.MarkType) { case ePipeMarkType.None: { } break; case ePipeMarkType.PipeStatus: { _hydroInfo.Pipes.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"状态:{Yw.WinFrmUI.HydroLinkStatusHelper.GetStatusName(t.LinkStatus)}" }); }); } break; case ePipeMarkType.Diameter: { _hydroInfo.Pipes.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"直径:{t.Diameter}mm" }); }); } break; case ePipeMarkType.Length: { _hydroInfo.Pipes.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"长度:{t.Length}m" }); }); } break; case ePipeMarkType.Roughness: { _hydroInfo.Pipes.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"粗糙系数:{t.Roughness}" }); }); } break; case ePipeMarkType.MinorLoss: { _hydroInfo.Pipes.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"局阻系数:{t.MinorLoss}" }); }); } break; default: break; } } } break; case Yw.Hydro.ParterCatalog.Nozzle: { if (_hydroInfo.Nozzles != null && _hydroInfo.Nozzles.Count > 0) { switch ((eNozzleMarkType)markSet.MarkType) { case eNozzleMarkType.None: { } break; case eNozzleMarkType.Elev: { _hydroInfo.Nozzles.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"标高:{Math.Round(t.Elev, 4)}m" }); }); } break; case eNozzleMarkType.Demand: { _hydroInfo.Nozzles.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"需水量:{t.Demand}m³/h" }); }); } break; case eNozzleMarkType.Coefficient: { _hydroInfo.Nozzles.ForEach(t => { _allMarkResultList.Add(new HydroMarkResultViewModel() { Code = t.Code, Text = $"喷射系数:{t.Coefficient}" }); }); } break; default: break; } } } break; default: break; } } return _allMarkResultList; } //应用标注结果列表 private async Task ApplyMarkResultList() { var allMarkResultList = GetMarkResultList(); var leadLabels = allMarkResultList?.Select(x => new LogicMarkLeadLabel(x.Code, x.Text, 100000)).ToList(); await _bimfaceCtrl?.SetLogicMarkLeadLabels(leadLabels); TipFormHelper.ShowSucceed("标注信息已设置"); } //清除标注结果列表 private async Task ClearMarkResultList() { if (_allMarkResultList == null || _allMarkResultList.Count < 1) { TipFormHelper.ShowWarn("尚未设置标注信息"); return; } _allMarkResultList = null; await _bimfaceCtrl?.ClearLogicMarkLeadLabels(); TipFormHelper.ShowSucceed("标注信息已清除"); } //显示标注设置窗体 private void ShowMarkSetDlg() { if (_hydroInfo == null) { return; } var allMarkSetList = GetMarkSetList(); var dlg = new SetHydroMarkDlg(); dlg.SetBindingData(allMarkSetList); dlg.ReloadDataEvent += async (list) => { _allMarkSetList = list; await ApplyMarkResultList(); }; dlg.ShowDialog(); } //设置标注 private void barBtnSetMark_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowMarkSetDlg(); } //清除标注 private async void barBtnClearMark_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { await ClearMarkResultList(); } #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 += () => { ShowApplyGradingDlg(); }; 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.GetCatalogName(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.GetCatalogName(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.GetCatalogName(Yw.Hydro.ParterCatalog.Pipe), PropName = Yw.Hydro.ParterProp.CalcuFlow }); } } return _allGradingApplyList; } //颜色分级应用结果列表 private List _allGradingApplyResultList = null; //获取颜色分级应用结果列表 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(); _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 Yw.Hydro.ParterProp.CalcuFlow: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuVelocity: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuHeadLoss: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuFlow: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuVelocity: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuHeadLoss: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuFlow: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuVelocity: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 Yw.Hydro.ParterProp.CalcuHeadLoss: { var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.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 List _allGradingCodeList = null; //应用颜色分级 private async void ApplyGrading() { if (_hydroInfo == null) { return; } var allGradingApplyResultList = await GetGradingApplyResultList(); _allGradingCodeList = allGradingApplyResultList?.Select(x => x.Code).Distinct().ToList(); 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); }); } //显示应用颜色分级窗体 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 += async (obj) => { _allGradingApplyList = obj; ApplyGrading(); }; dlg.ShowDialog(); } //应用颜色分级 private void barBtnGradingApply_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { ShowApplyGradingDlg(); } #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); _selectedParter = null; await _bimfaceCtrl?.ZoomAndSelectComponents(null); ShowProperty(); TipFormHelper.ShowSucceed("数据已刷新"); } } #endregion #region 水流动画 //加载流向 private async void barBtnLoadFlowDirection_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { var pipes = _hydroInfo.Pipes; var list = pipes.Select(x => { return new Yw.WinFrmUI.Bimface.LogicFlowEffect() { Id = x.Code, Rotation = 90, Speed = 0.1d }; }).ToList(); await _bimfaceCtrl?.LoadFlowEffect(list); } //卸载流向 private async void barBtnUnloadFlowDirection_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { await _bimfaceCtrl?.UnloadFlowEffect(); } #endregion } }