From a2a57963e160a319276c5c8499f16c9809056e4c Mon Sep 17 00:00:00 2001 From: duheng <2784771470@qq.com> Date: 星期日, 17 十一月 2024 21:54:55 +0800 Subject: [PATCH] 修改资产表 --- WinFrmUI/HStation.WinFrmUI.Assets.Core/06-threeLink/02-main/EditThreeLinkMainDlg.cs | 70 +++++++++++++++++++++++++++++++++++ 1 files changed, 70 insertions(+), 0 deletions(-) diff --git a/WinFrmUI/HStation.WinFrmUI.Assets.Core/06-threeLink/02-main/EditThreeLinkMainDlg.cs b/WinFrmUI/HStation.WinFrmUI.Assets.Core/06-threeLink/02-main/EditThreeLinkMainDlg.cs index d4ac5c6..80a3ee4 100644 --- a/WinFrmUI/HStation.WinFrmUI.Assets.Core/06-threeLink/02-main/EditThreeLinkMainDlg.cs +++ b/WinFrmUI/HStation.WinFrmUI.Assets.Core/06-threeLink/02-main/EditThreeLinkMainDlg.cs @@ -1,5 +1,6 @@ 锘縰sing DevExpress.Utils; using DevExpress.XtraEditors.Controls; +using HStation.Vmo; namespace HStation.WinFrmUI.Assets { @@ -13,8 +14,13 @@ private Vmo.AssetsThreelinkMainVmo _ThreeLinkVmo = null; + private List<Vmo.AssetsThreelinkCoefficientVmo> _AssetsThreelinkCoefficient; + public async void SetBindingData(Vmo.AssetsThreelinkMainVmo ThreeLinkVmo) { + var bll = new BLL.AssetsThreelinkCoefficient(); + _AssetsThreelinkCoefficient = await bll.GetAll(); + this.threelinkCoefficientViewModelBindingSource.DataSource = _AssetsThreelinkCoefficient; _ThreeLinkVmo = ThreeLinkVmo; var allCaliber = await new Yw.BLL.SysDictData().GetByTypeCode("1"); if (allCaliber != null) @@ -72,6 +78,70 @@ return true; } + //鏉愭枡閫夋嫨鍙樺寲浜嬩欢 + private void TextEditMaterial_SelectedIndexChanged(object sender, EventArgs e) + { + if (_AssetsThreelinkCoefficient == null) + return; + + var select = GetCoefficientByMaterial(TextEditMaterial.Text); + if (select == null) + { + this.TextEditMinorLoss.Text = string.Empty; + return; + } + this.TextEditMinorLoss.Text = select.MinorLoss.ToString(); + this.textEditRunThroughCoefficient.Text = select.RunThroughMinorLoss.ToString(); + this.textEditBranchThroughCoefficient.Text = select.BranchThroughMinorLoss.ToString(); + } + + //鍙e緞閫夋嫨鍙樺寲浜嬩欢 + private void TextEditCaliber_SelectedIndexChanged(object sender, EventArgs e) + { + if (_AssetsThreelinkCoefficient == null) + return; + if (double.TryParse(TextEditCaliber.Text, out double caliber)) + { + foreach (var item in _AssetsThreelinkCoefficient) + { + if (item.Caliber.HasValue) + { + if (Math.Abs(Convert.ToDouble(item.Caliber) - caliber) < 10) + { + this.TextEditMinorLoss.Text = item.MinorLoss.ToString(); + this.textEditRunThroughCoefficient.Text = item.RunThroughMinorLoss.ToString(); + this.textEditBranchThroughCoefficient.Text = item.BranchThroughMinorLoss.ToString(); + return; + } + } + } + } + } + + //鎵惧埌鏈�鐩歌繎鐨勬潗鏂� + private AssetsThreelinkCoefficientVmo GetCoefficientByMaterial(string name) + { + AssetsThreelinkCoefficientVmo select = null; + int maxMatchedChars = 0; + foreach (var item in _AssetsThreelinkCoefficient) + { + int matchedChars = GetIntersect(item.Material, name); + if (matchedChars > maxMatchedChars) + { + maxMatchedChars = matchedChars; + select = item; + return select; + } + } + return select; + } + + private int GetIntersect(string str1, string str2) + { + if (str1 == null || str2 == null) return 0; + return string.Join("", str1.Intersect(str2)).Count(); + } + //瀹屾垚 private async void BtnOk_ClickAsync(object sender, EventArgs e) { -- Gitblit v1.9.3