Form1.cs 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. using Check.DataOperate;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Text;
  6. using System.Threading;
  7. using System.Windows.Forms;
  8. using UAS_MES.PublicForm;
  9. namespace UAS_CheckWork
  10. {
  11. public partial class Form1 : Form
  12. {
  13. public Form1()
  14. {
  15. InitializeComponent();
  16. }
  17. DataHelper dh;
  18. //Create Standalone SDK class dynamicly.
  19. public zkemkeeper.CZKEMClass axCZKEM1 = new zkemkeeper.CZKEMClass();
  20. private bool bIsConnected = false;//the boolean value identifies whether the device is connected
  21. private int iMachineNumber = 1;//the serial number of the device.After connecting the device ,this value will be changed.
  22. //开启线程
  23. Thread InitGetInfo;
  24. private void btnConnect_Click(object sender, EventArgs e)
  25. {
  26. if (txtIP.Text.Trim() == "" || txtPort.Text.Trim() == "")
  27. {
  28. MessageBox.Show("请先输入IP和端口", "Error");
  29. return;
  30. }
  31. int idwErrorCode = 0;
  32. Cursor = Cursors.WaitCursor;
  33. if (btnConnect.Text == "断开连接")
  34. {
  35. axCZKEM1.Disconnect();
  36. bIsConnected = false;
  37. btnConnect.Text = "连接";
  38. lblState.Text = "状态:未连接";
  39. Cursor = Cursors.Default;
  40. return;
  41. }
  42. bIsConnected = axCZKEM1.Connect_Net(txtIP.Text, Convert.ToInt32(txtPort.Text));
  43. if (bIsConnected)
  44. {
  45. btnConnect.Text = "断开连接";
  46. btnConnect.Refresh();
  47. lblState.Text = "状态:已连接";
  48. iMachineNumber = 1;//In fact,when you are using the tcp/ip communication,this parameter will be ignored,that is any integer will all right.Here we use 1.
  49. axCZKEM1.RegEvent(iMachineNumber, 65535);//Here you can register the realtime events that you want to be triggered(the parameters 65535 means registering all)
  50. }
  51. else
  52. {
  53. axCZKEM1.GetLastError(ref idwErrorCode);
  54. MessageBox.Show("无法连接设备,ErrorCode=" + idwErrorCode.ToString(), "Error");
  55. }
  56. Cursor = Cursors.Default;
  57. }
  58. private void getAllData_Click(object sender, EventArgs e)
  59. {
  60. if (!bIsConnected)
  61. {
  62. MessageBox.Show("请先连接设备", "Error");
  63. return;
  64. }
  65. InitGetInfo = new Thread(InPrint);
  66. SetLoadingWindow stw = new SetLoadingWindow(InitGetInfo, "正在获取数据...");
  67. stw.StartPosition = FormStartPosition.CenterParent;
  68. stw.ShowDialog();
  69. }
  70. private void InPrint()
  71. {
  72. int idwErrorCode = 0;
  73. //axCZKEM1.EnableDevice(iMachineNumber, false);
  74. //获取所有的考勤记录
  75. if (axCZKEM1.ReadGeneralLogData(iMachineNumber))
  76. {
  77. //循环获取
  78. DataTable dt = new DataTable();
  79. dt.Columns.Add("cl_emcode");
  80. dt.Columns.Add("cl_time");
  81. string enrollNumber = "";//记录用户ID
  82. int verifyCode = 0;//记录用户验证方式 0 为密码验证,1 为指纹验证,2 为卡验证
  83. int inoutMode = 0;//考勤状态,具体含义如下: 默认 0—Check-In 1—Check-Out 2—Break-Out 3—Break-In 4—OT-In 5—OT-Out
  84. int year = 0;//记录考勤年份
  85. int month = 0;//记录考勤月份
  86. int day = 0;//记录考勤日期
  87. int hour = 0;//记录考勤小时
  88. int minute = 0;//记录考勤分钟
  89. int second = 0;//记录考勤秒
  90. int workCode = 0; //记录workCode
  91. while (axCZKEM1.SSR_GetGeneralLogData(iMachineNumber, out enrollNumber, out verifyCode, out inoutMode, out year, out month, out day, out hour, out minute, out second, ref workCode))
  92. {
  93. //将数据加入DataTable中
  94. DataRow dr = dt.NewRow();
  95. dr["cl_emcode"] = enrollNumber;
  96. Console.WriteLine("用户编号:"+enrollNumber);
  97. dr["cl_time"] = year + "-" + month + "-" + day + " " + hour + ":" + minute + ":" + second;
  98. Console.WriteLine("签到时间:" + year + "-" + month + "-" + day + " " + hour + ":" + minute + ":" + second);
  99. dt.Rows.Add(dr);
  100. }
  101. allData.DataSource = dt;
  102. //显示
  103. showDataGrid.DataSource = (DataTable)allData.DataSource;
  104. }
  105. else
  106. {
  107. axCZKEM1.GetLastError(ref idwErrorCode);
  108. MessageBox.Show("Unable to get data,ErrorCode=" + idwErrorCode.ToString(), "Error");
  109. }
  110. }
  111. private void Form1_Load(object sender, EventArgs e)
  112. {
  113. CheckForIllegalCrossThreadCalls = false;//可跨线程
  114. dh = new DataHelper();
  115. }
  116. private void saveData_Click(object sender, EventArgs e)
  117. {
  118. //点击保存数据
  119. string lastTime = dh.getFieldDataByCondition("cardlog", "TO_CHAR(max(wl_indate),'yyyy-MM-dd hh24:mi:ss')","").ToString();
  120. //筛选数据
  121. DataTable fd = dh.filterDataTable((DataTable)allData.DataSource, "cl_time > '"+lastTime+"'");
  122. //插入数据库
  123. //新增的数据
  124. List<string> cl_emcode = new List<string>();
  125. List<string> cl_time = new List<string>();
  126. for (int i=0;i<fd.Rows.Count;i++)
  127. {
  128. cl_emcode.Add(fd.Rows[i]["cl_emcode"].ToString());
  129. cl_time.Add(fd.Rows[i]["cl_time"].ToString());
  130. }
  131. //批量插入
  132. StringBuilder sql = new StringBuilder();
  133. sql.Append("insert into cardlog (cl_id,cl_emcode,cl_time) values (cardlog_seq.nextval,:cl_emcode,TO_DATE(:cl_time,'yyyy-MM-dd hh24:mi:ss'))");
  134. dh.BatchInsert(sql.ToString(), new string[] { "cl_emcode", "cl_time"}, cl_emcode.ToArray(), cl_time.ToArray());
  135. }
  136. }
  137. }