duheng
2024-03-26 bb006801e4d7fc281e8c1b43ab4b7b83da044ab6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
using DevExpress.XtraEditors;
using System;
using System.Collections.Generic;
using System.Windows.Forms;
 
namespace IStation.WinFrmUI.Curve
{
    /// <summary>
    /// 通过Excel导入曲线
    /// </summary>
    public partial class ImportCurveByExcelTemplateDlg : XtraForm
    {
        public ImportCurveByExcelTemplateDlg()
        {
            InitializeComponent();
        }
 
        #region 页面类
        public class CurrentViewModel : Model.GroupPoint
        {
            public CurrentViewModel() { }
 
            public CurrentViewModel(Model.GroupPoint rhs) : base(rhs)
            {
            }
 
            private double Round_Small(double value, int num, double small = 2.0)
            {
                if (value < small)
                    value = Math.Round(value, 3);
                else
                    value = Math.Round(value, num);
                return value;
            }
        }
        #endregion
 
        private List<CurrentViewModel> _allBindingList;
        public Action<string, Model.eCurveSourceFrom, Model.FeatCurveExpressGroup> ReloadDataEvent;
 
        /// <summary>
        /// 绑定数据
        /// </summary> 
        public void SetBindingData(string curveCode = "", double ratedSeed = 0)
        {
            this.CurveCodeTextEdit.EditValue = curveCode;
            this.RatedSeedTextEdit.EditValue = ratedSeed;
            this.SourceFromImageComboBoxEdit.Properties.AddEnum(typeof(Model.eCurveSourceFrom), false);
            this.SourceFromImageComboBoxEdit.SelectedIndex = 0;
 
            this.QHCurveFitTypeImageComboBoxEdit.Properties.AddEnum(typeof(Model.eCurveFitType), false);
            this.QHCurveFitTypeImageComboBoxEdit.SelectedIndex = 0;
 
            this.QECurveFitTypeImageComboBoxEdit.Properties.AddEnum(typeof(Model.eCurveFitType), false);
            this.QECurveFitTypeImageComboBoxEdit.SelectedIndex = 0;
 
            this.QPCurveFitTypeImageComboBoxEdit.Properties.AddEnum(typeof(Model.eCurveFitType), false);
            this.QPCurveFitTypeImageComboBoxEdit.SelectedIndex = 0;
        }
 
        //选择文件
        private void ExcelBtnEdit_ButtonClick(object sender, DevExpress.XtraEditors.Controls.ButtonPressedEventArgs e)
        {
            var dlg = new System.Windows.Forms.OpenFileDialog();
            dlg.Filter = "EXCEL 文件(*.xls)|*.xls";
            dlg.CheckFileExists = true;
            if (dlg.ShowDialog() != DialogResult.OK)
                return;
            this.ExcelBtnEdit.Text = dlg.FileName;
 
            var list = CurveExpressFileHelper.ImportByExcel(dlg.FileName, out string msg);
            if (list == null)
            {
                XtraMessageBox.Show(msg);
                return;
            }
            _allBindingList = new List<CurrentViewModel>();
            list.ForEach(x => _allBindingList.Add(new CurrentViewModel(x)));
            this.bindingSource1.DataSource = _allBindingList;
        }
 
        //验证
        private bool Valid()
        {
            this.dxErrorProvider1.ClearErrors();
            if (string.IsNullOrEmpty(this.CurveCodeTextEdit.Text.Trim()))
            {
                this.dxErrorProvider1.SetError(this.CurveCodeTextEdit, "必填项");
                return false;
            }
            if (string.IsNullOrEmpty(this.SourceFromImageComboBoxEdit.Text.Trim()))
            {
                this.dxErrorProvider1.SetError(this.SourceFromImageComboBoxEdit, "必选项");
                return false;
            }
            if (string.IsNullOrEmpty(this.QHCurveFitTypeImageComboBoxEdit.Text.Trim()))
            {
                this.dxErrorProvider1.SetError(this.QHCurveFitTypeImageComboBoxEdit, "必选项");
                return false;
            }
            if (string.IsNullOrEmpty(this.RatedSeedTextEdit.Text.Trim()))
            {
                this.dxErrorProvider1.SetError(this.RatedSeedTextEdit, "必填项");
                return false;
            }
            if (_allBindingList == null || _allBindingList.Count < 1)
            {
                XtraMessageBox.Show("无数据!");
                return false;
            }
            return true;
        }
 
 
        //确定
        private void btnOK_Click(object sender, EventArgs e)
        {
            if (!Valid())
                return;
 
            var curveCode = this.CurveCodeTextEdit.Text.Trim();
            var sourceFrom = (Model.eCurveSourceFrom)this.SourceFromImageComboBoxEdit.EditValue;
            var qhFitType = (Model.eCurveFitType)this.QHCurveFitTypeImageComboBoxEdit.EditValue;
            var qeFitType = (Model.eCurveFitType)this.QECurveFitTypeImageComboBoxEdit.EditValue;
            var qpFitType = (Model.eCurveFitType)this.QPCurveFitTypeImageComboBoxEdit.EditValue;
 
            var points_qh = new List<Model.CurvePoint>();
            var points_qe = new List<Model.CurvePoint>();
            var points_qp = new List<Model.CurvePoint>();
            for (int i = 0; i < _allBindingList.Count; i++)
            {
                var model = _allBindingList[i];
                if (model.H > 0)
                    points_qh.Add(new Model.CurvePoint() { X = model.Q, Y = model.H });
                if (model.E >= 0)
                    points_qe.Add(new Model.CurvePoint() { X = model.Q, Y = model.E });
 
                if (model.P > 0)
                    points_qp.Add(new Model.CurvePoint() { X = model.Q, Y = model.P });
            }
 
            var curve = new Model.FeatCurveExpressGroup();
            curve.CurveQH = new Model.CurveExpress(points_qh, qhFitType);
            curve.CurveQE = new Model.CurveExpress(points_qe, qeFitType);
            curve.CurveQP = new Model.CurveExpress(points_qp, qpFitType);
 
            this.ReloadDataEvent?.Invoke(curveCode, sourceFrom, curve);
            this.DialogResult = DialogResult.OK;
            this.Close();
        }
 
 
    }
}