CNAS取数仪器端升级
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

HuiFenUIOperation.cs 9.3KB

4 月之前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. using CnasSynchronusClient;
  2. using CnasSynchrousModel;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Windows.Forms;
  8. namespace CNAS_BalanceClient
  9. {
  10. public class HuiFenUIOperation
  11. {
  12. /// <summary>
  13. /// 更改灰分数据
  14. /// </summary>
  15. /// <param name="dgvShuiFen"></param>
  16. /// <param name="balanceWeight"></param>
  17. /// <param name="laboratoryTests"></param>
  18. public void UpdateHuifenData(System.Windows.Forms.DataGridView dgvShuiFen, double balanceWeight, List<LaboratoryTest> laboratoryTests)
  19. {
  20. //更改内存值
  21. bool bIfUpdate = true;
  22. string strID = dgvShuiFen.Rows[dgvShuiFen.CurrentCell.RowIndex].Cells[0].Value.ToString();
  23. var query = laboratoryTests.Where(s => s.GUID == strID).ToList<LaboratoryTest>();
  24. if (query.Count == 1)
  25. {
  26. switch (dgvShuiFen.CurrentCell.ColumnIndex.ToString())
  27. {
  28. case "4": //空坩埚重
  29. query[0].Empty_Crucible_Weight = CalculateOperation.GetShowDoubleValueN4(balanceWeight);
  30. dgvShuiFen.CurrentRow.Cells[6].Value = CalculateOperation.GetShowDoubleValueN4(query[0].Empty_Crucible_Weight + query[0].Sample_Weight);
  31. break;
  32. case "5": //样重
  33. if (balanceWeight < 0.9 || balanceWeight > 1.1)
  34. {
  35. MessageBox.Show("样重范围是0.9g~1.1g", "提示");
  36. bIfUpdate = false;
  37. }
  38. else
  39. {
  40. query[0].Sample_Weight = CalculateOperation.GetShowDoubleValueN4(balanceWeight);
  41. dgvShuiFen.CurrentRow.Cells[6].Value = CalculateOperation.GetShowDoubleValueN4(query[0].Empty_Crucible_Weight + query[0].Sample_Weight);
  42. }
  43. break;
  44. case "6"://加样重
  45. //query[0].AddSample_Weight = balanceWeight;
  46. break;
  47. case "7"://烘干重
  48. if (query[0].AddSample_Weight != 0 && balanceWeight > query[0].AddSample_Weight)
  49. {
  50. MessageBox.Show("烘干重不能大于加样重,请调整后再传入。", "提示");
  51. bIfUpdate = false;
  52. }
  53. else
  54. {
  55. double oldvaue = query[0].BurningResidue_Weight;
  56. query[0].BurningResidue_Weight = CalculateOperation.GetShowDoubleValueN4(balanceWeight);
  57. if (!UpdateAshPercentColumn(dgvShuiFen, laboratoryTests, dgvShuiFen.CurrentCell.RowIndex))
  58. {
  59. query[0].BurningResidue_Weight = CalculateOperation.GetShowDoubleValueN4(oldvaue);
  60. bIfUpdate = false;
  61. }
  62. }
  63. break;
  64. case "8"://二次烘干重
  65. if (query[0].AddSample_Weight != 0 && balanceWeight > query[0].AddSample_Weight)
  66. {
  67. MessageBox.Show("烘干重不能大于加样重,请调整后再传入。", "提示");
  68. bIfUpdate = false;
  69. }
  70. else
  71. {
  72. double oldvaue = query[0].SecondBurningResidue_Weight;
  73. query[0].SecondBurningResidue_Weight = CalculateOperation.GetShowDoubleValueN4(balanceWeight);
  74. if (!UpdateAshPercentColumn(dgvShuiFen, laboratoryTests, dgvShuiFen.CurrentCell.RowIndex))
  75. {
  76. query[0].SecondBurningResidue_Weight = CalculateOperation.GetShowDoubleValueN4(oldvaue);
  77. bIfUpdate = false;
  78. }
  79. }
  80. break;
  81. case "9"://三次烘干重
  82. if (query[0].AddSample_Weight != 0 && balanceWeight > query[0].AddSample_Weight)
  83. {
  84. MessageBox.Show("烘干重不能大于加样重,请调整后再传入。", "提示");
  85. bIfUpdate = false;
  86. }
  87. else
  88. {
  89. double oldvaue = query[0].ThirdBurningResidue_Weight;
  90. query[0].ThirdBurningResidue_Weight = CalculateOperation.GetShowDoubleValueN4(balanceWeight);
  91. if (!UpdateAshPercentColumn(dgvShuiFen, laboratoryTests, dgvShuiFen.CurrentCell.RowIndex))
  92. {
  93. query[0].ThirdBurningResidue_Weight = CalculateOperation.GetShowDoubleValueN4(oldvaue);
  94. bIfUpdate = false;
  95. }
  96. }
  97. break;
  98. }
  99. if (bIfUpdate)
  100. {
  101. query[0].Operator = GlobalCommonOperation.strUserName;
  102. query[0].OperaDateTime = Convert.ToDateTime(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  103. if (query[0].OperationType == null || query[0].OperationType == "")
  104. query[0].OperationType = "update";
  105. //更改显示值
  106. dgvShuiFen.CurrentCell.Value = CalculateOperation.GetShowDoubleValueN4(balanceWeight);
  107. }
  108. }
  109. }
  110. /// <summary>
  111. /// 更改灰分百分比
  112. /// </summary>
  113. /// <param name="dgvShuiFen"></param>
  114. /// <param name="laboratoryTests"></param>
  115. public bool UpdateAshPercentColumn(DataGridView dgvHuiFen, List<LaboratoryTest> laboratoryTests, int CurrentRowIndex)
  116. {
  117. bool IfUpdate = true;
  118. string strID = dgvHuiFen.Rows[CurrentRowIndex].Cells[0].Value.ToString();
  119. var query = laboratoryTests.Where(s => s.GUID == strID).ToList<LaboratoryTest>();
  120. if (query.Count == 1)
  121. {
  122. double percentdouble = 0;
  123. if (query[0].Sample_Weight != 0 && query[0].AddSample_Weight != 0 && query[0].BurningResidue_Weight != 0)
  124. {
  125. string strMsg = "";
  126. if (query[0].SecondBurningResidue_Weight == 0)
  127. {
  128. percentdouble = CalculateOperation.CalculateDecrement(query[0].AddSample_Weight, new double[1] { query[0].BurningResidue_Weight });
  129. if (percentdouble > 100 || percentdouble < 0)
  130. {
  131. MessageBox.Show("百分比计算结果出错,请调整数据。", "提示");
  132. return false;
  133. }
  134. dgvHuiFen.Rows[CurrentRowIndex].Cells["DecrementValue2"].Value = percentdouble;
  135. }
  136. else if (query[0].ThirdBurningResidue_Weight == 0)
  137. {
  138. percentdouble = CalculateOperation.CalculateDecrement(query[0].AddSample_Weight, new double[2] { query[0].BurningResidue_Weight, query[0].SecondBurningResidue_Weight });
  139. if (percentdouble > 100 || percentdouble < 0)
  140. {
  141. MessageBox.Show("百分比计算结果出错,请调整数据。", "提示");
  142. return false;
  143. }
  144. dgvHuiFen.Rows[CurrentRowIndex].Cells["DecrementValue2"].Value = percentdouble;
  145. }
  146. else
  147. {
  148. percentdouble = CalculateOperation.CalculateDecrement(query[0].AddSample_Weight, new double[3] { query[0].BurningResidue_Weight, query[0].SecondBurningResidue_Weight, query[0].ThirdBurningResidue_Weight });
  149. if (percentdouble > 100 || percentdouble < 0)
  150. {
  151. MessageBox.Show("百分比计算结果出错,请调整数据。", "提示");
  152. return false;
  153. }
  154. dgvHuiFen.Rows[CurrentRowIndex].Cells["DecrementValue2"].Value = percentdouble;
  155. }
  156. percentdouble = CalculateOperation.CalculateAad(query[0].AddSample_Weight, query[0].Sample_Weight, new double[3] { query[0].BurningResidue_Weight, query[0].SecondBurningResidue_Weight, query[0].ThirdBurningResidue_Weight }, ref strMsg);
  157. if (percentdouble > 100 || percentdouble < 0)
  158. {
  159. MessageBox.Show("百分比计算结果出错,请调整数据。", "提示");
  160. return false;
  161. }
  162. dgvHuiFen.Rows[CurrentRowIndex].Cells["AAD"].Value = percentdouble;
  163. query[0].Aad = Convert.ToDouble(dgvHuiFen.Rows[CurrentRowIndex].Cells["AAD"].Value);
  164. query[0].DecrementValue = Convert.ToDouble(dgvHuiFen.Rows[CurrentRowIndex].Cells["DecrementValue2"].Value);
  165. }
  166. }
  167. return IfUpdate;
  168. }
  169. }
  170. }