global using Yw.EPAnet; using NetTaste; 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; } 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 async void InitialDataSource() { base.InitialDataSource(); if (_project == null) { return; } this.PageTitle.Caption = $"{_project.Name}\r\n水力模拟"; await this.xhsProjectSimulationBimfaceCtrl1.SetBindingData(_project, _projectSite, () => _hydroInfo); this.xhsProjectSimulationQ3dCtrl1.SetBindingData(_hydroInfo); this.xhsProjectSimulationPropertyCtrl1.InitialData(() => _hydroInfo); } #region Bimface //bimface 加载完成事件 private async void xhsProjectSimulationBimfaceCtrl1_LoadCompletedEvent() { if (_hydroInfo == null) { return; } var elementIds = new List(); var pumps = _hydroInfo.Pumps?.Where(x => x.LinkStatus == Yw.Hydro.PumpStatus.Open).ToList(); pumps?.ForEach(x => elementIds.Add(x.Code)); var valves = _hydroInfo.Valves?.Where(x => x.LinkStatus == Yw.Hydro.ValveStatus.Open).ToList(); valves?.ForEach(x => elementIds.Add(x.Code)); await this.xhsProjectSimulationBimfaceCtrl1.SetOpenComponentsColor(elementIds); } //bimface 水力点击事件 private void xhsProjectSimulationBimfaceCtrl1_HydroClickEvent(Yw.Model.HydroParterInfo obj) { if (_hydroInfo == null) { return; } _parter = obj; ShowProperty(); SetBimfaceLinkColor(); } //设置Bimface连接颜色 private async void SetBimfaceLinkColor() { if (_hydroInfo == null) { return; } var elementIds = new List(); if (_parter != null) { if (_parter is Yw.Model.HydroLinkInfo linker) { var allParterList = _hydroInfo.GetAllParters(); var allLinkerList = _hydroInfo.GetAllLinks(); var startParter = allParterList?.Find(x => x.Code == linker.StartCode); if (startParter != null) { if (startParter.GetType() == typeof(Yw.Model.HydroJunctionInfo)) { var startLinkList = allLinkerList?.Where(x => x.StartCode == startParter.Code || x.EndCode == startParter.Code).ToList(); if (startLinkList != null) { elementIds.AddRange(startLinkList.Select(x => x.Code).Where(x => x != _parter.Code)); } } else { elementIds.Add(linker.StartCode); } } var endParter = allParterList?.Find(x => x.Code == linker.EndCode); if (endParter != null) { if (endParter.GetType() == typeof(Yw.Model.HydroJunctionInfo)) { var endLinkList = allLinkerList?.Where(x => x.StartCode == endParter.Code || x.EndCode == endParter.Code).ToList(); if (endLinkList != null) { elementIds.AddRange(endLinkList.Select(x => x.Code).Where(x => x != _parter.Code)); } } else { elementIds.Add(linker.EndCode); } } } } await this.xhsProjectSimulationBimfaceCtrl1.SetLinkComponentsColor(elementIds); } #endregion #region Q3d //点击事件 private void xhsProjectSimulationQ3dCtrl1_ClickParterEvent(string code) { if (_hydroInfo == null) { return; } var allParterList = _hydroInfo.GetAllParters(); _parter = allParterList?.Find(x => x.Code == code); ShowProperty(); } #endregion #region 属性面板 #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 this.xhsProjectSimulationBimfaceCtrl1.ZoomAndSelectComponents(elementIds); ShowProperty(); SetBimfaceLinkColor(); }; _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); 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 this.xhsProjectSimulationBimfaceCtrl1.ZoomAndSelectComponents(elementIds); ShowProperty(); SetBimfaceLinkColor(); }; _unMatchingListCtrl.ViewModelEvent += async (parters) =>//查看模型 { var codes = parters?.Select(x => x.Code).Distinct().ToList(); await this.xhsProjectSimulationBimfaceCtrl1.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 List _fastShowHideCodeList = null; //触发一键显隐 private async void barBtnShowHide_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } if (_hydroInfo.Decorators == null || _hydroInfo.Decorators.Count < 1) { return; } if (_fastShowHideCodeList == null) { _fastShowHideCodeList = _hydroInfo.Decorators.Select(x => x.Code).ToList(); await this.xhsProjectSimulationBimfaceCtrl1.HideComponents(_fastShowHideCodeList); } else { await this.xhsProjectSimulationBimfaceCtrl1.ShowComponents(_fastShowHideCodeList); _fastShowHideCodeList = null; } } #endregion #region 水力校验 //获取校验结果控件 private XhsProjectSimulationHydroCheckResultCtrl GetCheckResultCtrl() { if (_checkResultCtrl == null) { _checkResultCtrl = new XhsProjectSimulationHydroCheckResultCtrl(); _checkResultCtrl.Dock = DockStyle.Fill; _checkResultCtrl.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 this.xhsProjectSimulationBimfaceCtrl1.ZoomAndSelectComponents(elementIds); ShowProperty(); SetBimfaceLinkColor(); }; } return _checkResultCtrl; } //校验结果控件 private XhsProjectSimulationHydroCheckResultCtrl _checkResultCtrl = null; //水力验证 private void barBtnHydroCheck_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } _checkResult = _hydroInfo.Check(); this.controlContainerBottom.Controls.Clear(); var checkResultCtrl = GetCheckResultCtrl(); checkResultCtrl.SetBindingData(_checkResult); this.controlContainerBottom.Controls.Add(checkResultCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "校验结果"; this.docPnlBottom.Height = 350; } #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 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 this.xhsProjectSimulationBimfaceCtrl1.ZoomAndSelectComponents(new List() { _parter.Code }); ShowProperty(); SetBimfaceLinkColor(); }; } return _parterListCtrl; } //构件明细控件 private Yw.WinFrmUI.HydroParterListCtrl _parterListCtrl = null; //水力构件列表 private void barBtnHydroParterList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } this.controlContainerBottom.Controls.Clear(); var parterListCtrl = GetParterListCtrl(); parterListCtrl.SetBindingData(_hydroInfo); this.controlContainerBottom.Controls.Add(parterListCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "构件明细"; this.docPnlBottom.Height = 350; } #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 #region 业务方法 //显示属性 private void ShowProperty() { if (_hydroInfo == null) { return; } if (_parter == null) { this.xhsProjectSimulationPropertyCtrl1.SelectParter(null); return; } this.xhsProjectSimulationPropertyCtrl1.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) { this.xhsProjectSimulationPropertyCtrl1.UpdateCalcuProperty(calcuProperty); } } } } } #endregion #region 配置 //显示RadialMenu private void barBtnSetList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { this.rmSet.ShowPopup(MousePosition, true); } #endregion #region 性能曲线 //性能曲线 private void barBtnFeatCurve_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } if (_calcuResult == null) { return; } if (!_calcuResult.Succeed) { return; } var pumps = _hydroInfo.Pumps; var vmList = new List(); foreach (var x in pumps) { var vm = new Yw.WinFrmUI.Phart.PumpSerialParallelViewModel(); vm.Id = x.Code; vm.Name = x.Code; //vm.IsBp = ; //vm.RatedSpeed = 590; //vm.CurrentSpeed = 590; //vm.CurrentHz = 50; var PointsQH = _hydroInfo.Curves?.Find(t => t.Code == x.CurveQH)?.CurveData?.Select(z => new Yw.Geometry.Point2d() { X = z.X, Y = z.Y }).ToList(); var PointsQP = _hydroInfo.Curves?.Find(t => t.Code == x.CurveQP)?.CurveData?.Select(z => new Yw.Geometry.Point2d { X = z.X, Y = z.Y }).ToList(); var PointsQE = _hydroInfo.Curves?.Find(t => t.Code == x.CurveQE)?.CurveData?.Select(z => new Yw.Geometry.Point2d { X = z.X, Y = z.Y }).ToList(); vm.Qh = new Yw.Geometry.CubicSpline2d(PointsQH); vm.Qe = new Yw.Geometry.CubicSpline2d(PointsQE); vm.Qp = new Yw.Geometry.CubicSpline2d(PointsQP); vmList.Add(vm); } var dlg = new HStation.WinFrmUI.PhartRelation.PumpSerialParallelChartDlg(); dlg.SetBindingData(vmList, null, true); dlg.ShowDialog(); } #endregion #region 水力计算 //获取计算控件 private XhsProjectSimulationCalcuCtrl GetCalcuCtrl() { if (_calcuCtrl == null) { _calcuCtrl = new XhsProjectSimulationCalcuCtrl(); _calcuCtrl.Dock = DockStyle.Fill; _calcuCtrl.CancelEvent += () => { this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Hidden; }; _calcuCtrl.OkEvent += async () => { if (_hydroInfo == null) { return; } _checkResult = _hydroInfo.Check(); if (!_checkResult.Succeed) { this.controlContainerBottom.Controls.Clear(); var checkResultCtrl = GetCheckResultCtrl(); checkResultCtrl.SetBindingData(_checkResult); this.controlContainerBottom.Controls.Add(checkResultCtrl); TipFormHelper.ShowWarn("校验失败,请检查后重试"); return; } var netWork = Yw.Hydro.ParseHelper.ToNetwork(_hydroInfo); _calcuResult = netWork.Calcu(); if (_calcuResult.Succeed) { this.controlContainerBottom.Controls.Clear(); var parterListCtrl = GetParterListCtrl(); var calcuResultList = new List(); _calcuResult.NodeList?.ForEach(x => { calcuResultList.Add(new HydroCalcuNodeResult() { Code = x.Id, CalcuPress = x.Press, CalcuHead = x.Head, CalcuDemand = x.Demand, }); }); _calcuResult.LinkList?.ForEach(x => { calcuResultList.Add(new HydroCalcuLinkResult() { Code = x.Id, CalcuFlow = x.Flow, CalcuVelocity = x.Velocity, CalcuHeadLoss = x.Headloss }); }); parterListCtrl.SetBindingData(_hydroInfo, calcuResultList); parterListCtrl.SetCalcuView(); this.controlContainerBottom.Controls.Add(parterListCtrl); this.docPnlBottom.Text = "计算结果"; ShowProperty(); await this.xhsProjectSimulationBimfaceCtrl1.ShowCalcuCustomLabels(_calcuResult); TipFormHelper.ShowSucceed("计算成功!"); } else { _calcuCtrl.SetBindingData(_calcuResult.FailedList); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "计算失败原因"; this.docPnlBottom.Height = 350; TipFormHelper.ShowError("计算失败"); } }; } return _calcuCtrl; } private XhsProjectSimulationCalcuCtrl _calcuCtrl = null;//计算控件 //水力计算 private void barBtnHydroCalcu_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } this.controlContainerBottom.Controls.Clear(); var calcuCtrl = GetCalcuCtrl(); calcuCtrl.SetBindingData(_hydroInfo); this.controlContainerBottom.Controls.Add(calcuCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "计算前提条件"; this.docPnlBottom.Height = 350; } #endregion #region 构件查询 //获取查询组件 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 this.xhsProjectSimulationBimfaceCtrl1.ZoomAndSelectComponents(elementIds); ShowProperty(); SetBimfaceLinkColor(); }; } return _searchCtrl; } private XhsProjectSimulationSearchCtrl _searchCtrl = null;//查询组件 //查询 private void barBtnSearch_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { if (_hydroInfo == null) { return; } this.controlContainerBottom.Controls.Clear(); var searchCtrl = GetSearchCtrl(); this.controlContainerBottom.Controls.Add(searchCtrl); this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible; this.docPnlBottom.Text = "模型构件查询"; this.docPnlBottom.Height = 350; } #endregion } }