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