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.Vmo; using Yw.WinFrmUI.Phart; namespace HStation.WinFrmUI { public partial class SimulationPumpAnalyChartCtrl : DevExpress.XtraEditors.XtraUserControl { public SimulationPumpAnalyChartCtrl() { InitializeComponent(); } private Yw.Model.HydroModelInfo _hydroInfo = null;//水力信息 private Yw.Model.HydroPumpInfo _pumpInfo = null;//水泵信息 private Dictionary _allCalcuResultVisualDict = null;//计算结果可见字典 private List _allWorkingList = null;//所有工况列表 private Dictionary> _allWorkingCalcuResultDict = null;//所有工况计算结果字典 /// /// 绑定数据 /// public void SetBindingData ( Yw.Model.HydroModelInfo hydroInfo, Yw.Model.HydroPumpInfo pumpInfo, HydroCalcuResult calcuResult ) { var allCalcuResultVisualDict = calcuResult?.GetVisualDict(); SetBindingData(hydroInfo, pumpInfo, allCalcuResultVisualDict); } /// /// 绑定数据 /// public void SetBindingData ( Yw.Model.HydroModelInfo hydroInfo, Yw.Model.HydroPumpInfo pumpInfo, Dictionary allCalcuResultVisualDict ) { _hydroInfo = hydroInfo; _pumpInfo = pumpInfo; _allCalcuResultVisualDict = allCalcuResultVisualDict; var vm = CreateViewModel(); SetBindingData(vm); } /// /// 绑定数据 /// public void SetBindingData ( Yw.Model.HydroModelInfo hydroInfo, Yw.Model.HydroPumpInfo pumpInfo, List allWorkingList ) { _hydroInfo = hydroInfo; _pumpInfo = pumpInfo; _allWorkingList = allWorkingList; var vm = CreateWorkingViewModel(); SetBindingData(vm); } /// /// 绑定数据 /// public void SetBindingData(PumpRunViewViewModel vm) { this.pumpRunViewChart1.SetBindingData(vm); this.barCheckE.Checked = this.pumpRunViewChart1.QEVisible; this.barCheckP.Checked = this.pumpRunViewChart1.QPVisble; if (vm != null && vm.Items != null) { var item = vm.Items.FirstOrDefault(); SetCurrent(item); } } //设置当前 private void SetCurrent(PumpRunViewItemViewModel item) { if (item != null) { this.barTxtQ.EditValue = $"{Math.Round(item.Q, 1)}m³/h"; this.barTxtH.EditValue = $"{Math.Round(item.H, 2)}m"; this.barTxtP.EditValue = $"{Math.Round(item.P ?? 0, 1)}kW"; this.barTxtE.EditValue = $"{Math.Round(item.E ?? 0, 1)}%"; } } //创建视图 private PumpRunViewViewModel CreateViewModel() { if (_hydroInfo == null) { return default; } if (_pumpInfo == null) { return default; } var vm = new PumpRunViewViewModel(); vm.Id = _pumpInfo.Code; vm.Name = _pumpInfo.Name; vm.CurveName = $"额定曲线({_pumpInfo.RatedHz}hz)"; vm.RatedQ = _pumpInfo.RatedQ ?? 0; vm.RatedH = _pumpInfo.RatedH ?? 0; vm.RatedP = _pumpInfo.RatedP; vm.RatedN = _pumpInfo.RatedN ?? 0; vm.RatedHz = _pumpInfo.RatedHz; vm.Color = Color.Black; var curveqh = _hydroInfo.Curves?.Find(x => x.Code == _pumpInfo.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 == _pumpInfo.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 == _pumpInfo.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 (_pumpInfo.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(_pumpInfo.RatedHz * _pumpInfo.SpeedRatio, 1); vmItem.Color = Color.Blue; if (_pumpInfo.RatedN.HasValue) { vmItem.N = Math.Round(_pumpInfo.RatedN.Value * _pumpInfo.SpeedRatio, 1); } var calcuResult = _allCalcuResultVisualDict?.GetValue(_pumpInfo.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; } //创建工况视图 private PumpRunViewViewModel CreateWorkingViewModel() { if (_hydroInfo == null) { return default; } if (_pumpInfo == null) { return default; } var vm = new PumpRunViewViewModel(); vm.Id = _pumpInfo.Code; vm.Name = _pumpInfo.Name; vm.CurveName = $"额定曲线({_pumpInfo.RatedHz}hz)"; vm.RatedQ = _pumpInfo.RatedQ ?? 0; vm.RatedH = _pumpInfo.RatedH ?? 0; vm.RatedP = _pumpInfo.RatedP; vm.RatedN = _pumpInfo.RatedN ?? 0; vm.RatedHz = _pumpInfo.RatedHz; vm.Color = Color.Black; var curveqh = _hydroInfo.Curves?.Find(x => x.Code == _pumpInfo.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 == _pumpInfo.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 == _pumpInfo.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 (_allWorkingList != null && _allWorkingList.Count > 0) { vm.Items = new List(); foreach (var working in _allWorkingList) { var workingInfo = JsonHelper.Json2Object(working.WorkingInfo); if (workingInfo != null && workingInfo.Pumps != null && workingInfo.Pumps.Count > 0) { var workingPumpInfo = workingInfo.Pumps.Find(x => x.Code == _pumpInfo.Code); if (workingPumpInfo != null) { var vmItem = new PumpRunViewItemViewModel(); vm.Items.Add(vmItem); vmItem.Id = working.ID.ToString(); vmItem.Name = working.Name; vmItem.Hz = workingPumpInfo.CurrentHz; vmItem.Color = HydroPumpCurveColorHelper.GetRandomColor(_allWorkingList.IndexOf(working)); if (_pumpInfo.RatedN.HasValue) { var speedRatio = workingPumpInfo.CurrentHz / _pumpInfo.RatedHz; vmItem.N = Math.Round(_pumpInfo.RatedN.Value * speedRatio, 1); } vmItem.CurveName = $"{working.Name}({vmItem.Hz}hz)"; if (_allWorkingCalcuResultDict == null) { _allWorkingCalcuResultDict = new Dictionary>(); } if (!_allWorkingCalcuResultDict.ContainsKey(working)) { _hydroInfo.UpdateWorkingInfo(workingInfo); var calcuResult = _hydroInfo.Calcu(Yw.EPAnet.CalcuMode.MinorLoss); _allWorkingCalcuResultDict.Add(working, calcuResult?.GetVisualDict()); } var calcuResultVisualDict = _allWorkingCalcuResultDict[working]; var calcuPumpResult = calcuResultVisualDict?.GetValue(_pumpInfo.Code) as HydroCalcuPumpResult; if (calcuPumpResult != null) { vmItem.Q = calcuPumpResult.CalcuQ ?? 0; vmItem.H = calcuPumpResult.CalcuH ?? 0; vmItem.P = calcuPumpResult.CalcuP; vmItem.E = calcuPumpResult.CalcuE; } 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; } //效率线 private void barCheckE_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { this.pumpRunViewChart1.QEVisible = this.barCheckE.Checked; } //功率线 private void barCheckP_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { this.pumpRunViewChart1.QPVisble = this.barCheckP.Checked; } //设置坐标轴 private void barBtnCoord_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { this.pumpRunViewChart1.SetChartAxis(); } } }