Ioss110WidReader.cs 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. using Aitex.Common.Util;
  2. using Aitex.Core.Common;
  3. using Aitex.Core.RT.Event;
  4. using Aitex.Core.RT.Log;
  5. using Aitex.Core.RT.SCCore;
  6. using MECF.Framework.Common.Communications;
  7. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.OcrReaders;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.IO;
  11. using System.Linq;
  12. using System.Text;
  13. using System.Text.RegularExpressions;
  14. using System.Threading.Tasks;
  15. namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.OcrReaders.IOSS
  16. {
  17. public class Ioss110WidReader : OCRReaderBaseDevice, IConnection
  18. {
  19. public Ioss110WidReader(string module, string name, string scRoot) : base(module, name)
  20. {
  21. _scRoot = scRoot;
  22. CheckToPostMessage((int)OCRReaderMsg.StartInit, null);
  23. }
  24. private string libVers = "";
  25. private string parVers = "";
  26. private void InitIoss()
  27. {
  28. JobFileList = new List<string>();
  29. lib = new Wid110LibV7();
  30. Address = SC.GetStringValue($"{_scRoot}.{Name}.Address");
  31. _enableLog = SC.GetValue<bool>($"{_scRoot}.{Name}.EnableLogMessage");
  32. if (!isValidIP(Address))
  33. {
  34. EV.PostAlarmLog("System", $"Invalid IP address for WIDReader:{Name}");
  35. return;
  36. }
  37. if (!lib.FInit(Address))
  38. {
  39. EV.PostAlarmLog("System", $"WIDReader:{Name} initialize failed");
  40. int eno = Wid110LibConst.ecNotInit;
  41. eno = lib.FGetLastError();
  42. if (lib.isException())
  43. LOG.Write("getLastError(): EXCEPTION\r\n" + lib.getLastExcp());
  44. LOG.Write("getLastError(): return " + eno);
  45. return;
  46. }
  47. libVers = lib.FGetVersion();
  48. parVers = lib.FGetVersionParam();
  49. var fileInfo = new FileInfo(PathManager.GetDirectory($"Logs\\{Name}"));
  50. if (fileInfo.Directory != null && !fileInfo.Directory.Exists)
  51. fileInfo.Directory.Create();
  52. if (fileInfo.Directory != null)
  53. _imageStorePath = fileInfo.FullName;
  54. EV.PostInfoLog("System", $"WIDReader:{Name} initialize successful");
  55. IsConnected = true;
  56. }
  57. private string _imageStorePath;
  58. private bool isValidIP(string ip)
  59. {
  60. char[] sep = { '.' };
  61. string[] adr = ip.Split(sep);
  62. try
  63. {
  64. return (isValidIPPart(Convert.ToInt32(adr[0]))
  65. && isValidIPPart(Convert.ToInt32(adr[1]))
  66. && isValidIPPart(Convert.ToInt32(adr[2]))
  67. && isValidIPPart(Convert.ToInt32(adr[3])));
  68. }
  69. catch (Exception e)
  70. {
  71. LOG.Write("isValidIP( " + ip + " )\r\n"
  72. + "ERROR: Invalid IP Address\r\n"
  73. + e.ToString());
  74. return false;
  75. }
  76. }
  77. private bool isValidIPPart(int adr)
  78. {
  79. return (adr >= 0 && adr <= 255);
  80. }
  81. private Wid110LibV7 lib;
  82. private string _scRoot;
  83. public string Address { get; private set; }
  84. private bool _enableLog;
  85. public bool IsConnected { get; set; }
  86. protected override bool fStartSavePicture(object[] param)
  87. {
  88. return true;
  89. }
  90. protected override bool fStartReset(object[] param)
  91. {
  92. Address = SC.GetStringValue($"{_scRoot}.{Name}.Address");
  93. _enableLog = SC.GetValue<bool>($"{_scRoot}.{Name}.EnableLogMessage");
  94. if (!isValidIP(Address))
  95. {
  96. EV.PostAlarmLog("System", $"Invalid IP address for WIDReader:{Name}");
  97. return false;
  98. }
  99. if (IsConnected)
  100. lib.FExit();
  101. if (!lib.FInit(Address))
  102. {
  103. EV.PostAlarmLog("System", $"WIDReader:{Name} initialize address:{Address} failed");
  104. int eno = Wid110LibConst.ecNotInit;
  105. eno = lib.FGetLastError();
  106. if (lib.isException())
  107. LOG.Write("getLastError(): EXCEPTION\r\n" + lib.getLastExcp());
  108. LOG.Write("getLastError(): return " + eno);
  109. return false;
  110. }
  111. EV.PostInfoLog("System", $"WIDReader:{Name} initialize successful");
  112. IsConnected = true;
  113. return true; ;
  114. }
  115. protected override bool fStartInit(object[] param)
  116. {
  117. InitIoss();
  118. return true;
  119. }
  120. protected override bool fMonitorInit(object[] param)
  121. {
  122. return true;
  123. }
  124. protected override bool fStartSetParameter(object[] param)
  125. {
  126. return true;
  127. }
  128. private string m_readparameter;
  129. protected override bool fStartReadParameter(object[] param)
  130. {
  131. m_readparameter = param[0].ToString();
  132. switch (m_readparameter)
  133. {
  134. case "JobList":
  135. if (SC.ContainsItem($"{ _scRoot}.{ Name}.DirectoryForJob") && !string.IsNullOrEmpty(SC.GetStringValue($"{ _scRoot}.{ Name}.DirectoryForJob")))
  136. {
  137. string jobpath = SC.GetStringValue($"{ _scRoot}.{ Name}.DirectoryForJob");
  138. string[] files = Directory.GetFiles(jobpath);
  139. JobFileList = new List<string>();
  140. JobFileList.Clear();
  141. foreach (string strfile in files)
  142. {
  143. FileInfo f = new FileInfo(strfile);
  144. if (f.Extension == ".job" || f.Extension == ".wid")
  145. {
  146. JobFileList.Add(f.Name);
  147. }
  148. }
  149. }
  150. break;
  151. default:
  152. break;
  153. }
  154. return true; ;
  155. }
  156. protected override bool fMonitorReadParameter(object[] param)
  157. {
  158. return true;
  159. }
  160. protected override bool fStartReadWaferID(object[] param)
  161. {
  162. string job = param[0].ToString();
  163. int lasermarkindex = (int)param[1];
  164. IsReadLaserMark1 = lasermarkindex == 0;
  165. string path = SC.GetStringValue($"{ _scRoot}.{ Name}.DirectoryForJob");
  166. if (!lib.FLoadRecipes(path, job))
  167. {
  168. string le = lib.FGetErrorDescription(lib.FGetLastError());
  169. OnError("Load job failed:" + le);
  170. return false;
  171. }
  172. if (!lib.FProcessRead())
  173. {
  174. string le = lib.FGetErrorDescription(lib.FGetLastError());
  175. OnError("Read laser mark failed:" + le);
  176. return false;
  177. }
  178. return true;
  179. //return lib.FGetWaferId();
  180. }
  181. protected override bool fMonitorReading(object[] param)
  182. {
  183. CurrentLaserMark = lib.FGetWaferId().Replace("READ:", "").Trim();
  184. if (CurrentLaserMark.Length > KeepLaserMarkCharatersNumber)
  185. {
  186. CurrentLaserMark = CurrentLaserMark.Substring(0, KeepLaserMarkCharatersNumber);
  187. }
  188. if (IsReadLaserMark1)
  189. {
  190. LaserMark1 = CurrentLaserMark;
  191. LaserMark1Score = lib.FGetCodeQualityOCR().ToString();
  192. LaserMark1ReadTime = lib.FGetCodeTime().ToString();
  193. LaserMark1ReadResult = $"ID:{LaserMark1},Score:{LaserMark1Score},Read time:{LaserMark1ReadTime}";
  194. }
  195. else
  196. {
  197. LaserMark2 = CurrentLaserMark;
  198. LaserMark2 = CurrentLaserMark;
  199. LaserMark2Score = lib.FGetCodeQualityOCR().ToString();
  200. LaserMark2ReadTime = lib.FGetCodeTime().ToString();
  201. LaserMark2ReadResult = $"ID:{LaserMark2},Score:{LaserMark2Score},Read time:{LaserMark2ReadTime}";
  202. }
  203. GetProcessImage();
  204. IsBusy = false;
  205. return true;
  206. }
  207. private void GetProcessImage(int bestOrAll = 0)
  208. {
  209. if (!lib.FIsInitialized())
  210. {
  211. string errMsg;
  212. int errorNo = lib.getErrno();
  213. errMsg = lib.FGetErrorDescription(errorNo);
  214. OnError("ERROR: " + errMsg);
  215. return;
  216. }
  217. //try
  218. //{
  219. // if (File.Exists(CurrentImageFileName))
  220. // File.Delete(CurrentImageFileName);
  221. //}
  222. //catch (Exception ex) { LOG.Write(ex); }
  223. if (!lib.FProcessGetImage(CurrentImageFileName, bestOrAll))
  224. {
  225. if (lib.getErrno() == Wid110LibConst.ecNoMoreImg)
  226. {
  227. EV.PostInfoLog("WIDReader", "1 image retrieved after last process trigger.");
  228. return;
  229. }
  230. int errorNo = lib.getErrno();
  231. string errMsg = lib.FGetErrorDescription(errorNo);
  232. OnError("ERROR: " + errMsg);
  233. }
  234. }
  235. public override string[] GetJobFileList()
  236. {
  237. return JobFileList.ToArray();
  238. }
  239. public bool Connect()
  240. {
  241. return lib.FInit(Address);
  242. }
  243. public bool Disconnect()
  244. {
  245. return lib.FExit();
  246. }
  247. public override void Terminate()
  248. {
  249. try
  250. {
  251. if (!lib.FExit())
  252. {
  253. LOG.Write(lib.FGetErrorDescription(lib.FGetLastError()));
  254. }
  255. }
  256. catch (Exception ex)
  257. {
  258. LOG.Write(ex);
  259. }
  260. }
  261. }
  262. }