using DevExpress.XtraEditors; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using Yw.Geometry; using Yw.Pump; using Yw.WinFrmUI.Phart; namespace HStation.WinFrmUI { public partial class SimulationSingleWorkingPumpAnalyCtrl : DevExpress.XtraEditors.XtraUserControl { public SimulationSingleWorkingPumpAnalyCtrl() { InitializeComponent(); this.layoutControl1.SetupLayoutControl(); this.hydroPumpListStateViewCtrl1.SelectedChangedEvent += HydroPumpListStateViewCtrl1_SelectedChangedEvent; } private Yw.Model.HydroModelInfo _hydroInfo = null;//水力信息 private Dictionary _allCalcuResultVisualDict = null;//所有计算结果可见字典 /// /// 绑定数据 /// public void SetBindingData(Yw.Model.HydroModelInfo hydroInfo, HydroCalcuResult calcuResult) { var allCalcuResultVisualDict = calcuResult?.GetVisualDict(); SetBindingData(hydroInfo, allCalcuResultVisualDict); } /// /// 绑定数据 /// public void SetBindingData(Yw.Model.HydroModelInfo hydroInfo, Dictionary allCalcuResultVisualDict) { _hydroInfo = hydroInfo; _allCalcuResultVisualDict = allCalcuResultVisualDict; this.hydroPumpListStateViewCtrl1.SetBindingData(hydroInfo); } //选择改变 private void HydroPumpListStateViewCtrl1_SelectedChangedEvent(Yw.Model.HydroPumpInfo pump) { if (pump == null) { return; } 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; 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(); var vmItem = new PumpRunViewItemViewModel(); vm.Items.Add(vmItem); vmItem.Id = string.Empty; vmItem.Name = "运行"; vmItem.Hz = Math.Round(pump.RatedHz * pump.SpeedRatio, 1); 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; } } }