Make_FuselageLabelPrintRFID.cs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  1. using System;
  2. using System.Data;
  3. using System.Drawing;
  4. using System.Text;
  5. using System.Windows.Forms;
  6. using UAS_MES_NEW.DataOperate;
  7. using UAS_MES_NEW.PublicMethod;
  8. using UAS_MES_NEW.Entity;
  9. using LabelManager2;
  10. using System.IO;
  11. using System.Threading;
  12. using UAS_MES_NEW.PublicForm;
  13. using Seagull.BarTender.Print;
  14. using DEV_HDL = System.UInt32;
  15. using LABEL_TEMP_HDL = System.UInt32;
  16. using System.Runtime.InteropServices;
  17. namespace UAS_MES_NEW.Make
  18. {
  19. public partial class Make_FuselageLabelPrintRFID : Form
  20. {
  21. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  22. public static extern UInt32 DSTP2x_Lib_Init(string pSzInitInfo, Int32 nInitInfoLen, StringBuilder pSzResult, ref int pResultLen);
  23. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  24. public static extern UInt32 DSTP2x_Lib_Clear();
  25. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  26. public static extern UInt32 DSTP2x_EnumDev(Int32 nEnumType, byte[] szEnumList, ref int pDevSize, ref int pDevNum);
  27. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  28. public static extern UInt32 DSTP2x_ConnEnumeratedDev(string szDevName, ref DEV_HDL pDevHdl);
  29. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  30. public static extern UInt32 DSTP2x_DisconnDev(DEV_HDL ullDevHdl);
  31. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  32. public static extern UInt32 DSTP2x_SetPrnEmulation(DEV_HDL ullDevHdl, Int32 nEmulation);
  33. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  34. public static extern UInt32 DSTP2x_SetImgDpi(DEV_HDL ullDevHdl, Int32 nDpi);
  35. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  36. public static extern UInt32 DSTP2x_LoadLabelTmpl(string szFileName, ref LABEL_TEMP_HDL pLTHdl);
  37. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  38. public static extern UInt32 DSTP2x_PrintTmpl(DEV_HDL ullDevHdl, LABEL_TEMP_HDL ullLTHdl, byte[] szOutFile, ref int pOutFileSize, byte[] szOutRFID, ref int pOutRFIDSize);
  39. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  40. public static extern UInt32 DSTP2x_DeleteTmpl(LABEL_TEMP_HDL ullLTHdl);
  41. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  42. public static extern UInt32 DSTP2x_SetTmplPrnMode(LABEL_TEMP_HDL ullLTHdl, Int32 nPrnMode);
  43. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  44. public static extern UInt32 DSTP2x_SetTmplPrnData(LABEL_TEMP_HDL ullLTHdl, string szElemID, string szActualData);
  45. [DllImport("lib/Win32/libDSThermal.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi)]
  46. public static extern UInt32 DSTP2x_SetTmplRFIDData(LABEL_TEMP_HDL ullLTHdl, string szElemID, string pActualData, Int32 nActualDataSize);
  47. DataHelper dh;
  48. DataTable dt;
  49. LogStringBuilder sql = new LogStringBuilder();
  50. Document doc;
  51. AutoSizeFormClass asc = new AutoSizeFormClass();
  52. //保存StepProduct查询出来的数据
  53. // DataTable ListA = new DataTable();
  54. //保存make left join makecraftdetail left join product的数据
  55. // DataTable ListB;
  56. DataTable mapB;
  57. string ma_unlimitin = "";
  58. ApplicationClass lbl;
  59. string oMakeCode = "";
  60. string oMsId = "";
  61. string oErrorMessage = "";
  62. bool pr_change = false;
  63. ftpOperater ftp;
  64. DataTable Dbfind;
  65. public Make_FuselageLabelPrintRFID()
  66. {
  67. InitializeComponent();
  68. }
  69. DEV_HDL uRet = 0;
  70. DEV_HDL dev_prt = 0;
  71. LABEL_TEMP_HDL tmp_prt = 0;
  72. byte[] pEnumList = new byte[1024];
  73. int enumListLen = 1024;
  74. byte[] szOutFile = new byte[1024];
  75. int pOutFileSize = 1024;
  76. byte[] szOutRFID = new byte[1024];
  77. int pOutRFIDSize = 1024;
  78. int deviceNum = 0;
  79. string device = "";
  80. StringBuilder pSzResult = new StringBuilder(256);
  81. int pResultLen = 256;
  82. private void Make_FuselageLabelPrint_Load(object sender, EventArgs e)
  83. {
  84. asc.controllInitializeSize(this);
  85. sncode.Focus();
  86. LockMakeCode.GetMakeCodeCtl(ma_code);
  87. ma_code.SetLockCheckBox(LockMakeCode);
  88. //工单号放大镜配置
  89. ma_code.TableName = "make left join product on ma_prodcode=pr_code";
  90. ma_code.SelectField = "ma_code # 工单号,ma_prodcode # 产品编号,pr_detail # 产品名称";
  91. ma_code.FormName = Name;
  92. ma_code.SetValueField = new string[] { "ma_code", "ma_prodcode", "pr_detail" };
  93. ma_code.DbChange += Ma_code_DbChange;
  94. ma_code.Condition = "(ma_statuscode='STARTED' or ma_statuscode='FINISH')";
  95. dh = SystemInf.dh;
  96. StepCount.StepCode = User.CurrentStepCode;
  97. StepCount.Source = User.UserSourceCode;
  98. StepCount.LineCode = User.UserLineCode;
  99. StepCount.Dh = dh;
  100. StepCount.Start();
  101. try
  102. {
  103. if (File.Exists("FugeLabel" + ".txt"))
  104. {
  105. File.Delete("FugeLabel" + ".txt");
  106. }
  107. StreamWriter sw = File.AppendText("FugeLabel" + ".txt");
  108. sw.WriteLine(sncode.Handle);
  109. sw.Close();
  110. }
  111. catch (Exception) { }
  112. //1.Initialize the Library.
  113. }
  114. private void Ma_code_DbChange(object sender, EventArgs e)
  115. {
  116. Dbfind = ma_code.ReturnData;
  117. BaseUtil.SetFormValue(this.Controls, Dbfind);
  118. ////获取工单的其他信息
  119. //sql.Clear();
  120. //sql.Append("select ma_code,nvl(mcd_okqty,0) mcd_okqty,ma_prodcode as pr_code ,pr_detail,");
  121. //sql.Append("pr_spec,ma_qty - nvl(mcd_inqty, 0) mcd_remainqty from make left join makecraftdetail on ");
  122. //sql.Append("mcd_maid=ma_id left join product on pr_code=ma_prodcode where ma_code='" + ma_code.Text + "' and mcd_stepcode='" + User.CurrentStepCode + "'");
  123. //dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  124. //if (dt.Rows.Count > 0)
  125. //{
  126. // BaseUtil.SetFormValue(this.Controls, dt);
  127. //}
  128. }
  129. private void sn_code_KeyDown(object sender, KeyEventArgs e)
  130. {
  131. //按下enter键
  132. if (e.KeyCode == Keys.Enter)
  133. {
  134. //如果输入的值为空的话,提示不能为空
  135. if (sncode.Text == "")
  136. {
  137. OperateResult.AppendText(">>序列号不能为空\n", Color.Red);
  138. return;
  139. }
  140. if (LogicHandler.CheckStepAttribute(Tag.ToString(), User.UserSourceCode, out oErrorMessage))
  141. {
  142. //定义临时变量
  143. dt = (DataTable)dh.ExecuteSql("select ms_sncode from makeserial where ms_code='" + sncode.Text + "' order by ms_id desc", "select");
  144. if (dt.Rows.Count > 0)
  145. {
  146. sncode.Text = dt.Rows[0]["ms_sncode"].ToString();
  147. }
  148. string oStatus = "";
  149. //调用公共方法CheckStepSNAndMacode判断工序是否正确
  150. string status = "";
  151. LogicHandler.GetMakeInfo(sncode.Text, out oMakeCode, out status, out oErrorMessage);
  152. if (oMakeCode == "" || oMakeCode == null)
  153. oMakeCode = ma_code.Text;
  154. if (LogicHandler.CheckStepSNAndMacode(oMakeCode, User.UserSourceCode, sncode.Text, User.UserCode, out oMakeCode, out oMsId, out oErrorMessage))
  155. {
  156. string nextstepcode = dh.getFieldDataByCondition("makeserial", "ms_nextstepcode", "ms_id='" + oMsId + "'").ToString();
  157. if (nextstepcode != User.CurrentStepCode)
  158. {
  159. string stname = dh.getFieldDataByCondition("step", "st_name", "st_code='" + nextstepcode + "'").ToString();
  160. OperateResult.AppendText("<<序列号:" + sncode.Text + "下一工序是" + stname + ",不是当前岗位的工序\n", Color.Red, sncode);
  161. return;
  162. }
  163. //IF (如果ma_code 为空)THEN
  164. if (ma_code.Text == "" || ma_code.Text != oMakeCode)
  165. {
  166. //获取工单的其他信息
  167. sql.Clear();
  168. sql.Append("select ma_code,nvl(mcd_okqty,0),ma_prodcode,pr_detail,nvl(ma_unlimitin,0)ma_unlimitin,");
  169. sql.Append("pr_spec,ma_qty - nvl(mcd_inqty, 0) mcd_remainqty from make left join makecraftdetail on ");
  170. sql.Append("mcd_maid=ma_id left join product on pr_code=ma_prodcode where ma_code='" + oMakeCode + "' and mcd_stepcode='" + User.CurrentStepCode + "'");
  171. mapB = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  172. //如果有数据的话
  173. if (mapB.Rows.Count > 0)
  174. {
  175. ma_unlimitin = mapB.Rows[0]["ma_unlimitin"].ToString();
  176. //将工单的其他信息赋值到对应的控件
  177. BaseUtil.SetFormValue(this.Controls, mapB);
  178. //提示用户“<<工单号:取ma_makecode”
  179. OperateResult.AppendText("<<工单号:" + ma_code.Text + "\n", Color.Black);
  180. //提示用户“<< 序列号:XXXX”
  181. }
  182. //没有数据
  183. else
  184. {
  185. OperateResult.AppendText(">>无序列号" + sncode.Text + "对应工单信息\n", Color.Red);
  186. return;
  187. }
  188. }
  189. //所选标签不为空
  190. if (PrintLabel.SelectedValue != null)
  191. {
  192. //如果打印张数为空,返回
  193. if (PrintNum.Text == "" || int.Parse(PrintNum.Text) == 0)
  194. {
  195. OperateResult.AppendText(">>打印张数不可空或者为0\n", Color.Red, sncode);
  196. //清空输入框的值,聚焦
  197. sncode.Focus();
  198. //提示用户“>>请输入SN”
  199. OperateResult.AppendText(">>请输入SN\n", Color.Black);
  200. return;
  201. }
  202. OperateResult.AppendText("<<序列号:" + sncode.Text + "\n", Color.Black);
  203. //按照打印张数打印
  204. //doc = lbl.Documents.Open(PrintLabel.Text);
  205. string tmpPath = PrintLabel.Text;
  206. uRet = DSTP2x_Lib_Init("", 0, pSzResult, ref pResultLen);
  207. if (uRet != 0)
  208. {
  209. OperateResult.AppendText("DSTP2x_Lib_Init,error code:[" + uRet.ToString() + "]");
  210. return;
  211. }
  212. uRet = DSTP2x_EnumDev(1, pEnumList, ref enumListLen, ref deviceNum); //USB connection
  213. if (uRet != 0)
  214. {
  215. OperateResult.AppendText("Enumerate device error,error code:[" + uRet.ToString() + "]");
  216. goto SAMPLE_END;
  217. }
  218. if (deviceNum > 1)
  219. {
  220. string str = Encoding.UTF8.GetString(pEnumList, 0, enumListLen);
  221. string[] enumList = str.Split(new[] { '\n' }, StringSplitOptions.RemoveEmptyEntries);
  222. device = enumList[0];
  223. }
  224. else if (deviceNum == 1)
  225. device = Encoding.UTF8.GetString(pEnumList, 0, enumListLen);
  226. else
  227. {
  228. OperateResult.AppendText("No device");
  229. goto SAMPLE_END;
  230. }
  231. //3.Connect the device.
  232. uRet = DSTP2x_ConnEnumeratedDev(device, ref dev_prt);
  233. if (uRet != 0)
  234. {
  235. OperateResult.AppendText("Failed to connect device,error code:[" + uRet.ToString() + "]");
  236. goto SAMPLE_END;
  237. }
  238. //Non essential interface. 1-ZPL, 2-TSPL, 3-ESCPOS
  239. uRet = DSTP2x_SetPrnEmulation(dev_prt, 1); //ZPL
  240. if (uRet != 0)
  241. {
  242. OperateResult.AppendText("Failed to set up print simulation,error code:[" + uRet.ToString() + "]");
  243. goto SAMPLE_END;
  244. }
  245. //4.Load the template.
  246. uRet = DSTP2x_LoadLabelTmpl(tmpPath, ref tmp_prt);
  247. if (uRet != 0)
  248. {
  249. OperateResult.AppendText("Failed to load label template,error code:[" + uRet.ToString() + "]");
  250. goto SAMPLE_END;
  251. }
  252. //5.Set the print mode. 0-print, 1-generate the prn file, 2-generate the preview image.
  253. uRet = DSTP2x_SetTmplPrnMode(tmp_prt, 0); //set print mode
  254. if (uRet != 0)
  255. {
  256. OperateResult.AppendText("Setting whether to print failed,error code:[" + uRet.ToString() + "]");
  257. goto SAMPLE_END;
  258. }
  259. //6.Set the print data.
  260. uRet = DSTP2x_SetTmplPrnData(tmp_prt, "Text-01", sncode.Text);
  261. uRet = DSTP2x_SetTmplPrnData(tmp_prt, "Text-02", sncode.Text); //The data must be utf-8
  262. if (uRet != 0)
  263. {
  264. OperateResult.AppendText("Failed to set someone data in template,error code:[" + uRet.ToString() + "]");
  265. goto SAMPLE_END;
  266. }
  267. //7.Set the RFID data.
  268. uRet = DSTP2x_SetTmplRFIDData(tmp_prt, "EPC-01", Hex.Checked ? AsciiToHex(sncode.Text) : sncode.Text, Hex.Checked ? AsciiToHex(sncode.Text).Length : sncode.Text.Length);
  269. if (uRet != 0)
  270. {
  271. OperateResult.AppendText("Failed to set EPC data in template,error code:[" + uRet.ToString() + "]");
  272. goto SAMPLE_END;
  273. }
  274. //uRet = DSTP2x_SetTmplRFIDData(tmp_prt, "USER-01", "123ABC", "123ABC".Length);
  275. //if (uRet != 0)
  276. //{
  277. // OperateResult.AppendText("Failed to set USER data in template,error code:[" + uRet.ToString() + "]");
  278. // goto SAMPLE_END;
  279. //}
  280. //8.Print template and get the RFID data.
  281. uRet = DSTP2x_PrintTmpl(dev_prt, tmp_prt, szOutFile, ref pOutFileSize, szOutRFID, ref pOutRFIDSize);
  282. if (uRet != 0)
  283. {
  284. OperateResult.AppendText("Print template failed,error code:[" + uRet.ToString() + "]");
  285. goto SAMPLE_END;
  286. }
  287. OperateResult.AppendText("The RFID data is " + Encoding.UTF8.GetString(szOutRFID, 0, pOutRFIDSize));
  288. //9.Delete the handle of template.
  289. uRet = DSTP2x_DeleteTmpl(tmp_prt);
  290. if (uRet != 0)
  291. {
  292. OperateResult.AppendText("Delete handle of template failed,error code:[" + uRet.ToString() + "]");
  293. goto SAMPLE_END;
  294. }
  295. //10.Disconnect the device.
  296. uRet = DSTP2x_DisconnDev(dev_prt);
  297. if (uRet != 0)
  298. {
  299. OperateResult.AppendText("Delete handle of device failed,error code:[" + uRet.ToString() + "]");
  300. goto SAMPLE_END;
  301. }
  302. SAMPLE_END:
  303. {
  304. uRet = DSTP2x_Lib_Clear();
  305. }
  306. //记录日志
  307. LogicHandler.DoCommandLog(Tag.ToString(), User.UserCode, oMakeCode, User.UserLineCode, User.UserSourceCode, "RFID打印", "RFID打印成功", sncode.Text, "");
  308. //更新打印的数据
  309. if (LogicHandler.SetStepResult(ma_code.Text, User.UserSourceCode, sncode.Text, "RFID打印", "RFID打印成功", User.UserCode, out oErrorMessage))
  310. {
  311. //提示正确返回时传递的信息
  312. if (oErrorMessage.Contains("AFTERSUCCESS"))
  313. OperateResult.AppendText(">>" + oErrorMessage + "\n");
  314. if (CollectRemark.Checked && Remark.Text != "")
  315. {
  316. LogicHandler.CollectRemarkInf(sncode.Text, "", "", oMakeCode, ma_prodcode.Text, Remark.Text);
  317. }
  318. //清空输入框的值,聚焦
  319. sncode.Text = "";
  320. sncode.Focus();
  321. //刷新打印数量和剩余数量
  322. dt = (DataTable)dh.ExecuteSql("select ma_qty - nvl(mcd_inqty, 0) mcd_remainqty,nvl(ma_unlimitin,0)ma_unlimitin from make left join makecraftdetail on mcd_macode=ma_code where ma_code='" + ma_code.Text + "' and mcd_stepcode='" + User.CurrentStepCode + "'", "select");
  323. BaseUtil.SetFormValue(Controls, dt);
  324. mcd_okqty.Text = int.Parse(mcd_okqty.Text) + 1 + "";
  325. //IF 剩余数=0,则清空form中的数据, 提示用户“工单:xx已经打印完成,>>请输入SN”, 清空mapB,listC 中的数据
  326. if (int.Parse(mcd_remainqty.Text) == 0 && ma_unlimitin == "0")
  327. {
  328. OperateResult.AppendText(">>工单:" + ma_code.Text + "打印完成,>>请输入SN\n", Color.Green);
  329. }
  330. //剩余数量不为0
  331. else
  332. {
  333. OperateResult.AppendText(">>请输入SN\n", Color.Black);
  334. }
  335. }
  336. else
  337. {
  338. OperateResult.AppendText(">>" + oErrorMessage + "\n", Color.Red, sncode);
  339. //清空输入框的值,聚焦
  340. sncode.Text = "";
  341. sncode.Focus();
  342. }
  343. }
  344. //标签为空
  345. else
  346. {
  347. OperateResult.AppendText(">>产品编号:" + ma_prodcode.Text + "未维护RFID签\n", Color.Red, sncode);
  348. }
  349. }
  350. else
  351. {
  352. OperateResult.AppendText(">>" + oErrorMessage + "\n", Color.Red, sncode);
  353. }
  354. }
  355. else
  356. {
  357. OperateResult.AppendText(">>" + oErrorMessage + "\n", Color.Red, sncode);
  358. }
  359. }
  360. }
  361. static string AsciiToHex(string asciiString)
  362. {
  363. byte[] bytes = Encoding.ASCII.GetBytes(asciiString);
  364. return BitConverter.ToString(bytes).Replace("-", "").ToLower();
  365. }
  366. private void pr_code_TextChanged(object sender, EventArgs e)
  367. {
  368. DataTable dt = (DataTable)dh.ExecuteSql("select la_id,la_url,la_isdefault from label where la_prodcode='" + ma_prodcode.Text + "' and la_templatetype='RFID' and la_statuscode='AUDITED' order by la_isdefault", "select");
  369. if (dt.Rows.Count == 0)
  370. {
  371. dt = (DataTable)dh.ExecuteSql("select la_id,la_url,la_isdefault from label where la_prodcode is null and la_templatetype='RFID' and la_statuscode='AUDITED' order by la_isdefault", "select");
  372. }
  373. PrintLabel.DataSource = dt;
  374. PrintLabel.DisplayMember = "la_url";
  375. PrintLabel.ValueMember = "la_id";
  376. pr_change = true;
  377. }
  378. private void Make_FuselageLabelPrint_Activated(object sender, EventArgs e)
  379. {
  380. sncode.Focus();
  381. }
  382. private void Make_FuselageLabelPrint_FormClosing(object sender, FormClosingEventArgs e)
  383. {
  384. BaseUtil.ClosePrint(lbl);
  385. }
  386. private void Make_FuselageLabelPrint_SizeChanged(object sender, EventArgs e)
  387. {
  388. asc.controlAutoSize(this);
  389. }
  390. private void PrintLabel_SelectedValueChanged(object sender, EventArgs e)
  391. {
  392. if (PrintLabel.SelectedValue != null && PrintLabel.SelectedValue.ToString() != "System.Data.DataRowView")
  393. {
  394. string PrintNums = dh.getFieldDataByCondition("label", "la_printnos", "la_id='" + PrintLabel.SelectedValue.ToString() + "'").ToString();
  395. PrintNum.Text = (PrintNums == "" ? "1" : PrintNums);
  396. }
  397. }
  398. private void StepCount_Load(object sender, EventArgs e)
  399. {
  400. }
  401. }
  402. }