using DevExpress.Utils;
|
using DevExpress.XtraCharts;
|
using System.Text;
|
|
namespace Yw.WinFrmUI.Phart
|
{
|
/// <summary>
|
/// bug:隐藏效率线计算剩下两条线的轴,计算轴坐标不合理
|
/// </summary>
|
public partial class PumpPerform2dMultiChart : DevExpress.XtraEditors.XtraUserControl
|
{
|
public PumpPerform2dMultiChart()
|
{
|
InitializeComponent();
|
InitialChart();
|
this.chartControl1.RuntimeHitTesting = true;
|
_vm_list = new List<CurrentViewModel>();
|
}
|
|
#region Private Variable
|
|
private class CurrentViewModel
|
{
|
public string ID { get; set; }
|
public string Name { get; set; }
|
public Yw.Geometry.CubicSpline2d QH { get; set; }
|
public Yw.Geometry.CubicSpline2d QE { get; set; }
|
public Yw.Geometry.CubicSpline2d QP { get; set; }
|
public List<Yw.Geometry.Point2d> QHPoints { get; set; }
|
public List<Yw.Geometry.Point2d> QEPoints { get; set; }
|
public List<Yw.Geometry.Point2d> QPPoints { get; set; }
|
public Color Color { get; set; }
|
}
|
|
private List<CurrentViewModel> _vm_list;
|
private readonly string _tag_qh = "CurveQH", _tag_qe = "CurveQE", _tag_qp = "CurveQP";
|
|
private XYDiagram _main_chart_diagram;
|
private XYDiagramDefaultPane _pane_qh;
|
private XYDiagramPane _pane_qe;
|
private XYDiagramPane _pane_qp;
|
private AxisX _axis_x_q;
|
private AxisY _axis_y_qh;
|
private SecondaryAxisY _axis_y_qe, _axis_y_qp;
|
private ConstantLine _work_pt_line;
|
|
private TextAnnotation _work_pt_txt_annot;
|
|
private PumpCoordinate _coordinate_paras;
|
|
public bool _cubic_spline_qh_visible = true;
|
public bool _cubic_spline_qe_visible = true;
|
public bool _cubic_spline_qp_visible = true;
|
|
|
private bool _initialData = false;
|
|
#endregion
|
|
#region Public Variable
|
|
/// <summary>
|
/// 工作线是否可见
|
/// </summary>
|
public bool LineVisible
|
{
|
get => _line_visible;
|
set
|
{
|
_line_visible = value;
|
this.barCekLineVisible.Checked = _line_visible;
|
}
|
}
|
private bool _line_visible = false;
|
|
/// <summary>
|
/// 曲线名是否可见
|
/// </summary>
|
public bool LineNameVisible
|
{
|
get => _line_name_visible;
|
set
|
{
|
_line_name_visible = value;
|
this.barCekCurveNameVisible.Checked = _line_name_visible;
|
}
|
}
|
private bool _line_name_visible = false;
|
|
#endregion
|
|
#region Public Evnet
|
|
public event Action<PumpCoordinate> OnCurveCoordinateChanged;
|
|
public event Action<string, PumpGroupPt> OnCalcQueryPoint = null;
|
|
#endregion
|
|
#region Initial
|
|
/// <summary>
|
/// 初始化图表
|
/// </summary>
|
private void InitialChart()
|
{
|
this.chartControl1.SetChartDisplay();
|
this.chartControl1.Legend.Direction = DevExpress.XtraCharts.LegendDirection.TopToBottom;
|
|
_main_chart_diagram = (XYDiagram)chartControl1.Diagram;
|
_pane_qh = _main_chart_diagram.DefaultPane;
|
_pane_qe = (XYDiagramPane)_main_chart_diagram.FindPaneByName("PaneQE");
|
_pane_qp = (XYDiagramPane)_main_chart_diagram.FindPaneByName("PaneQP");
|
|
_axis_x_q = _main_chart_diagram.AxisX;
|
_axis_x_q.SetAxisXQDisplay();
|
_axis_y_qh = _main_chart_diagram.AxisY;
|
_axis_y_qh.SetAxisYQHDisplay();
|
_axis_y_qe = _main_chart_diagram.SecondaryAxesY.GetAxisByName("AxisYQE");
|
_axis_y_qe.SetSecondaryAxisYQEDisplay();
|
_axis_y_qe.Alignment = AxisAlignment.Near;
|
_axis_y_qp = _main_chart_diagram.SecondaryAxesY.GetAxisByName("AxisYQP");
|
_axis_y_qp.SetSecondaryAxisYQPDisplay();
|
|
_work_pt_line = (ConstantLine)_main_chart_diagram.AxisX.ConstantLines.GetElementByName("WorkPointLine");
|
_work_pt_line.SetWorkPointLineDisplay();
|
|
_work_pt_txt_annot = this.chartControl1.AnnotationRepository[0] as TextAnnotation;
|
_work_pt_txt_annot.SetTextAnnoWorkPointDisplay();
|
|
_axis_x_q.Visibility = DefaultBoolean.False;
|
_axis_x_q.GridLines.Visible = false;
|
_axis_y_qh.Visibility = DefaultBoolean.False;
|
_axis_y_qh.GridLines.Visible = false;
|
_axis_y_qe.Visibility = DefaultBoolean.False;
|
_axis_y_qe.GridLines.Visible = false;
|
_axis_y_qp.Visibility = DefaultBoolean.False;
|
_axis_y_qp.GridLines.Visible = false;
|
|
|
_work_pt_line.Visible = false;
|
_work_pt_txt_annot.Visible = false;
|
|
this.chartControl1.MouseMove += new System.Windows.Forms.MouseEventHandler(this.chartControl1_MouseMove);
|
this.chartControl1.MouseUp += new System.Windows.Forms.MouseEventHandler(this.chartControl1_MouseUp);
|
this.chartControl1.MouseDown += new System.Windows.Forms.MouseEventHandler(this.chartControl1_MouseDown);
|
this.chartControl1.Resize += new System.EventHandler(this.chartControl1_Resize);
|
}
|
|
/// <summary>
|
/// 初始化图表数据
|
/// </summary>
|
public void InitialChartData()
|
{
|
_initialData = false;
|
_coordinate_paras = null;
|
|
UpdateChart(false);
|
}
|
|
#endregion
|
|
#region Add Update Curve
|
|
|
/// <summary>
|
/// 添加曲线
|
/// </summary>
|
/// <param name="id"></param>
|
/// <param name="name"></param>
|
/// <param name="color"></param>
|
/// <param name="cubic_spline_qh"></param>
|
/// <param name="cubic_spline_qe"></param>
|
/// <param name="cubic_spline_qp"></param>
|
public void Add(
|
string id,
|
string name,
|
Color color,
|
Yw.Geometry.CubicSpline2d cubic_spline_qh,
|
Yw.Geometry.CubicSpline2d cubic_spline_qe,
|
Yw.Geometry.CubicSpline2d cubic_spline_qp)
|
{
|
if (cubic_spline_qh == null)
|
return;
|
if (_vm_list.Exists(x => x.ID == id))
|
return;
|
_initialData = true;
|
|
List<Yw.Geometry.Point2d> pt_qh_list, pt_qe_list = null, pt_qp_list = null;
|
|
pt_qh_list = cubic_spline_qh.GetPointList(12);
|
if (cubic_spline_qe != null)
|
pt_qe_list = cubic_spline_qe.GetPointList(12);
|
|
if (cubic_spline_qp != null)
|
pt_qp_list = cubic_spline_qp.GetPointList(12);
|
|
Add(id, name, color, cubic_spline_qh, cubic_spline_qe, cubic_spline_qp, pt_qh_list, pt_qe_list, pt_qp_list);
|
}
|
|
/// <summary>
|
/// 添加曲线
|
/// </summary>
|
/// <param name="id"></param>
|
/// <param name="name"></param>
|
/// <param name="color"></param>
|
/// <param name="cubic_spline_qh"></param>
|
/// <param name="cubic_spline_qe"></param>
|
/// <param name="cubic_spline_qp"></param>
|
public void Add(
|
string id,
|
string name,
|
Color color,
|
List<Yw.Geometry.Point2d> pt_qh_list,
|
List<Yw.Geometry.Point2d> pt_qe_list,
|
List<Yw.Geometry.Point2d> pt_qp_list)
|
{
|
if (pt_qh_list == null || !pt_qh_list.Any())
|
return;
|
if (_vm_list.Exists(x => x.ID == id))
|
return;
|
_initialData = true;
|
|
Yw.Geometry.CubicSpline2d cubic_spline_qh, cubic_spline_qe = null, cubic_spline_qp = null;
|
|
cubic_spline_qh = new Yw.Geometry.CubicSpline2d(pt_qh_list);
|
if (pt_qe_list != null && pt_qe_list.Any())
|
cubic_spline_qe = new Yw.Geometry.CubicSpline2d(pt_qe_list);
|
|
if (pt_qp_list != null && pt_qp_list.Any())
|
cubic_spline_qp = new Yw.Geometry.CubicSpline2d(pt_qp_list);
|
|
Add(id, name, color, cubic_spline_qh, cubic_spline_qe, cubic_spline_qp, pt_qh_list, pt_qe_list, pt_qp_list);
|
}
|
|
/// <summary>
|
/// 添加曲线
|
/// </summary>
|
/// <param name="id"></param>
|
/// <param name="name"></param>
|
/// <param name="color"></param>
|
/// <param name="cubic_spline_qh"></param>
|
/// <param name="cubic_spline_qe"></param>
|
/// <param name="cubic_spline_qp"></param>
|
/// <param name="def_pt_qh_list"></param>
|
/// <param name="def_pt_qe_list"></param>
|
/// <param name="def_pt_qp_list"></param>
|
public void Add
|
(string id,
|
string name,
|
Color color,
|
Yw.Geometry.CubicSpline2d cubic_spline_qh,
|
Yw.Geometry.CubicSpline2d cubic_spline_qe,
|
Yw.Geometry.CubicSpline2d cubic_spline_qp,
|
List<Yw.Geometry.Point2d> def_pt_qh_list = null,
|
List<Yw.Geometry.Point2d> def_pt_qe_list = null,
|
List<Yw.Geometry.Point2d> def_pt_qp_list = null)
|
{
|
if (cubic_spline_qh == null)
|
return;
|
if (_vm_list.Exists(x => x.ID == id))
|
return;
|
_initialData = true;
|
CurrentViewModel curve = new CurrentViewModel();
|
curve.ID = id;
|
curve.Name = name;
|
curve.QH = cubic_spline_qh;
|
curve.QE = cubic_spline_qe;
|
curve.QP = cubic_spline_qp;
|
|
curve.QHPoints = def_pt_qh_list;
|
curve.QEPoints = def_pt_qe_list;
|
curve.QPPoints = def_pt_qp_list;
|
|
|
curve.Color = color;
|
_vm_list.Add(curve);
|
UpdateChart(true);
|
}
|
|
|
/// <summary>
|
/// 设置曲线
|
/// </summary>
|
/// <param name="id"></param>
|
/// <param name="cubic_spline_qh"></param>
|
/// <param name="cubic_spline_qe"></param>
|
/// <param name="cubic_spline_qp"></param>
|
/// <param name="name"></param>
|
public void Set(string id, Yw.Geometry.CubicSpline2d cubic_spline_qh, Yw.Geometry.CubicSpline2d cubic_spline_qe, Yw.Geometry.CubicSpline2d cubic_spline_qp, string name = "")
|
{
|
var exist = _vm_list.FirstOrDefault(x => x.ID == id);
|
if (exist == null)
|
return;
|
if (!string.IsNullOrEmpty(name))
|
{
|
exist.Name = name;
|
}
|
exist.QH = cubic_spline_qh;
|
exist.QE = cubic_spline_qe;
|
exist.QP = cubic_spline_qp;
|
|
exist.QHPoints = cubic_spline_qh.GetPointList(12);
|
exist.QEPoints = cubic_spline_qe.GetPointList(12);
|
exist.QPPoints = cubic_spline_qp.GetPointList(12);
|
|
UpdateChart(true);
|
}
|
|
/// <summary>
|
/// 设置曲线
|
/// </summary>
|
/// <param name="id"></param>
|
/// <param name="color"></param>
|
public void Set(string id, Color color)
|
{
|
var exist = _vm_list.FirstOrDefault(x => x.ID == id);
|
if (exist == null)
|
return;
|
foreach (Series series in this.chartControl1.Series)
|
{
|
var tag = series.Tag;
|
if (tag == null)
|
continue;
|
if (tag.ToString() != exist.ID.ToString())
|
continue;
|
exist.Color = color;
|
series.View.Color = color;
|
for (int i = 0; i < this.chartControl1.AnnotationRepository.Count; i++)
|
{
|
var txt = this.chartControl1.AnnotationRepository[i];
|
if (txt.Name == _tag_qh + id.ToString())
|
{
|
(txt as TextAnnotation).TextColor = color;
|
(txt as TextAnnotation).Border.Color = color;
|
}
|
}
|
}
|
|
}
|
|
/// <summary>
|
/// 设置曲线(需手动更新图表)
|
/// </summary>
|
/// <param name="id"></param>
|
/// <param name="name"></param>
|
public void SetName(string id, string name)
|
{
|
var exist = _vm_list.FirstOrDefault(x => x.ID == id);
|
if (exist == null)
|
return;
|
exist.Name = name;
|
}
|
|
/// <summary>
|
/// 删除曲线
|
/// </summary>
|
public void Delete()
|
{
|
_vm_list.Clear();
|
UpdateChart(true);
|
_initialData = false;
|
|
}
|
|
/// <summary>
|
/// 删除曲线
|
/// </summary>
|
/// <param name="id"></param>
|
public void Delete(string id)
|
{
|
var exist = _vm_list.FirstOrDefault(x => x.ID == id);
|
if (exist == null)
|
return;
|
_vm_list.Remove(exist);
|
UpdateChart(true);
|
if (_vm_list.Count == 0)
|
{
|
_initialData = false;
|
}
|
}
|
|
/// <summary>
|
/// 更新图表
|
/// </summary>
|
/// <param name="calcCoordinate">计算坐标</param>
|
public void UpdateChart(bool calcCoordinate = false)
|
{
|
if (calcCoordinate || _coordinate_paras == null)
|
{
|
//不强迫计算,就用上次更新的坐标系
|
CalcCoordinate();
|
}
|
|
CalcSeries();
|
|
CalcChartAxis();
|
|
CalcWorkPointByQ();
|
|
CalcTextAnchorPoint();
|
}
|
|
#endregion
|
|
#region Calc
|
|
private double _minQ, _maxQ;
|
private double _maxH = 0, _minH = 10000;
|
private double _maxE = 0, _minE = 0;
|
private double _maxP = 0, _minP = 1000;
|
|
/// <summary>
|
/// 计算坐标
|
/// </summary>
|
private void CalcCoordinate()
|
{
|
if (_vm_list == null || !_vm_list.Any())
|
{
|
//设置成白板坐标
|
_coordinate_paras = new PumpCoordinate();
|
_coordinate_paras.GridNumberX = 30;
|
_coordinate_paras.GridNumberY = 16;
|
//显示的坐标线号
|
_coordinate_paras.StartLineNoH = 10;
|
_coordinate_paras.EndLineNoH = 15;
|
_coordinate_paras.StartLineNoE = 0;
|
_coordinate_paras.EndLineNoE = 10;
|
_coordinate_paras.StartLineNoP = 2;
|
_coordinate_paras.EndLineNoP = 9;
|
//坐标最小值和间隔
|
_coordinate_paras.CoordMinQ = 0; _coordinate_paras.CoordSpaceQ = 1000;
|
_coordinate_paras.CoordMinH = 10; _coordinate_paras.CoordSpaceH = 100;
|
_coordinate_paras.CoordMinE = 0; _coordinate_paras.CoordSpaceE = 100;
|
_coordinate_paras.CoordMinP = 10; _coordinate_paras.CoordSpaceP = 100;
|
return;
|
}
|
|
_maxQ = 0; _minQ = 10000;
|
_maxH = 0; _minH = 10000;
|
_maxE = 0; _minE = 0;
|
_maxP = 0; _minP = 1000;
|
|
double _scaleMinH = 1, _scaleMaxH = 1;
|
|
foreach (var curve in _vm_list)
|
{
|
var xxx = curve.QHPoints.Select(x => x.X);
|
var yyy = curve.QHPoints.Select(x => x.Y);
|
|
_minQ = Math.Min(_minQ, xxx.Min());
|
_maxQ = Math.Max(_maxQ, xxx.Max());
|
|
_minH = Math.Min(_minH, yyy.Min());
|
_maxH = Math.Max(_maxH, yyy.Max());
|
}
|
|
|
foreach (CurrentViewModel info in _vm_list)
|
{
|
if (info.QEPoints == null)
|
continue;
|
var yyy = info.QEPoints?.Select(x => x.Y);
|
_maxE = Math.Max(_maxE, yyy.Max());
|
}
|
foreach (CurrentViewModel info in _vm_list)
|
{
|
var yyy = info.QPPoints.Select(x => x.Y);
|
|
_minP = Math.Min(_minP, yyy.Min());
|
_maxP = Math.Max(_maxP, yyy.Max());
|
}
|
|
_coordinate_paras = PumpCoordinate.CalcCoordinate(_minQ,
|
_maxQ,
|
_minH * _scaleMinH,
|
_maxH * _scaleMaxH,
|
_minE,
|
_maxE,
|
_minP,
|
_maxP);
|
|
if (_coordinate_paras == null)
|
return;
|
if (_coordinate_paras.CoordMinQ + _coordinate_paras.CoordSpaceQ * this._coordinate_paras.GridNumberX < _maxQ * 1.05)
|
{
|
_coordinate_paras.GridNumberX++;
|
}
|
}
|
|
/// <summary>
|
/// 计算图表轴
|
/// </summary>
|
private void CalcChartAxis()
|
{
|
// if (_coordinateParas == null)
|
// {
|
_axis_x_q.Visibility = DefaultBoolean.False;
|
_axis_x_q.GridLines.Visible = false;
|
_axis_y_qh.Visibility = DefaultBoolean.False;
|
_axis_y_qh.GridLines.Visible = false;
|
_axis_y_qe.Visibility = DefaultBoolean.False;
|
_axis_y_qe.GridLines.Visible = false;
|
_axis_y_qp.Visibility = DefaultBoolean.False;
|
_axis_y_qp.GridLines.Visible = false;
|
|
_work_pt_line.Visible = false;
|
|
_pane_qe.Visibility = ChartElementVisibility.Hidden;
|
_pane_qp.Visibility = ChartElementVisibility.Hidden;
|
// return;
|
// }
|
|
_pane_qe.Visibility = _cubic_spline_qe_visible ? ChartElementVisibility.Visible : ChartElementVisibility.Hidden;
|
_pane_qp.Visibility = _cubic_spline_qp_visible ? ChartElementVisibility.Visible : ChartElementVisibility.Hidden;
|
|
//计算刻度 Q
|
var axisQLabels = new List<CustomAxisLabel>();
|
var disQ = _coordinate_paras.CoordMinQ;
|
for (int i = 0; i < _coordinate_paras.GridNumberX + 1; i++)
|
{
|
axisQLabels.Add(new CustomAxisLabel(disQ.ToString("N0"), disQ));
|
disQ = disQ + _coordinate_paras.CoordSpaceQ;
|
}
|
|
_axis_x_q.CustomLabels.Clear();
|
_axis_x_q.CustomLabels.AddRange(axisQLabels.ToArray());
|
_axis_x_q.Visibility = DefaultBoolean.True;
|
_axis_x_q.GridLines.Visible = true;
|
|
|
|
//计算刻度
|
var axisQHLabels = new List<CustomAxisLabel>();
|
var disH = _coordinate_paras.CoordMinH + _coordinate_paras.CoordSpaceH * _coordinate_paras.StartLineNoH;
|
for (int i = _coordinate_paras.StartLineNoH; i < _coordinate_paras.EndLineNoH + 1; i++)
|
{
|
axisQHLabels.Add(new CustomAxisLabel(disH.ToString(), disH));
|
disH = disH + _coordinate_paras.CoordSpaceH;
|
}
|
|
_axis_y_qh.CustomLabels.Clear();
|
_axis_y_qh.CustomLabels.AddRange(axisQHLabels.ToArray());
|
_axis_y_qh.Visibility = DefaultBoolean.True;
|
_axis_y_qh.GridLines.Visible = true;
|
|
//效率
|
if (_maxE > _minE && _cubic_spline_qe_visible)
|
{
|
//计算刻度
|
var axisQELabels = new List<CustomAxisLabel>();
|
var disE = _coordinate_paras.CoordMinE + _coordinate_paras.CoordSpaceE * _coordinate_paras.StartLineNoE;
|
for (int i = _coordinate_paras.StartLineNoE; i < _coordinate_paras.EndLineNoE + 1; i++)
|
{
|
axisQELabels.Add(new CustomAxisLabel(disE.ToString(), disE));
|
disE = disE + _coordinate_paras.CoordSpaceE;
|
}
|
|
_axis_y_qe.CustomLabels.Clear();
|
_axis_y_qe.CustomLabels.AddRange(axisQELabels.ToArray());
|
_axis_y_qe.Visibility = DefaultBoolean.True;
|
_axis_y_qe.GridLines.Visible = true;
|
}
|
|
//功率
|
if (_maxP > _minP)
|
{
|
//计算刻度
|
var axisQPLabels = new List<CustomAxisLabel>();
|
double disP = _coordinate_paras.CoordMinP + _coordinate_paras.CoordSpaceP * _coordinate_paras.StartLineNoP;
|
for (int i = _coordinate_paras.StartLineNoP; i < _coordinate_paras.EndLineNoP + 1; i++)
|
{
|
axisQPLabels.Add(new CustomAxisLabel(disP.ToString(), disP));
|
disP = disP + _coordinate_paras.CoordSpaceP;
|
}
|
|
_axis_y_qp.CustomLabels.Clear();
|
_axis_y_qp.CustomLabels.AddRange(axisQPLabels.ToArray());
|
_axis_y_qp.Visibility = DefaultBoolean.True;
|
_axis_y_qp.GridLines.Visible = true;
|
}
|
|
|
_axis_x_q.SetAxisRange(_coordinate_paras.CoordMinQ, _coordinate_paras.DispMaxQ());
|
_axis_y_qh.SetAxisRange(_coordinate_paras.DispMinH(), _coordinate_paras.DispMaxH());
|
_axis_y_qe.SetAxisRange(_coordinate_paras.DispMinE(), _coordinate_paras.DispMaxE());
|
_axis_y_qp.SetAxisRange(_coordinate_paras.DispMinP(), _coordinate_paras.DispMaxP());
|
}
|
|
/// <summary>
|
/// 计算系列
|
/// </summary>
|
private void CalcSeries()
|
{
|
this.chartControl1.BeginInit();
|
this.chartControl1.Series.Clear();
|
|
var annotationCount = this.chartControl1.AnnotationRepository.Count;
|
for (int i = annotationCount - 1; i > 0; i--)
|
{
|
if (i == 0)
|
break;
|
this.chartControl1.AnnotationRepository.RemoveAt(i);
|
}
|
|
this.chartControl1.Legend.CustomItems.Clear();
|
foreach (var curve in _vm_list)
|
{
|
CreateSeries(curve);
|
}
|
if (_vm_list.Count == 0)
|
{
|
LineVisible = false;
|
}
|
this.chartControl1.EndInit();
|
}
|
|
/// <summary>
|
/// 计算注释定位
|
/// </summary>
|
private void CalcTextAnchorPoint()
|
{
|
var x = this.chartControl1.Location.X + this.chartControl1.Width - (100);
|
var y = this.chartControl1.Height - (100);
|
|
(_work_pt_txt_annot.AnchorPoint as ChartAnchorPoint).X = x;
|
(_work_pt_txt_annot.AnchorPoint as ChartAnchorPoint).Y = y;
|
}
|
|
/// <summary>
|
/// 计算工作点
|
/// </summary>
|
/// <param name="workQ"></param>
|
public void CalcWorkPointByQ(double? workQ = null)
|
{
|
if (!_line_visible)
|
{
|
_work_pt_line.Visible = false;
|
_work_pt_line.Title.Visible = false;
|
_work_pt_txt_annot.Visible = false;
|
return;
|
}
|
else
|
{
|
_work_pt_line.Visible = true;
|
_work_pt_line.Title.Visible = true;
|
_work_pt_txt_annot.Visible = true;
|
}
|
|
if (_vm_list == null || !_vm_list.Any())
|
return;
|
|
if (_vm_list.Exists(x => x.ID == "-1"))
|
{
|
_work_pt_txt_annot.Visible = true;
|
}
|
else
|
{
|
_work_pt_txt_annot.Visible = false;
|
}
|
|
|
if (workQ == null)
|
{
|
workQ = (_minQ + _maxQ) / 2;
|
}
|
|
if (workQ < _minQ || workQ > _maxQ)
|
return;
|
foreach (var curve in _vm_list)
|
{
|
var curveMinQ = curve.QH.MinX;
|
var curveMaxQ = curve.QH.MaxX;
|
|
var workPoint = new PumpGroupPt(0, 0, 0, 0, 0);
|
if (curveMinQ > workQ.Value || workQ.Value > curveMaxQ)
|
{
|
if (OnCalcQueryPoint != null)
|
{
|
OnCalcQueryPoint(curve.ID, workPoint);
|
}
|
|
if (curve.ID == "-1")
|
{
|
_work_pt_txt_annot.Visible = false;
|
}
|
continue;
|
}
|
workPoint.Q = workQ.Value;
|
workPoint.H = curve.QH.GetPointY(workQ.Value);
|
|
var workInfoStringBuilder = new StringBuilder();
|
workInfoStringBuilder.AppendLine($"流量:{workPoint.Q.ToString("N1")} ");
|
workInfoStringBuilder.AppendLine($"扬程:{workPoint.H.ToString("N1")} ");
|
|
|
|
if (curve.QE != null)
|
{
|
if (curve.QP != null)
|
{
|
workPoint.P = curve.QP.GetPointY(workPoint.Q);
|
workPoint.E = PumpCalcHelper.CalculateE(workPoint.Q, workPoint.H, workPoint.P);
|
}
|
else
|
{
|
workPoint.E = curve.QE.GetPointY(workPoint.Q);
|
}
|
|
workInfoStringBuilder.AppendLine($"效率:{workPoint.E.ToString("N2")} ");
|
}
|
if (curve.QP != null)
|
{
|
workPoint.P = curve.QP.GetPointY(workPoint.Q);
|
workInfoStringBuilder.Append($"功率:{workPoint.P.ToString("N1")} ");
|
}
|
|
if (curve.ID == "-1")
|
{
|
_work_pt_txt_annot.Text = workInfoStringBuilder.ToString();
|
_work_pt_txt_annot.AutoSize = true;
|
}
|
else
|
{
|
|
if (OnCalcQueryPoint != null)
|
{
|
OnCalcQueryPoint(curve.ID, workPoint);
|
}
|
}
|
}
|
|
_work_pt_line.AxisValue = workQ;
|
_work_pt_line.Title.Text = workQ.Value.ToString("N1");
|
}
|
|
/// <summary>
|
/// 创建系列
|
/// </summary>
|
private void CreateSeries(CurrentViewModel curve)
|
{
|
|
var seriesCurveQH = new DevExpress.XtraCharts.Series();
|
seriesCurveQH.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.Numerical;
|
seriesCurveQH.LabelsVisibility = DevExpress.Utils.DefaultBoolean.False;
|
seriesCurveQH.Name = _tag_qh + curve.ID.ToString();
|
seriesCurveQH.ShowInLegend = false;
|
seriesCurveQH.CrosshairEnabled = DefaultBoolean.False;
|
seriesCurveQH.Tag = curve.ID.ToString();
|
seriesCurveQH.ShowInLegend = true;
|
seriesCurveQH.LegendTextPattern = curve.Name;
|
|
var seriesCurveQHView = new DevExpress.XtraCharts.SplineSeriesView();
|
seriesCurveQHView.LineStyle.Thickness = 2;
|
seriesCurveQHView.Color = curve.Color;
|
seriesCurveQHView.EnableAntialiasing = DefaultBoolean.True;
|
|
seriesCurveQH.SeriesPointsSorting = SortingMode.None;
|
seriesCurveQH.SeriesPointsSortingKey = SeriesPointKey.Value_1;
|
seriesCurveQH.View = seriesCurveQHView;
|
seriesCurveQH.Visible = _cubic_spline_qh_visible;
|
|
var pointsQH = curve.QH.GetPointList(12);
|
for (int i = 0; i < pointsQH.Count; i++)
|
{
|
seriesCurveQH.Points.Add(new SeriesPoint(pointsQH[i].X, new double[] { pointsQH[i].Y }));
|
}
|
|
var pointQH = pointsQH[pointsQH.Count() - 1];
|
var anchorPointQH = new DevExpress.XtraCharts.PaneAnchorPoint();
|
anchorPointQH.Pane = _pane_qh;
|
anchorPointQH.AxisXCoordinate.AxisValue = pointQH.X.ToString();
|
anchorPointQH.AxisYCoordinate.AxisValue = pointQH.Y.ToString();
|
|
var positionQH = new DevExpress.XtraCharts.RelativePosition();
|
positionQH.Angle = 30;
|
positionQH.ConnectorLength = 35;
|
|
var txtQH = new TextAnnotation();
|
txtQH.Border.Visibility = DefaultBoolean.False;
|
txtQH.AnchorPoint = anchorPointQH;
|
txtQH.AutoHeight = true;
|
txtQH.AutoWidth = true;
|
txtQH.BackColor = System.Drawing.Color.Transparent;
|
txtQH.Border.Color = curve.Color;
|
txtQH.ConnectorStyle = DevExpress.XtraCharts.AnnotationConnectorStyle.Line;
|
txtQH.DXFont = Perform2dChartDisplay.AnnoFontQH;
|
txtQH.Name = _tag_qh + curve.ID.ToString();
|
txtQH.Padding.Bottom = 1;
|
txtQH.Padding.Left = 1;
|
txtQH.Padding.Right = 1;
|
txtQH.Padding.Top = 1;
|
txtQH.RuntimeAnchoring = false;
|
txtQH.RuntimeMoving = true;
|
txtQH.RuntimeResizing = false;
|
txtQH.RuntimeRotation = false;
|
txtQH.Text = curve.Name;
|
txtQH.TextColor = curve.Color;
|
txtQH.ShapePosition = positionQH;
|
txtQH.Visible = _line_name_visible;
|
this.chartControl1.AnnotationRepository.Add(txtQH);
|
|
this.chartControl1.Series.Add(seriesCurveQH);
|
|
if (curve.QE != null)
|
{
|
var seriesCurveQE = new DevExpress.XtraCharts.Series();
|
seriesCurveQE.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.Numerical;
|
seriesCurveQE.LabelsVisibility = DevExpress.Utils.DefaultBoolean.False;
|
seriesCurveQE.Name = _tag_qe + curve.ID.ToString();
|
seriesCurveQE.ShowInLegend = false;
|
seriesCurveQE.CrosshairEnabled = DefaultBoolean.False;
|
seriesCurveQE.Tag = curve.ID.ToString();
|
|
var seriesCurveQEView = new DevExpress.XtraCharts.SplineSeriesView();
|
seriesCurveQEView.LineStyle.Thickness = 2;
|
seriesCurveQEView.Color = curve.Color;
|
seriesCurveQEView.AxisY = _axis_y_qe;
|
seriesCurveQEView.Pane = _pane_qe;
|
seriesCurveQEView.EnableAntialiasing = DefaultBoolean.True;
|
|
seriesCurveQE.SeriesPointsSorting = SortingMode.None;
|
seriesCurveQE.SeriesPointsSortingKey = SeriesPointKey.Value_1;
|
seriesCurveQE.View = seriesCurveQEView;
|
seriesCurveQE.Visible = _cubic_spline_qe_visible;
|
|
var pointsQE = curve.QE.GetPointList(12);
|
for (int i = 0; i < pointsQE.Count; i++)
|
{
|
seriesCurveQE.Points.Add(new SeriesPoint(pointsQE[i].X, new double[] { pointsQE[i].Y }));
|
}
|
|
this.chartControl1.Series.Add(seriesCurveQE);
|
}
|
|
if (curve.QP != null)
|
{
|
var seriesCurveQP = new DevExpress.XtraCharts.Series();
|
seriesCurveQP.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.Numerical;
|
seriesCurveQP.LabelsVisibility = DevExpress.Utils.DefaultBoolean.False;
|
seriesCurveQP.Name = _tag_qp + curve.ID.ToString();
|
seriesCurveQP.ShowInLegend = false;
|
seriesCurveQP.CrosshairEnabled = DefaultBoolean.False;
|
seriesCurveQP.Tag = curve.ID.ToString();
|
|
var seriesCurveQPView = new DevExpress.XtraCharts.SplineSeriesView();
|
seriesCurveQPView.LineStyle.Thickness = 2;
|
seriesCurveQPView.Color = curve.Color;
|
seriesCurveQPView.AxisY = _axis_y_qp;
|
seriesCurveQPView.Pane = _pane_qp;
|
seriesCurveQPView.EnableAntialiasing = DefaultBoolean.True;
|
|
seriesCurveQP.SeriesPointsSorting = SortingMode.None;
|
seriesCurveQP.SeriesPointsSortingKey = SeriesPointKey.Value_1;
|
seriesCurveQP.View = seriesCurveQPView;
|
seriesCurveQP.Visible = _cubic_spline_qp_visible;
|
|
var pointsQP = curve.QP.GetPointList(12);
|
for (int i = 0; i < pointsQP.Count; i++)
|
{
|
seriesCurveQP.Points.Add(new SeriesPoint(pointsQP[i].X, new double[] { pointsQP[i].Y }));
|
}
|
|
this.chartControl1.Series.Add(seriesCurveQP);
|
}
|
}
|
|
private Series _seriesCurvePointQH, _seriesCurvePointQE, _seriesCurvePointQP;
|
|
/// <summary>
|
/// 创建系列
|
/// </summary>
|
public void CreatePointSeries(List<Yw.Geometry.Point2d> curvePointsQH, List<Yw.Geometry.Point2d> curvePointsQE, List<Yw.Geometry.Point2d> curvePointsQP)
|
{
|
this.chartControl1.BeginInit();
|
if (curvePointsQH == null)
|
{
|
if (_seriesCurvePointQH != null)
|
{
|
this.chartControl1.Series.Remove(_seriesCurvePointQH);
|
}
|
if (_seriesCurvePointQE != null)
|
{
|
this.chartControl1.Series.Remove(_seriesCurvePointQE);
|
}
|
if (_seriesCurvePointQP != null)
|
{
|
this.chartControl1.Series.Remove(_seriesCurvePointQP);
|
}
|
_seriesCurvePointQH = null;
|
_seriesCurvePointQE = null;
|
_seriesCurvePointQP = null;
|
this.chartControl1.EndInit();
|
return;
|
}
|
|
_seriesCurvePointQH = new DevExpress.XtraCharts.Series();
|
_seriesCurvePointQH.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.Numerical;
|
_seriesCurvePointQH.LabelsVisibility = DevExpress.Utils.DefaultBoolean.False;
|
_seriesCurvePointQH.Name = _tag_qh + "CurvePoint";
|
_seriesCurvePointQH.ShowInLegend = false;
|
_seriesCurvePointQH.CrosshairEnabled = DefaultBoolean.False;
|
_seriesCurvePointQH.ShowInLegend = true;
|
_seriesCurvePointQH.LegendTextPattern = "流量扬程点";
|
_seriesCurvePointQH.LabelsVisibility = DefaultBoolean.True;
|
|
var seriesCurveQHView = new DevExpress.XtraCharts.PointSeriesView();
|
seriesCurveQHView.Color = Perform2dChartDisplay.PointColorQH;
|
|
_seriesCurvePointQH.SeriesPointsSorting = SortingMode.None;
|
_seriesCurvePointQH.SeriesPointsSortingKey = SeriesPointKey.Value_1;
|
_seriesCurvePointQH.View = seriesCurveQHView;
|
_seriesCurvePointQH.Visible = _cubic_spline_qh_visible;
|
|
for (int i = 0; i < curvePointsQH.Count; i++)
|
{
|
_seriesCurvePointQH.Points.Add(new SeriesPoint(curvePointsQH[i].X, new double[] { curvePointsQH[i].Y }));
|
}
|
|
this.chartControl1.Series.Add(_seriesCurvePointQH);
|
|
if (curvePointsQE != null)
|
{
|
_seriesCurvePointQE = new DevExpress.XtraCharts.Series();
|
_seriesCurvePointQE.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.Numerical;
|
_seriesCurvePointQE.LabelsVisibility = DevExpress.Utils.DefaultBoolean.False;
|
_seriesCurvePointQE.Name = _tag_qe + "CurvePoint";
|
_seriesCurvePointQE.ShowInLegend = false;
|
_seriesCurvePointQE.CrosshairEnabled = DefaultBoolean.False;
|
_seriesCurvePointQE.LabelsVisibility = DefaultBoolean.True;
|
|
var seriesCurveQEView = new DevExpress.XtraCharts.PointSeriesView();
|
seriesCurveQEView.Color = Perform2dChartDisplay.PointColorQE;
|
seriesCurveQEView.AxisY = _axis_y_qe;
|
seriesCurveQEView.Pane = _pane_qe;
|
|
_seriesCurvePointQE.SeriesPointsSorting = SortingMode.None;
|
_seriesCurvePointQE.SeriesPointsSortingKey = SeriesPointKey.Value_1;
|
_seriesCurvePointQE.View = seriesCurveQEView;
|
_seriesCurvePointQE.Visible = _cubic_spline_qe_visible;
|
|
for (int i = 0; i < curvePointsQE.Count; i++)
|
{
|
_seriesCurvePointQE.Points.Add(new SeriesPoint(curvePointsQE[i].X, new double[] { curvePointsQE[i].Y }));
|
}
|
|
this.chartControl1.Series.Add(_seriesCurvePointQE);
|
}
|
|
if (curvePointsQP != null)
|
{
|
_seriesCurvePointQP = new DevExpress.XtraCharts.Series();
|
_seriesCurvePointQP.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.Numerical;
|
_seriesCurvePointQP.LabelsVisibility = DevExpress.Utils.DefaultBoolean.False;
|
_seriesCurvePointQP.Name = _tag_qp + "CurvePoint";
|
_seriesCurvePointQP.ShowInLegend = false;
|
_seriesCurvePointQP.CrosshairEnabled = DefaultBoolean.False;
|
_seriesCurvePointQP.LabelsVisibility = DefaultBoolean.True;
|
|
var seriesCurveQPView = new DevExpress.XtraCharts.PointSeriesView();
|
seriesCurveQPView.Color = Perform2dChartDisplay.PointColorQP;
|
seriesCurveQPView.AxisY = _axis_y_qp;
|
seriesCurveQPView.Pane = _pane_qp;
|
|
_seriesCurvePointQP.SeriesPointsSorting = SortingMode.None;
|
_seriesCurvePointQP.SeriesPointsSortingKey = SeriesPointKey.Value_1;
|
_seriesCurvePointQP.View = seriesCurveQPView;
|
_seriesCurvePointQP.Visible = _cubic_spline_qp_visible;
|
|
for (int i = 0; i < curvePointsQP.Count; i++)
|
{
|
_seriesCurvePointQP.Points.Add(new SeriesPoint(curvePointsQP[i].X, new double[] { curvePointsQP[i].Y }));
|
}
|
|
this.chartControl1.Series.Add(_seriesCurvePointQP);
|
}
|
this.chartControl1.EndInit();
|
}
|
|
public void SetPointSeries(bool show, bool showLabel)
|
{
|
if (_seriesCurvePointQH == null || _seriesCurvePointQE == null || _seriesCurvePointQP == null)
|
{
|
return;
|
}
|
|
var labelsVisibility = showLabel ? DefaultBoolean.True : DefaultBoolean.False;
|
_seriesCurvePointQH.Visible = show;
|
_seriesCurvePointQH.LabelsVisibility = labelsVisibility;
|
if (_seriesCurvePointQE != null)
|
{
|
_seriesCurvePointQE.Visible = show;
|
_seriesCurvePointQE.LabelsVisibility = labelsVisibility;
|
}
|
if (_seriesCurvePointQP != null)
|
{
|
_seriesCurvePointQP.Visible = show;
|
_seriesCurvePointQP.LabelsVisibility = labelsVisibility;
|
}
|
}
|
|
#endregion
|
|
#region ChartEvent
|
|
// 右键对象
|
private object _rightClickObj = null;
|
private bool _onMoveWorkPointLine = false;
|
private void chartControl1_MouseDown(object sender, MouseEventArgs e)
|
{
|
if (!_initialData)
|
return;
|
var hitInfo = chartControl1.CalcHitInfo(e.Location);
|
if (e.Button == MouseButtons.Left)
|
{
|
if (hitInfo.InSeries)
|
{
|
_rightClickObj = hitInfo.Series;
|
|
}
|
else if (hitInfo.InAxis)
|
{
|
_rightClickObj = hitInfo.Axis;
|
}
|
else if (hitInfo.InConstantLine)
|
{
|
if (hitInfo.ConstantLine == _work_pt_line)
|
{
|
_onMoveWorkPointLine = true;
|
}
|
|
|
}
|
else if (hitInfo.InAnnotation)
|
{
|
_rightClickObj = hitInfo.Annotation;
|
}
|
else
|
{
|
_rightClickObj = null;
|
}
|
}
|
else if (e.Button == MouseButtons.Right)
|
{
|
if (hitInfo.InConstantLine)
|
{
|
this.popMenuLine.ShowPopup(MousePosition);
|
}
|
else
|
{
|
this.popMenuChart.ShowPopup(MousePosition);
|
}
|
}
|
}
|
|
private void chartControl1_MouseMove(object sender, MouseEventArgs e)
|
{
|
if (!_initialData)
|
return;
|
if (_onMoveWorkPointLine)
|
{
|
var diagramCoordinates = _main_chart_diagram.PointToDiagram(e.Location);
|
var axisValue = diagramCoordinates.GetAxisValue(_axis_x_q);
|
if (axisValue == null)
|
return;
|
double chartQ = axisValue.NumericalValue;
|
CalcWorkPointByQ(chartQ);
|
|
}
|
}
|
|
private void chartControl1_MouseUp(object sender, MouseEventArgs e)
|
{
|
if (!_initialData)
|
return;
|
_onMoveWorkPointLine = false;
|
}
|
|
private void chartControl1_Resize(object sender, EventArgs e)
|
{
|
CalcTextAnchorPoint();
|
}
|
#endregion
|
|
#region Right Click Menu
|
|
#region Event
|
private void barBtnSetAxisQValue_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
if (_vm_list == null || !_vm_list.Any())
|
return;
|
var dlg = new PumpAxisValueDlg();
|
dlg.SetBindingData();
|
dlg.VerifyValueChanged += (value) =>
|
{
|
if (value < _minQ || value > _maxQ)
|
return false;
|
CalcWorkPointByQ(value);
|
return true;
|
};
|
dlg.ShowDialog();
|
}
|
|
private void barCekLineVisible_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
SetLineVisible(this.barCekLineVisible.Checked);
|
}
|
|
private void barCekCurveNameVisible_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
SetCurveNameVisible(this.barCekCurveNameVisible.Checked);
|
}
|
|
|
private void barCekLegendVisible_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
SetLegendVisible(this.barCekLegendVisible.Checked);
|
}
|
|
private void barCekSetAxisNameVisible_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
SetAxisNameVisible(this.barCekSetAxisNameVisible.Checked);
|
}
|
|
private void barBtnSetChartAxis_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
SetChartAxis();
|
}
|
|
private void barCekCurveQHVisible_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
_pane_qh.Visibility = _pane_qh.Visibility == ChartElementVisibility.Visible ? ChartElementVisibility.Hidden : ChartElementVisibility.Visible;
|
}
|
|
private void barCekCurveQEVisible_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
_pane_qe.Visibility = _pane_qe.Visibility == ChartElementVisibility.Visible ? ChartElementVisibility.Hidden : ChartElementVisibility.Visible;
|
}
|
|
private void barCekCurveQPVisible_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
|
{
|
_pane_qp.Visibility = _pane_qp.Visibility == ChartElementVisibility.Visible ? ChartElementVisibility.Hidden : ChartElementVisibility.Visible;
|
}
|
|
#endregion
|
|
/// <summary>
|
/// 设置工作点显示
|
/// </summary>
|
public void SetLineVisible(bool visible)
|
{
|
if (!_initialData)
|
return;
|
_line_visible = visible;
|
CalcWorkPointByQ();
|
}
|
|
/// <summary>
|
/// 设置曲线名
|
/// </summary>
|
public void SetCurveNameVisible(bool visible)
|
{
|
if (!_initialData)
|
return;
|
_line_name_visible = visible;
|
for (int i = 1; i < this.chartControl1.AnnotationRepository.Count; i++)
|
{
|
var anno = this.chartControl1.AnnotationRepository[i];
|
anno.Visible = _line_name_visible;
|
}
|
}
|
|
/// <summary>
|
/// 设置图例显示
|
/// </summary>
|
public void SetLegendVisible(bool visible)
|
{
|
this.chartControl1.Legend.Visibility = visible ? DefaultBoolean.True : DefaultBoolean.False;
|
}
|
|
/// <summary>
|
/// 设置轴名称显示
|
/// </summary>
|
public void SetAxisNameVisible(bool visible)
|
{
|
_axis_x_q.Title.Visibility = visible ? DefaultBoolean.True : DefaultBoolean.False;
|
_axis_y_qh.Title.Visibility = visible ? DefaultBoolean.True : DefaultBoolean.False;
|
_axis_y_qe.Title.Visibility = visible ? DefaultBoolean.True : DefaultBoolean.False;
|
_axis_y_qp.Title.Visibility = visible ? DefaultBoolean.True : DefaultBoolean.False;
|
}
|
|
/// <summary>
|
/// 设置坐标轴
|
/// </summary>
|
public void SetChartAxis()
|
{
|
var dlg = new PumpChartCoordinateDlg();
|
dlg.SetBindingData(_coordinate_paras);
|
dlg.OnChangedCoord += (rhs) =>
|
{
|
_coordinate_paras = rhs;
|
CalcChartAxis();
|
this.OnCurveCoordinateChanged?.Invoke(_coordinate_paras);
|
};
|
dlg.ShowDialog();
|
}
|
|
#endregion
|
|
#region Get
|
|
/// <summary>
|
/// 获取曲线列表
|
/// </summary>
|
public void GetCubicSplne2dList(out List<Tuple<Yw.Geometry.CubicSpline2d, Yw.Geometry.CubicSpline2d, Yw.Geometry.CubicSpline2d>> list)
|
{
|
list = null;
|
if (_vm_list == null || !_vm_list.Any())
|
return;
|
foreach (var item in _vm_list)
|
{
|
if (item.ID == "-1")
|
continue;
|
var qh = item.QH;
|
var qe = item.QE;
|
var qp = item.QP;
|
|
list.Add(new Tuple<Geometry.CubicSpline2d, Geometry.CubicSpline2d, Geometry.CubicSpline2d>(qh, qe, qp));
|
}
|
}
|
|
#endregion
|
|
}
|
|
}
|