Query_SN.cs 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. using Seagull.BarTender.Print;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.Drawing.Printing;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Text.RegularExpressions;
  11. using System.Windows.Forms;
  12. using UAS_MES_NEW.DataOperate;
  13. using UAS_MES_NEW.Entity;
  14. using UAS_MES_NEW.PublicMethod;
  15. using UAS_MES_NEW.Query;
  16. using static System.Runtime.CompilerServices.RuntimeHelpers;
  17. namespace UAS_MES_NEW.Query
  18. {
  19. public partial class Query_SN : Form
  20. {
  21. int serialnum = 0;
  22. //客户的流水号
  23. int custserialnum = 0;
  24. Engine engine = new Engine();
  25. LabelFormatDocument format;
  26. DataHelper dh = SystemInf.dh;
  27. DataTable Dbfind;
  28. public Query_SN()
  29. {
  30. InitializeComponent();
  31. }
  32. private void PrintTest_Click(object sender, EventArgs e)
  33. {
  34. PrintDocument print = new PrintDocument();
  35. print.PrinterSettings.PrinterName = PrinterList.Text;
  36. print.PrintPage += Print_PrintPage;
  37. print.Print();
  38. }
  39. private void Print_PrintPage(object sender, PrintPageEventArgs e)
  40. {
  41. Graphics g = e.Graphics;
  42. float leftMargin = 10f; //左边距
  43. SolidBrush myBrush = new SolidBrush(Color.Black);//刷子
  44. float yPosition = 5f;//行定位
  45. Font printFont = new Font("微软雅黑", 20f, FontStyle.Bold);//设置字体
  46. yPosition += printFont.GetHeight(g);//另起一行
  47. g.DrawString("成功连接此打印机", printFont, myBrush, leftMargin, yPosition, new StringFormat());
  48. }
  49. private void Setting_Click(object sender, EventArgs e)
  50. {
  51. PrintDialog printd = new PrintDialog();
  52. printd.PrinterSettings.PrinterName = PrinterList.Text;
  53. printd.ShowDialog();
  54. }
  55. private void Export_Click(object sender, EventArgs e)
  56. {
  57. if (!dh.CheckExist("make", "ma_code='" + ma_code.Text + "'"))
  58. {
  59. MessageBox.Show("工单号不存在");
  60. return;
  61. }
  62. DataTable dt = (DataTable)dh.ExecuteSql("select msl_sncode from makesnlist where msl_makecode='" + ma_code.Text + "'", "select");
  63. if (dt.Rows.Count == 0)
  64. {
  65. MessageBox.Show("工单号未生成SN");
  66. return;
  67. }
  68. if (OneColumn.Checked)
  69. {
  70. format = engine.Documents.Open(Application.StartupPath + "/单排.btw");
  71. for (int i = 0; i < dt.Rows.Count; i = i + 1)
  72. {
  73. int temp = i;
  74. for (int j = 0; j < format.SubStrings.Count; j++)
  75. {
  76. switch (format.SubStrings[j].Name)
  77. {
  78. case "SN":
  79. format.SubStrings[j].Value = dt.Rows[i]["msl_sncode"].ToString();
  80. break;
  81. default:
  82. break;
  83. }
  84. }
  85. format.PrintSetup.PrinterName = PrinterList.Text;
  86. format.PrintSetup.IdenticalCopiesOfLabel = 1;
  87. format.Print();
  88. }
  89. }
  90. if (TwoColumn.Checked)
  91. {
  92. format = engine.Documents.Open(Application.StartupPath + "/双排.btw");
  93. for (int i = 0; i < dt.Rows.Count; i = i + 2)
  94. {
  95. int temp = i;
  96. for (int j = 0; j < format.SubStrings.Count; j++)
  97. {
  98. switch (format.SubStrings[j].Name)
  99. {
  100. case "SN":
  101. format.SubStrings[j].Value = dt.Rows[i]["msl_sncode"].ToString();
  102. break;
  103. case "SN2":
  104. format.SubStrings[j].Value = dt.Rows[i + 1]["msl_sncode"].ToString();
  105. break;
  106. default:
  107. break;
  108. }
  109. }
  110. format.PrintSetup.PrinterName = PrinterList.Text;
  111. format.PrintSetup.IdenticalCopiesOfLabel = 1;
  112. format.Print();
  113. }
  114. }
  115. if (ThreeColumn.Checked)
  116. {
  117. format = engine.Documents.Open(Application.StartupPath + "/Label.btw");
  118. for (int i = 0; i < dt.Rows.Count; i = i + 3)
  119. {
  120. int temp = i;
  121. for (int j = 0; j < format.SubStrings.Count; j++)
  122. {
  123. switch (format.SubStrings[j].Name)
  124. {
  125. case "SN":
  126. format.SubStrings[j].Value = dt.Rows[i]["msl_sncode"].ToString();
  127. break;
  128. case "SN2":
  129. format.SubStrings[j].Value = dt.Rows[i + 1]["msl_sncode"].ToString();
  130. break;
  131. case "SN3":
  132. format.SubStrings[j].Value = dt.Rows[i + 2]["msl_sncode"].ToString();
  133. break;
  134. default:
  135. break;
  136. }
  137. }
  138. format.PrintSetup.PrinterName = PrinterList.Text;
  139. format.PrintSetup.IdenticalCopiesOfLabel = 1;
  140. format.Print();
  141. }
  142. }
  143. if (FourColumn.Checked)
  144. {
  145. format = engine.Documents.Open(Application.StartupPath + "/四排.btw");
  146. for (int i = 0; i < dt.Rows.Count; i = i + 4)
  147. {
  148. int temp = i;
  149. for (int j = 0; j < format.SubStrings.Count; j++)
  150. {
  151. switch (format.SubStrings[j].Name)
  152. {
  153. case "SN":
  154. format.SubStrings[j].Value = dt.Rows[i]["msl_sncode"].ToString();
  155. break;
  156. case "SN2":
  157. format.SubStrings[j].Value = dt.Rows[i + 1]["msl_sncode"].ToString();
  158. break;
  159. case "SN3":
  160. format.SubStrings[j].Value = dt.Rows[i + 2]["msl_sncode"].ToString();
  161. break;
  162. case "SN4":
  163. format.SubStrings[j].Value = dt.Rows[i + 3]["msl_sncode"].ToString();
  164. break;
  165. default:
  166. break;
  167. }
  168. }
  169. format.PrintSetup.PrinterName = PrinterList.Text;
  170. format.PrintSetup.IdenticalCopiesOfLabel = 1;
  171. format.Print();
  172. }
  173. }
  174. }
  175. public string BarcodeMethod1(string Prefix, string Suffix, int Index, int Length, int radix)
  176. {
  177. string str = Prefix;
  178. //如果是流水则需要在前面加0
  179. string serialcode = BaseUtil.DToAny(custserialnum, radix);
  180. for (int j = serialcode.ToString().Length; j < Length; j++)
  181. {
  182. serialcode = "0" + serialcode;
  183. }
  184. str += serialcode;
  185. str += Suffix;
  186. custserialnum = custserialnum + 1;
  187. return str;
  188. }
  189. private static string lpad(int length, string number)
  190. {
  191. while (number.Length < length)
  192. {
  193. number = "0" + number;
  194. }
  195. number = number.Substring(number.Length - length, length);
  196. return number;
  197. }
  198. private void SystemSetting_PrinterTest_Load(object sender, EventArgs e)
  199. {
  200. engine.Start();
  201. ma_code.TableName = " make left join product on ma_prodcode=pr_code";
  202. ma_code.SelectField = "ma_code # 工单编号,pr_code # 产品编号,pr_spec # 型号";
  203. ma_code.FormName = Name;
  204. ma_code.SetValueField = new string[] { "ma_code" };
  205. ma_code.Condition = "ma_statuscode='STARTED'";
  206. ma_code.DbChange += pr_code_DbChange;
  207. }
  208. private void pr_code_DbChange(object sender, EventArgs e)
  209. {
  210. Dbfind = ma_code.ReturnData;
  211. BaseUtil.SetFormValue(this.Controls, Dbfind);
  212. DataTable dt = (DataTable)dh.ExecuteSql("select ma_qty,ma_prodcode,pr_detail,ma_printnum from make left join product on ma_prodcode=pr_code left join (select count(1)ma_printnum,mil_makecode from makeimeilist where mil_printstatus=-1 group by mil_makecode) on mil_makecode=ma_code where ma_code='" + ma_code.Text + "'", "select");
  213. if (dt.Rows.Count > 0)
  214. {
  215. pr_code.Text = dt.Rows[0]["ma_prodcode"].ToString();
  216. ma_qty.Text = dt.Rows[0]["ma_qty"].ToString();
  217. ma_printcount.Text = dt.Rows[0]["ma_printnum"].ToString();
  218. pr_detail.Text = dt.Rows[0]["pr_detail"].ToString();
  219. }
  220. }
  221. private void GenSN_Click(object sender, EventArgs e)
  222. {
  223. }
  224. }
  225. }