| | |
| | | using Yw.EPAnet; |
| | | using Yw.Geometry; |
| | | using Yw.Pump; |
| | | using Yw.Vmo; |
| | | using Yw.WinFrmUI.Phart; |
| | | |
| | | namespace HStation.WinFrmUI |
| | |
| | | { |
| | | InitializeComponent(); |
| | | this.layoutControl1.SetupLayoutControl(); |
| | | this.hydroPumpListStateViewCtrl1.SelectedChangedEvent += HydroPumpRunStatusListCtrl1_SelectedChangedEvent; |
| | | } |
| | | |
| | | private HydroWorkingVmo _working = null;//工况 |
| | | private Yw.Model.HydroModelInfo _hydroInfo = null;//水力信息 |
| | | private Dictionary<string, HydroCalcuVisualResult> _allCalcuResultVisualDict = null;//所有计算结果可见字典 |
| | | |
| | | /// <summary> |
| | | /// 绑定数据 |
| | | /// </summary> |
| | | public void SetBindingData(Yw.Model.HydroModelInfo hydroInfo, HydroCalcuResult calcuResult) |
| | | public void SetBindingData(HydroWorkingVmo working, Yw.Model.HydroModelInfo hydroInfo, HydroCalcuResult calcuResult) |
| | | { |
| | | if (hydroInfo == null) |
| | | { |
| | | return; |
| | | } |
| | | if (calcuResult == null) |
| | | { |
| | | return; |
| | | } |
| | | if (!calcuResult.Succeed) |
| | | { |
| | | return; |
| | | } |
| | | var allCalcuResultVisualDict = calcuResult.GetVisualDict(); |
| | | SetBindingData(hydroInfo, allCalcuResultVisualDict); |
| | | var allCalcuResultVisualDict = calcuResult?.GetVisualDict(); |
| | | SetBindingData(working, hydroInfo, allCalcuResultVisualDict); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 绑定数据 |
| | | /// </summary> |
| | | public void SetBindingData(Yw.Model.HydroModelInfo hydroInfo, Dictionary<string, HydroCalcuVisualResult> allCalcuResultVisualDict) |
| | | public void SetBindingData(HydroWorkingVmo working, Yw.Model.HydroModelInfo hydroInfo, Dictionary<string, HydroCalcuVisualResult> allCalcuResultVisualDict) |
| | | { |
| | | if (working == null) |
| | | { |
| | | return; |
| | | } |
| | | if (hydroInfo == null) |
| | | { |
| | | return; |
| | |
| | | { |
| | | return; |
| | | } |
| | | _working = working; |
| | | _hydroInfo = hydroInfo; |
| | | _allCalcuResultVisualDict = allCalcuResultVisualDict; |
| | | this.hydroEnergyTotalViewCtrl1.SetBindingData(hydroInfo, allCalcuResultVisualDict); |
| | | this.hydroPumpListStateViewCtrl1.SetBindingData(hydroInfo); |
| | | this.hydroEnergyTotalHorizViewCtrl1.SetBindingData(_hydroInfo, _allCalcuResultVisualDict); |
| | | this.simulationSingleWorkingPumpCtrl1.SetBindingData(_working, _hydroInfo, _allCalcuResultVisualDict); |
| | | } |
| | | |
| | | //泵选择改变 |
| | | private void HydroPumpRunStatusListCtrl1_SelectedChangedEvent(Yw.Model.HydroPumpInfo pump) |
| | | { |
| | | if (_hydroInfo == null) |
| | | { |
| | | return; |
| | | } |
| | | if (_allCalcuResultVisualDict == null || _allCalcuResultVisualDict.Count < 1) |
| | | { |
| | | return; |
| | | } |
| | | if (pump == null) |
| | | { |
| | | return; |
| | | } |
| | | this.groupForSinglePumpInfo.Text = pump.Name; |
| | | this.txtQ.EditValue = null; |
| | | this.txtH.EditValue = null; |
| | | this.txtP.EditValue = null; |
| | | this.txtE.EditValue = null; |
| | | if (_allCalcuResultVisualDict.ContainsKey(pump.Code)) |
| | | { |
| | | var calcuResult = _allCalcuResultVisualDict[pump.Code] as HydroCalcuPumpResult; |
| | | if (calcuResult != null) |
| | | { |
| | | if (pump.LinkStatus == Yw.Hydro.PumpStatus.Open) |
| | | { |
| | | this.txtQ.EditValue = calcuResult.CalcuQ.HasValue ? $"{Math.Round(calcuResult.CalcuQ.Value, 1)}m³/h" : null; |
| | | this.txtH.EditValue = calcuResult.CalcuH.HasValue ? $"{Math.Round(calcuResult.CalcuH.Value, 2)}m" : null; |
| | | this.txtP.EditValue = calcuResult.CalcuP.HasValue ? $"{Math.Round(calcuResult.CalcuP.Value, 1)}kW" : null; |
| | | this.txtE.EditValue = calcuResult.CalcuE.HasValue ? $"{Math.Round(calcuResult.CalcuE.Value, 1)}%" : null; |
| | | } |
| | | var vm = CreateViewModel(pump); |
| | | this.pumpRunViewChart1.SetBindingData(vm); |
| | | } |
| | | } |
| | | |
| | | |
| | | } |
| | | |
| | | //创建 |
| | | private PumpRunViewViewModel CreateViewModel(Yw.Model.HydroPumpInfo pump) |
| | | { |
| | | if (_hydroInfo == null) |
| | | { |
| | | return default; |
| | | } |
| | | var vm = new PumpRunViewViewModel(); |
| | | vm.Id = pump.Code; |
| | | vm.Name = pump.Name; |
| | | vm.CurveName = $"额定曲线({pump.RatedHz}hz)"; |
| | | vm.RatedQ = pump.RatedQ.HasValue ? pump.RatedQ.Value : 0; |
| | | vm.RatedH = pump.RatedH.HasValue ? pump.RatedH.Value : 0; |
| | | vm.RatedP = pump.RatedP; |
| | | vm.RatedN = pump.RatedN.HasValue ? pump.RatedN.Value : 0; |
| | | vm.RatedHz = pump.RatedHz; |
| | | vm.Color = Color.LightGray; |
| | | |
| | | var curveqh = _hydroInfo.Curves?.Find(x => x.Code == pump.CurveQH); |
| | | if (curveqh != null) |
| | | { |
| | | var qh_pts = curveqh.CurveData?.Select(x => new Yw.Geometry.Point2d(x.X, x.Y)).ToList(); |
| | | if (qh_pts != null && qh_pts.Count > 3) |
| | | { |
| | | vm.CurveQH = new CubicSpline2d(qh_pts); |
| | | } |
| | | } |
| | | |
| | | var curveqp = _hydroInfo.Curves?.Find(x => x.Code == pump.CurveQP); |
| | | if (curveqp != null) |
| | | { |
| | | var qp_pts = curveqp.CurveData?.Select(x => new Yw.Geometry.Point2d(x.X, x.Y)).ToList(); |
| | | if (qp_pts != null && qp_pts.Count > 3) |
| | | { |
| | | vm.CurveQP = new CubicSpline2d(qp_pts); |
| | | } |
| | | } |
| | | |
| | | var curveqe = _hydroInfo.Curves?.Find(x => x.Code == pump.CurveQE); |
| | | if (curveqe != null) |
| | | { |
| | | var qepts = curveqe.CurveData?.Select(x => new Yw.Geometry.Point2d(x.X, x.Y)).ToList(); |
| | | if (qepts != null && qepts.Count > 3) |
| | | { |
| | | vm.CurveQE = new CubicSpline2d(qepts); |
| | | } |
| | | } |
| | | |
| | | if (pump.LinkStatus == Yw.Hydro.PumpStatus.Open) |
| | | { |
| | | vm.Items = new List<PumpRunViewItemViewModel>(); |
| | | var vmItem = new PumpRunViewItemViewModel(); |
| | | vm.Items.Add(vmItem); |
| | | vmItem.Id = string.Empty; |
| | | vmItem.Name = "运行"; |
| | | vmItem.Hz = Math.Round(pump.RatedHz * pump.SpeedRatio, 1); |
| | | vmItem.Color = Color.Green; |
| | | if (pump.RatedN.HasValue) |
| | | { |
| | | vmItem.N = Math.Round(pump.RatedN.Value * pump.SpeedRatio, 1); |
| | | } |
| | | var calcuResult = _allCalcuResultVisualDict?.GetValue(pump.Code) as HydroCalcuPumpResult; |
| | | if (calcuResult != null) |
| | | { |
| | | vmItem.Q = calcuResult.CalcuQ ?? 0; |
| | | vmItem.H = calcuResult.CalcuH ?? 0; |
| | | vmItem.P = calcuResult.CalcuP; |
| | | vmItem.E = calcuResult.CalcuE; |
| | | } |
| | | vmItem.CurveName = $"运行曲线({vmItem.Hz}hz)"; |
| | | |
| | | if (vm.CurveQH != null) |
| | | { |
| | | var qh_pts = vm.CurveQH.GetPointList(20); |
| | | var qh_run_pts = qh_pts.GetQHPointListByN(vm.RatedHz, vmItem.Hz); |
| | | vmItem.CurveQH = new CubicSpline2d(qh_run_pts); |
| | | } |
| | | |
| | | if (vm.CurveQP != null) |
| | | { |
| | | var qp_pts = vm.CurveQP.GetPointList(20); |
| | | var qp_run_pts = qp_pts.GetQPPointListByN(vm.RatedHz, vmItem.Hz); |
| | | vmItem.CurveQP = new CubicSpline2d(qp_run_pts); |
| | | } |
| | | |
| | | if (vm.CurveQE != null) |
| | | { |
| | | var qe_pts = vm.CurveQE.GetPointList(20); |
| | | var qe_run_pts = qe_pts.GetQEPointListByN(vm.RatedHz, vmItem.Hz); |
| | | vmItem.CurveQE = new CubicSpline2d(qe_run_pts); |
| | | } |
| | | |
| | | } |
| | | |
| | | return vm; |
| | | } |
| | | |
| | | } |
| | | } |