HRT_Help.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. using BaseLibRWFile;
  2. using Newtonsoft.Json;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.IO;
  6. using System.Linq;
  7. using System.Net.Http;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Forms;
  11. using static System.Windows.Forms.VisualStyles.VisualStyleElement.ListView;
  12. namespace HRT_Measure
  13. {
  14. public class HRT_Help
  15. {
  16. public static string strDataDirectoryNormal = @"D:\数据表\Normal";
  17. public static string strDataDirectoryAll = @"D:\数据表\All";
  18. public static List<string> listResultTitleNormal = new List<string>();
  19. public static List<string> listResultTitleAll = new List<string>();
  20. //public static event Action<int, int, bool, bool, bool,bool> eventDisplayResult;
  21. #region 结果数据存放
  22. public static List<double> dListCtl1_Channel1_Thickness = new List<double>();
  23. public static List<double> dListCtl1_Channel1_Flatness = new List<double>();
  24. public static List<double> dListCtl1_Channel1_Height = new List<double>();
  25. public static List<double> dListCtl1_Channel1_TopValue = new List<double>();
  26. public static List<double> dListCtl1_Channel1_BottomValue = new List<double>();
  27. public static List<double> dListCtl1_Channel1_ThicknessAll = new List<double>();
  28. public static List<double> dListCtl1_Channel1_Diff = new List<double>();
  29. public static List<double> dListCtl1_Channel2_Thickness = new List<double>();
  30. public static List<double> dListCtl1_Channel2_Flatness = new List<double>();
  31. public static List<double> dListCtl1_Channel2_Height = new List<double>();
  32. public static List<double> dListCtl1_Channel2_TopValue = new List<double>();
  33. public static List<double> dListCtl1_Channel2_BottomValue = new List<double>();
  34. public static List<double> dListCtl1_Channel2_ThicknessAll = new List<double>();
  35. public static List<double> dListCtl1_Channel2_Diff = new List<double>();
  36. public static List<double> dListCtl1_Channel3_Thickness = new List<double>();
  37. public static List<double> dListCtl1_Channel3_Flatness = new List<double>();
  38. public static List<double> dListCtl1_Channel3_Height = new List<double>();
  39. public static List<double> dListCtl1_Channel3_TopValue = new List<double>();
  40. public static List<double> dListCtl1_Channel3_BottomValue = new List<double>();
  41. public static List<double> dListCtl1_Channel3_ThicknessAll = new List<double>();
  42. public static List<double> dListCtl1_Channel3_Diff = new List<double>();
  43. public static List<double> dListCtl1_Channel4_Thickness = new List<double>();
  44. public static List<double> dListCtl1_Channel4_Flatness = new List<double>();
  45. public static List<double> dListCtl1_Channel4_Height = new List<double>();
  46. public static List<double> dListCtl1_Channel4_TopValue = new List<double>();
  47. public static List<double> dListCtl1_Channel4_BottomValue = new List<double>();
  48. public static List<double> dListCtl1_Channel4_ThicknessAll = new List<double>();
  49. public static List<double> dListCtl1_Channel4_Diff = new List<double>();
  50. public static List<double> dListCtl1_Channel5_Thickness = new List<double>();
  51. public static List<double> dListCtl1_Channel5_Flatness = new List<double>();
  52. public static List<double> dListCtl1_Channel5_Height = new List<double>();
  53. public static List<double> dListCtl1_Channel5_TopValue = new List<double>();
  54. public static List<double> dListCtl1_Channel5_BottomValue = new List<double>();
  55. public static List<double> dListCtl1_Channel5_ThicknessAll = new List<double>();
  56. public static List<double> dListCtl1_Channel5_Diff = new List<double>();
  57. public static List<double> dListCtl1_Channel6_Thickness = new List<double>();
  58. public static List<double> dListCtl1_Channel6_Flatness = new List<double>();
  59. public static List<double> dListCtl1_Channel6_Height = new List<double>();
  60. public static List<double> dListCtl1_Channel6_TopValue = new List<double>();
  61. public static List<double> dListCtl1_Channel6_BottomValue = new List<double>();
  62. public static List<double> dListCtl1_Channel6_ThicknessAll = new List<double>();
  63. public static List<double> dListCtl1_Channel6_Diff = new List<double>();
  64. public static List<double> dListCtl2_Channel1_Thickness = new List<double>();
  65. public static List<double> dListCtl2_Channel1_Flatness = new List<double>();
  66. public static List<double> dListCtl2_Channel1_Height = new List<double>();
  67. public static List<double> dListCtl2_Channel1_TopValue = new List<double>();
  68. public static List<double> dListCtl2_Channel1_BottomValue = new List<double>();
  69. public static List<double> dListCtl2_Channel1_ThicknessAll = new List<double>();
  70. public static List<double> dListCtl2_Channel1_Diff = new List<double>();
  71. public static List<double> dListCtl2_Channel2_Thickness = new List<double>();
  72. public static List<double> dListCtl2_Channel2_Flatness = new List<double>();
  73. public static List<double> dListCtl2_Channel2_Height = new List<double>();
  74. public static List<double> dListCtl2_Channel2_TopValue = new List<double>();
  75. public static List<double> dListCtl2_Channel2_BottomValue = new List<double>();
  76. public static List<double> dListCtl2_Channel2_ThicknessAll = new List<double>();
  77. public static List<double> dListCtl2_Channel2_Diff = new List<double>();
  78. public static List<double> dListCtl2_Channel3_Thickness = new List<double>();
  79. public static List<double> dListCtl2_Channel3_Flatness = new List<double>();
  80. public static List<double> dListCtl2_Channel3_Height = new List<double>();
  81. public static List<double> dListCtl2_Channel3_TopValue = new List<double>();
  82. public static List<double> dListCtl2_Channel3_BottomValue = new List<double>();
  83. public static List<double> dListCtl2_Channel3_ThicknessAll = new List<double>();
  84. public static List<double> dListCtl2_Channel3_Diff = new List<double>();
  85. public static List<double> dListCtl2_Channel4_Thickness = new List<double>();
  86. public static List<double> dListCtl2_Channel4_Flatness = new List<double>();
  87. public static List<double> dListCtl2_Channel4_Height = new List<double>();
  88. public static List<double> dListCtl2_Channel4_TopValue = new List<double>();
  89. public static List<double> dListCtl2_Channel4_BottomValue = new List<double>();
  90. public static List<double> dListCtl2_Channel4_ThicknessAll = new List<double>();
  91. public static List<double> dListCtl2_Channel4_Diff = new List<double>();
  92. public static List<double> dListCtl2_Channel5_Thickness = new List<double>();
  93. public static List<double> dListCtl2_Channel5_Flatness = new List<double>();
  94. public static List<double> dListCtl2_Channel5_Height = new List<double>();
  95. public static List<double> dListCtl2_Channel5_TopValue = new List<double>();
  96. public static List<double> dListCtl2_Channel5_BottomValue = new List<double>();
  97. public static List<double> dListCtl2_Channel5_ThicknessAll = new List<double>();
  98. public static List<double> dListCtl2_Channel5_Diff = new List<double>();
  99. public static List<double> dListCtl2_Channel6_Thickness = new List<double>();
  100. public static List<double> dListCtl2_Channel6_Flatness = new List<double>();
  101. public static List<double> dListCtl2_Channel6_Height = new List<double>();
  102. public static List<double> dListCtl2_Channel6_TopValue = new List<double>();
  103. public static List<double> dListCtl2_Channel6_BottomValue = new List<double>();
  104. public static List<double> dListCtl2_Channel6_ThicknessAll = new List<double>();
  105. public static List<double> dListCtl2_Channel6_Diff = new List<double>();
  106. #endregion
  107. /// <summary> mes 开始时间 </summary>
  108. public static string strBeginTime = "";
  109. /// <summary> mes 结束时间 </summary>
  110. public static string strEndTime = "";
  111. /// <summary> mes 总产量 </summary>
  112. public static int iTotalCount = 0;
  113. /// <summary> mes OK产量 </summary>
  114. public static int iOkCount = 0;
  115. /// <summary> mes NG产量 </summary>
  116. public static int iNgCount = 0;
  117. /// <summary> mes 不良信息统计 </summary>
  118. public static List<string> listNGInfo = new List<string>();
  119. public static void LoadResultTitle()
  120. {
  121. strDataDirectoryNormal += $"\\{ProgramHelp.Instance.ProConfig.当前料号}";
  122. strDataDirectoryAll += $"\\{ProgramHelp.Instance.ProConfig.当前料号}";
  123. listResultTitleNormal.Clear();
  124. listResultTitleAll.Clear();
  125. listResultTitleNormal.Add("产品编号");
  126. listResultTitleNormal.Add("产品号");
  127. listResultTitleNormal.Add("时间");
  128. listResultTitleAll.Add("产品编号");
  129. listResultTitleAll.Add("产品号");
  130. listResultTitleAll.Add("时间");
  131. //for (int i = 0; i < ProgramHelp.Instance.ProPara.厚度测量总数; i++)
  132. //{
  133. // listResultTitleAll.Add(ProgramHelp.Instance.ProPara.厚度测量名称[i]);
  134. // if (ProgramHelp.Instance.ProPara.厚度是否保存[i])
  135. // {
  136. // listResultTitleNormal.Add(ProgramHelp.Instance.ProPara.厚度测量名称[i]);
  137. // }
  138. //}
  139. listResultTitleNormal.Add("凹面平面度");
  140. listResultTitleNormal.Add("凸面平面度");
  141. listResultTitleAll.Add("凹面平面度");
  142. listResultTitleAll.Add("凸面平面度");
  143. //for (int i = 0; i < ProgramHelp.Instance.ProPara.高度测量总数; i++)
  144. //{
  145. // listResultTitleNormal.Add(ProgramHelp.Instance.ProPara.高度测量名称[i]);
  146. // listResultTitleAll.Add(ProgramHelp.Instance.ProPara.高度测量名称[i]);
  147. //}
  148. listResultTitleNormal.Add("左极差");
  149. listResultTitleAll.Add("左极差");
  150. listResultTitleNormal.Add("右极差");
  151. listResultTitleAll.Add("右极差");
  152. listResultTitleNormal.Add("左右极差");
  153. listResultTitleAll.Add("左右极差");
  154. listResultTitleNormal.Add("结果");
  155. listResultTitleAll.Add("结果");
  156. }
  157. public static object objSaveData = new object();
  158. public static void SaveDataToCsv(int index, List<string> listDataNormal, List<string> listDataAll)
  159. {
  160. lock (objSaveData)
  161. {
  162. try
  163. {
  164. if (!Directory.Exists(strDataDirectoryNormal))
  165. {
  166. Directory.CreateDirectory(strDataDirectoryNormal);
  167. }
  168. if (!Directory.Exists(strDataDirectoryAll))
  169. {
  170. Directory.CreateDirectory(strDataDirectoryAll);
  171. }
  172. string strDate = DateTime.Now.ToString("yyyy-MM-dd");
  173. //string strTime = DateTime.Now.ToString("HH:mm:ss");
  174. string pathNormal = strDataDirectoryNormal + $"\\{strDate}.csv";
  175. string pathAll = strDataDirectoryAll + $"\\{strDate}.csv";
  176. if (!File.Exists(pathNormal))
  177. {
  178. using (FileStream fs = new FileStream(pathNormal, FileMode.Append, FileAccess.Write))
  179. {
  180. using (StreamWriter sw = new StreamWriter(fs))
  181. {
  182. sw.WriteLine(string.Join(",", listResultTitleNormal.ToArray()));
  183. }
  184. }
  185. }
  186. if (!File.Exists(pathAll))
  187. {
  188. using (FileStream fs = new FileStream(pathAll, FileMode.Append, FileAccess.Write))
  189. {
  190. using (StreamWriter sw = new StreamWriter(fs))
  191. {
  192. sw.WriteLine(string.Join(",", listResultTitleAll.ToArray()));
  193. }
  194. }
  195. }
  196. using (FileStream fs = new FileStream(pathNormal, FileMode.Append, FileAccess.Write))
  197. {
  198. using (StreamWriter sw = new StreamWriter(fs))
  199. {
  200. sw.WriteLine(string.Join(",", listDataNormal.ToArray()));
  201. }
  202. }
  203. using (FileStream fs = new FileStream(pathAll, FileMode.Append, FileAccess.Write))
  204. {
  205. using (StreamWriter sw = new StreamWriter(fs))
  206. {
  207. sw.WriteLine(string.Join(",", listDataAll.ToArray()));
  208. }
  209. }
  210. }
  211. catch (Exception ex)
  212. {
  213. MessageBox.Show("写data报错!" + ex.ToString());
  214. }
  215. }
  216. }
  217. public static bool JudgeResult(double currentValue, double standartValue, double positiveValue, double negativeValue)
  218. {
  219. if (currentValue >= (standartValue - negativeValue) && currentValue <= (standartValue + positiveValue))
  220. {
  221. return true;
  222. }
  223. else
  224. {
  225. return false;
  226. }
  227. }
  228. public static void CalYield(bool isThicknessOK, bool isFlatnessOK, bool isHeightOK,bool isDiffOK)
  229. {
  230. iTotalCount++;
  231. if (isThicknessOK && isFlatnessOK && isHeightOK && isDiffOK)
  232. {
  233. iOkCount++;
  234. }
  235. else
  236. {
  237. iNgCount++;
  238. if (!isThicknessOK) listNGInfo.Add("厚度不良");
  239. if (!isFlatnessOK) listNGInfo.Add("平面度不良");
  240. if (!isHeightOK) listNGInfo.Add("高度不良");
  241. if(!isDiffOK) listNGInfo.Add("极差不良");
  242. }
  243. }
  244. public static object objCalResult = new object();
  245. public async Task UploadFileAsync(string url, string fileName)
  246. {
  247. using (var client = new HttpClient())
  248. {
  249. using (var content = new MultipartFormDataContent())
  250. {
  251. // 添加API密钥
  252. //content.Add(new StringContent("MachineCode"), ProgramHelp.Instance.ProConfig.机器编号);
  253. // 添加文件
  254. using (var fileStream = File.OpenRead(fileName))
  255. {
  256. var streamContent = new StreamContent(fileStream);
  257. var fileContent = new ByteArrayContent(await streamContent.ReadAsByteArrayAsync());
  258. fileContent.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("multipart/form-data");
  259. content.Add(fileContent, "file", Path.GetFileName(fileName));
  260. }
  261. var response = await client.PostAsync(url, content);
  262. response.EnsureSuccessStatusCode();
  263. }
  264. }
  265. }
  266. public static object objHalfGet = new object();
  267. }
  268. }