MesClient.java 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919
  1. package com.mes.ui;
  2. import com.alibaba.fastjson2.JSONObject;
  3. import com.github.xingshuangs.iot.protocol.modbus.service.ModbusTcp;
  4. import com.mes.component.MesRadio;
  5. import com.mes.component.MesWebView;
  6. import com.mes.netty.NettyClient;
  7. import com.mes.util.CommonUtils;
  8. import com.mes.util.DateLocalUtils;
  9. import com.mes.util.HttpUtils;
  10. import com.mes.util.JdbcUtils;
  11. import javafx.embed.swing.JFXPanel;
  12. import org.slf4j.Logger;
  13. import org.slf4j.LoggerFactory;
  14. import javax.swing.*;
  15. import javax.swing.border.EmptyBorder;
  16. import javax.swing.event.ChangeEvent;
  17. import javax.swing.event.ChangeListener;
  18. import java.awt.*;
  19. import java.awt.event.ActionEvent;
  20. import java.awt.event.ActionListener;
  21. import java.awt.event.MouseAdapter;
  22. import java.awt.event.MouseEvent;
  23. import java.io.BufferedReader;
  24. import java.io.IOException;
  25. import java.io.InputStream;
  26. import java.io.InputStreamReader;
  27. import java.sql.ResultSet;
  28. import java.sql.SQLException;
  29. import java.sql.Statement;
  30. import java.time.LocalDateTime;
  31. import java.util.List;
  32. import java.util.Properties;
  33. import java.util.Timer;
  34. import java.util.TimerTask;
  35. import java.util.concurrent.ExecutorService;
  36. import java.util.concurrent.Executors;
  37. public class MesClient extends JFrame {
  38. public static final Logger log = LoggerFactory.getLogger(MesClient.class);
  39. public static int mes_auth = 0; // 权限级别 0=无权限 1=操作工人 2=管理员
  40. public static String mes_gw = ""; // 工位号
  41. public static String mes_gw_des = ""; // 工位名称
  42. public static String mes_server_ip = ""; // 服务器IP地址
  43. public static int mes_tcp_port = 3000; // TCP服务端口
  44. public static int mes_heart_beat_cycle = 10; // 心跳周期
  45. public static int mes_heart_icon_cycle = 1;
  46. public static String mes_line_sn = ""; // 产线编号
  47. //TCP连接
  48. public static NettyClient nettyClient;
  49. //TCP连接状态
  50. public static boolean tcp_connect_flag = false;
  51. //TCP连接请求
  52. public static boolean connect_request_flag = false;
  53. //session
  54. public static String sessionid = "";
  55. public static JPanel contentPane;
  56. public static MesClient mesClientFrame;
  57. public static JTabbedPane tabbedPane;
  58. public static JScrollPane indexScrollPaneA;
  59. public static JScrollPane searchScrollPane;
  60. public static JScrollPane searchScrollPaneDj;
  61. public static Boolean check_quality_result = false;
  62. public static Integer work_status = 0;
  63. public static JButton heart_beat_menu;
  64. public static JButton status_menu;
  65. public static JButton user_menu;
  66. public static int scan_type = 0;
  67. public static JButton finish_ok_bt;
  68. public static JButton finish_ng_bt;
  69. public static JTextField product_sn;
  70. public static JButton f_scan_data_bt_1;
  71. public static String user20 = "";
  72. public static JFrame welcomeWin;
  73. public static JPanel indexPanelB;
  74. public static MesWebView jfxPanel = null;
  75. public static JPanel indexPanelC;
  76. public static MesWebView jfxPanel2 = null;
  77. public static MesRadio mesRadioHj;
  78. public static JTable table;
  79. public static Object[] columnNames = { "物料名称", "绑定批次", "剩余次数", "操作" };
  80. public static Object[][] rowData = null;
  81. public static JLabel fxlabel;
  82. public static ModbusTcp modbusTcp = new ModbusTcp(1, "192.168.88.99");
  83. public static Integer tjFlag = 0; // 0=未扫码 1=已扫码,设备未运行 2=设备运行中 3=设备运行结束,结果未提交到MES
  84. public static Integer tjStatus = 0; // 0=重置 1=提交失败
  85. public static Integer smStatus = 0; // 0=未获取寿命 1=以获取寿命
  86. public static Integer yxtime = 0; // 运行时长
  87. public static String tjResult = "OK"; // 加工结果,只要不急停就算加工完成
  88. public static String tjFlagText2 = "设备运行中";
  89. public static String tjFlagText3 = "设备运行结束,提交结果中";
  90. public static String tjFlagText4 = "结果已上传MES,请扫下一件";
  91. public static String tjFlagText5 = "已扫码,等待设备运行";
  92. public static String tjFlagTextErr = "结果上传MES失败,请重试";
  93. public static String tcTitle = "提示";
  94. public static int alarmFlag = 0; // 报警标志
  95. public static void main(String[] args) {
  96. if (LockUtil.getInstance().isAppActive() == true){
  97. // JOptionPane.showMessageDialog(null, "已有一个程序在运行,程序退出");
  98. return;
  99. }
  100. EventQueue.invokeLater(new Runnable() {
  101. @Override
  102. public void run() {
  103. try{
  104. //读文件配置
  105. readProperty();
  106. // 显示界面
  107. mesClientFrame = new MesClient();
  108. mesClientFrame.setVisible(false);
  109. JdbcUtils.getConn();
  110. welcomeWin = new LoginFarme();
  111. welcomeWin.setVisible(true);
  112. // getMaterailData();
  113. // startUpdateQualityTimer();
  114. alarmFlag = ModbusUitl.getAlarm(modbusTcp);
  115. getPlcParam();
  116. monitorAlarm();
  117. }catch (Exception e){
  118. e.printStackTrace();
  119. }
  120. }
  121. });
  122. }
  123. public static Timer cjTimer;
  124. public static void getPlcParam() {
  125. if(cjTimer!=null) {
  126. cjTimer.cancel();
  127. }
  128. cjTimer = new Timer();
  129. cjTimer.schedule(new TimerTask() {
  130. public void run() {
  131. if(work_status == 1){
  132. // if(CommonUtils.formatOprno(mes_gw).equals("OP180")){
  133. // int program = ModbusUitl.getProgram(modbusTcp);
  134. // int program2 = CommonUtils.getProductProgram(product_sn.getText().trim());
  135. // if(program != program2){
  136. // MesClient.setMenuStatus("工件码与程序不匹配",-1);
  137. // }
  138. // }
  139. ModbusUitl.getParamData(modbusTcp);
  140. }else{
  141. int qdstatus = ModbusUitl.getEnable(modbusTcp);
  142. if(qdstatus == 0){
  143. ModbusUitl.changeEnable(MesClient.modbusTcp,1); // 禁止启动
  144. }
  145. }
  146. }
  147. }, 1000,2000);
  148. }
  149. public static java.util.Timer jsTimer2;
  150. public static void monitorAlarm() { // 定时关闭继电器
  151. if(jsTimer2!=null) {
  152. jsTimer2.cancel();
  153. }
  154. jsTimer2 = new java.util.Timer();
  155. jsTimer2.schedule(new TimerTask() {
  156. public void run() {
  157. try {
  158. if(work_status == 1){
  159. int alarmStatus = ModbusUitl.getAlarm(modbusTcp);
  160. if(alarmStatus != MesClient.alarmFlag && alarmStatus == 1){
  161. MesClient.alarmFlag = alarmStatus;
  162. // 提交报警信息
  163. DataUtil.upAlarm(MesClient.product_sn.getText().trim(),user_menu.getText().trim());
  164. }
  165. }
  166. } catch (Exception e) {
  167. log.info("设备报警:"+e.getMessage());
  168. }
  169. }
  170. }, 100,2000);
  171. }
  172. //读配置文件
  173. private static void readProperty() throws IOException{
  174. String enconding = "UTF-8";
  175. InputStream is = ClassLoader.getSystemResourceAsStream("config/config.properties");
  176. Properties pro = new Properties();
  177. BufferedReader br = new BufferedReader(new InputStreamReader(is, enconding));
  178. pro.load(br);
  179. mes_gw = pro.getProperty("mes.gw");
  180. mes_server_ip = pro.getProperty("mes.server_ip");
  181. mes_tcp_port = Integer.parseInt(pro.getProperty("mes.tcp_port"));
  182. mes_heart_beat_cycle = Integer.parseInt(pro.getProperty("mes.heart_beat_cycle"));
  183. mes_line_sn = pro.getProperty("mes.line_sn");
  184. mes_gw_des = OprnoUtil.getGwDes(mes_line_sn,mes_gw);
  185. log.info(mes_gw + ";" + mes_gw_des + ";" + mes_server_ip + ";" + mes_tcp_port + ";" + mes_heart_beat_cycle);
  186. }
  187. // 初始化TCP
  188. public static void initTcpConnection() {
  189. try {
  190. if(nettyClient==null) {
  191. //初始化TCP连接
  192. nettyClient = new NettyClient();
  193. //TCP连接状态
  194. tcp_connect_flag = false;
  195. //设置TCP请求状态
  196. connect_request_flag = true;
  197. DataUtil.synrTcp(nettyClient,mes_gw);
  198. }
  199. } catch (Exception e) {
  200. // TODO Auto-generated catch block
  201. e.printStackTrace();
  202. }
  203. }
  204. //启动心跳包程序
  205. public static java.util.Timer heartBeatTimer;
  206. public static java.util.Timer heartBeatIconTimer;
  207. public static boolean iconREDFlag = true;
  208. public static void startHeartBeatTimer() {
  209. if(heartBeatTimer!=null) {
  210. heartBeatTimer.cancel();
  211. }
  212. heartBeatTimer = new java.util.Timer();
  213. heartBeatTimer.schedule(new TimerTask() {
  214. public void run() {
  215. if(nettyClient!=null&&tcp_connect_flag) {
  216. //System.out.println("发送心跳报文");
  217. DataUtil.heartBeat(nettyClient,mes_gw);
  218. heart_beat_menu.setText(DateLocalUtils.getCurrentTime());
  219. }
  220. }
  221. }, 100,mes_heart_beat_cycle*1000);
  222. //心跳显示图标
  223. if(heartBeatIconTimer!=null) {
  224. heartBeatIconTimer.cancel();
  225. }
  226. heartBeatIconTimer = new Timer();
  227. heartBeatIconTimer.schedule(new TimerTask() {
  228. public void run() {
  229. if(tcp_connect_flag) {
  230. if(iconREDFlag) {
  231. heart_beat_menu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/grey_dot.png")));
  232. iconREDFlag = false;
  233. }else {
  234. heart_beat_menu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/green_dot.png")));
  235. iconREDFlag = true;
  236. }
  237. heart_beat_menu.setText(DateLocalUtils.getCurrentTime());
  238. heart_beat_menu.repaint();
  239. }else {
  240. heart_beat_menu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/grey_dot.png")));
  241. heart_beat_menu.setText(DateLocalUtils.getCurrentTime());
  242. heart_beat_menu.repaint();
  243. //若未连接则尝试连接
  244. if(nettyClient!=null&&!tcp_connect_flag){
  245. System.out.println("TCP已断开");
  246. //TCP重新同步连接
  247. if(!connect_request_flag) {
  248. //System.out.println("TCP重新同步连接");
  249. //设置TCP请求状态,只重新同步连接一次
  250. connect_request_flag = true;
  251. DataUtil.synrTcp(nettyClient,mes_gw);
  252. }
  253. }
  254. }
  255. }
  256. }, 100,mes_heart_icon_cycle*1000);
  257. }
  258. //设置tcp连接状态显示
  259. public static void setTcpStatus() {
  260. if(tcp_connect_flag) {
  261. status_menu.setText("已连接MES服务器");
  262. heart_beat_menu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/grey_dot.png")));
  263. heart_beat_menu.repaint();
  264. }else {
  265. status_menu.setText("未连接MES服务器");
  266. heart_beat_menu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/grey_dot.png")));
  267. heart_beat_menu.repaint();
  268. }
  269. }
  270. public static void initWarehouseData(){
  271. resetScanA();
  272. }
  273. public static void resetScanA() {
  274. work_status = 0;
  275. check_quality_result = false;
  276. MesClient.finish_ok_bt.setEnabled(false);
  277. MesClient.finish_ng_bt.setEnabled(false);
  278. product_sn.setText("");
  279. MesClient.fxlabel.setVisible(false);
  280. MesClient.f_scan_data_bt_1.setEnabled(true);
  281. MesClient.status_menu.setText("请扫工件码");
  282. MesClient.tjFlag = 0;
  283. MesClient.tjStatus = 0;
  284. MesClient.yxtime = 0;
  285. // ModbusUitl.changeProgram(MesClient.modbusTcp, 0);
  286. // updateMaterailData();
  287. // shiftUserCheck();
  288. }
  289. public static int userLoginHours;//用户登录所处小时
  290. //换班用户信息检查
  291. private static void shiftUserCheck() {
  292. LocalDateTime now = LocalDateTime.now();
  293. // 判断时间范围
  294. if (userLoginHours >= 8 && userLoginHours < 20) {
  295. int hour = now.getHour();
  296. if (hour >= 20 || hour < 8) {
  297. logoff();
  298. }
  299. } else {
  300. int hour = now.getHour();
  301. if (hour >= 8 && hour < 20) {
  302. logoff();
  303. }
  304. }
  305. }
  306. public static void resetScanB() {
  307. }
  308. //获取用户20位
  309. public static void getUser() {
  310. user20 = user_menu.getText().toString();
  311. String space_tmp1 = "";
  312. if(user20.length()<20) {
  313. for(int i=0;i<20-user20.length();i++) {
  314. space_tmp1 = space_tmp1 + " ";
  315. }
  316. }
  317. user20 = user20 + space_tmp1;
  318. }
  319. //获取barcode内容36位
  320. public static String getBarcode(String barcodeTmp) {
  321. String barcodeRet = barcodeTmp;
  322. if(barcodeTmp.equalsIgnoreCase("")) {
  323. return "";
  324. }else {
  325. if(barcodeTmp.length()<36) {
  326. String space = "";
  327. for(int i=0;i<36-barcodeTmp.length();i++) {
  328. space = space + " ";
  329. }
  330. barcodeRet = barcodeTmp + space;
  331. }
  332. }
  333. return barcodeRet;
  334. }
  335. public static void scanBarcode() {
  336. if(work_status == 1){
  337. JOptionPane.showMessageDialog(mesClientFrame,"工作中,勿扫码","提示窗口", JOptionPane.INFORMATION_MESSAGE);
  338. return;
  339. }
  340. String scanBarcodeTitle = "";
  341. switch(scan_type) {
  342. case 1:
  343. product_sn.setText("");
  344. scanBarcodeTitle = "请扫工件码";
  345. break;
  346. }
  347. //弹窗扫工件码
  348. String scanBarcode = JOptionPane.showInputDialog(null, scanBarcodeTitle);
  349. if(scanBarcode!=null&&!scanBarcode.equalsIgnoreCase("")) {
  350. //获取用户
  351. getUser();
  352. //获取扫码内容36位
  353. String barcode36 = getBarcode(scanBarcode);//处理36为码
  354. //工位号
  355. String gw = "";
  356. switch(scan_type) {
  357. case 1:
  358. product_sn.setText(scanBarcode);
  359. break;
  360. }
  361. //刷新界面
  362. mesClientFrame.repaint();
  363. if(!tcp_connect_flag) {
  364. MesClient.setMenuStatus("设备未连接Mes服务器",-1);
  365. // JOptionPane.showMessageDialog(mesClientFrame,"设备未连接Mes服务器","提示窗口", JOptionPane.INFORMATION_MESSAGE);
  366. return;
  367. }
  368. // 查询工件质量
  369. Boolean sendret = DataUtil.checkQuality(nettyClient,barcode36,user20);
  370. if(!sendret){
  371. MesClient.setMenuStatus("消息发送失败,请重试",-1);
  372. // JOptionPane.showMessageDialog(mesClientFrame,"消息发送失败,请重试","提示窗口", JOptionPane.INFORMATION_MESSAGE);
  373. return;
  374. }
  375. }else {
  376. MesClient.setMenuStatus("请扫工件码,请重试",-1);
  377. // JOptionPane.showMessageDialog(mesClientFrame,"请扫工件码","提示窗口", JOptionPane.INFORMATION_MESSAGE);
  378. return;
  379. }
  380. }
  381. public static void logoff() {
  382. welcomeWin.setVisible(true);
  383. mesClientFrame.setVisible(false);
  384. nettyClient = null;
  385. // if(heartBeatTimer!=null) {
  386. // heartBeatTimer.cancel();
  387. // }
  388. // if(heartBeatIconTimer!=null) {
  389. // heartBeatIconTimer.cancel();
  390. // }
  391. tcp_connect_flag = false;
  392. connect_request_flag = false;
  393. }
  394. public MesClient() {
  395. setIconImage(Toolkit.getDefaultToolkit().getImage(MesClient.class.getResource("/bg/logo.png")));
  396. setTitle("MES系统客户端:"+mes_gw + "- " + mes_gw_des);
  397. setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
  398. setBounds(0, 0, 1024, 768);
  399. JMenuBar menuBar = new JMenuBar();
  400. menuBar.setFont(new Font("Microsoft YaHei UI", Font.PLAIN, 26));
  401. setJMenuBar(menuBar);
  402. JMenu fileMenu = new JMenu("用户");
  403. fileMenu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/user.png")));
  404. fileMenu.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  405. menuBar.add(fileMenu);
  406. JMenuItem exitMenuItem = new JMenuItem("退出");
  407. exitMenuItem.setIcon(new ImageIcon(MesClient.class.getResource("/bg/logoff.png")));
  408. exitMenuItem.setFont(new Font("微软雅黑", Font.PLAIN, 22));
  409. fileMenu.add(exitMenuItem);
  410. exitMenuItem.addMouseListener(new MouseAdapter() {
  411. @Override
  412. public void mousePressed(MouseEvent e) {//只能检测到mousePressed事件
  413. super.mouseClicked(e);
  414. //dispose();
  415. logoff();
  416. }
  417. });
  418. JMenu settingMenu = new JMenu("设置");
  419. //settingMenu.setVisible(false);
  420. settingMenu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/menu_setting.png")));
  421. settingMenu.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  422. menuBar.add(settingMenu);
  423. JMenuItem resetTcpMenu = new JMenuItem("\u91CD\u8FDEMES");
  424. resetTcpMenu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/reset_logo.png")));
  425. resetTcpMenu.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  426. resetTcpMenu.addMouseListener(new MouseAdapter() {
  427. @Override
  428. public void mousePressed(MouseEvent e) {
  429. super.mouseClicked(e);
  430. //重连mes
  431. nettyClient.future.channel().close();
  432. }
  433. });
  434. settingMenu.add(resetTcpMenu);
  435. JMenuItem resetTcpMenu_1 = new JMenuItem("刷新工件");
  436. resetTcpMenu_1.setIcon(new ImageIcon(MesClient.class.getResource("/bg/reset_logo.png")));
  437. resetTcpMenu_1.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  438. resetTcpMenu_1.addMouseListener(new MouseAdapter() {
  439. @Override
  440. public void mousePressed(MouseEvent e) {
  441. super.mouseClicked(e);
  442. resetScanA();
  443. }
  444. });
  445. settingMenu.add(resetTcpMenu_1);
  446. contentPane = new JPanel();
  447. contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
  448. setContentPane(contentPane);
  449. contentPane.setLayout(new BorderLayout(0, 0));
  450. JToolBar toolBar = new JToolBar();
  451. contentPane.add(toolBar, BorderLayout.NORTH);
  452. JLabel equipment_statu_label = new JLabel("状态:");
  453. equipment_statu_label.setHorizontalAlignment(SwingConstants.CENTER);
  454. equipment_statu_label.setForeground(Color.BLACK);
  455. equipment_statu_label.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  456. equipment_statu_label.setBackground(Color.LIGHT_GRAY);
  457. toolBar.add(equipment_statu_label);
  458. status_menu = new JButton("设备未连接MES服务器");
  459. if(tcp_connect_flag) {
  460. status_menu.setText("已连接MES服务器");
  461. status_menu.setForeground(Color.GREEN);
  462. }else {
  463. status_menu.setText("未连接MES服务器");
  464. status_menu.setForeground(Color.DARK_GRAY);
  465. }
  466. status_menu.addActionListener(new ActionListener() {
  467. public void actionPerformed(ActionEvent e) {
  468. }
  469. });
  470. status_menu.setForeground(Color.GREEN);
  471. status_menu.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  472. status_menu.setBackground(Color.BLACK);
  473. toolBar.add(status_menu);
  474. JLabel space_1 = new JLabel(" ");
  475. toolBar.add(space_1);
  476. JLabel heart_beat_status_label = new JLabel("心跳:");
  477. heart_beat_status_label.setHorizontalAlignment(SwingConstants.CENTER);
  478. heart_beat_status_label.setForeground(Color.BLACK);
  479. heart_beat_status_label.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  480. heart_beat_status_label.setBackground(Color.LIGHT_GRAY);
  481. toolBar.add(heart_beat_status_label);
  482. heart_beat_menu = new JButton("2024-02-20 23:20:10");
  483. heart_beat_menu.setIcon(new ImageIcon(MesClient.class.getResource("/bg/green_dot.png")));
  484. heart_beat_menu.setForeground(Color.GREEN);
  485. heart_beat_menu.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  486. heart_beat_menu.setBackground(Color.BLACK);
  487. toolBar.add(heart_beat_menu);
  488. JLabel space_2 = new JLabel(" ");
  489. toolBar.add(space_2);
  490. JLabel user_status_label = new JLabel("登录用户:");
  491. user_status_label.setHorizontalAlignment(SwingConstants.CENTER);
  492. user_status_label.setForeground(Color.BLACK);
  493. user_status_label.setFont(new Font("微软雅黑", Font.PLAIN, 20));
  494. user_status_label.setBackground(Color.LIGHT_GRAY);
  495. toolBar.add(user_status_label);
  496. user_menu = new JButton("JinJuShi");
  497. user_menu.setForeground(Color.GREEN);
  498. user_menu.setFont(new Font("微软雅黑", Font.PLAIN, 22));
  499. user_menu.setBackground(Color.BLACK);
  500. toolBar.add(user_menu);
  501. JLabel space_3 = new JLabel(" ");
  502. toolBar.add(space_3);
  503. JLabel space_4 = new JLabel(" ");
  504. toolBar.add(space_4);
  505. tabbedPane = new JTabbedPane(JTabbedPane.TOP);
  506. tabbedPane.setMinimumSize(new Dimension(400, 50));
  507. tabbedPane.setFont(new Font("宋体", Font.BOLD, 22));
  508. contentPane.add(tabbedPane);
  509. //首页
  510. JPanel indexPanelA = new JPanel();
  511. indexScrollPaneA = new JScrollPane(indexPanelA);
  512. indexPanelA.setLayout(null);
  513. product_sn = new JTextField();
  514. product_sn.setHorizontalAlignment(SwingConstants.CENTER);
  515. product_sn.setEditable(false);
  516. product_sn.setFont(new Font("微软雅黑", Font.PLAIN, 28));
  517. product_sn.setBounds(81, 70, 602, 70);
  518. // 添加鼠标点击事件,点击显示二维码
  519. product_sn.addMouseListener(new MouseAdapter() {
  520. @Override
  521. public void mouseClicked(MouseEvent e) {
  522. String sn = product_sn.getText();
  523. if(sn != null && !sn.trim().isEmpty()){
  524. new com.mes.component.QRCodeDialog(mesClientFrame, "工件码二维码", sn);
  525. }
  526. }
  527. });
  528. indexPanelA.add(product_sn);
  529. product_sn.setColumns(10);
  530. f_scan_data_bt_1 = new JButton("扫码");
  531. f_scan_data_bt_1.addActionListener(new ActionListener() {
  532. public void actionPerformed(ActionEvent e) {
  533. scan_type = 1;
  534. scanBarcode();
  535. }
  536. });
  537. f_scan_data_bt_1.setIcon(new ImageIcon(MesClient.class.getResource("/bg/scan_barcode.png")));
  538. f_scan_data_bt_1.setFont(new Font("微软雅黑", Font.PLAIN, 32));
  539. f_scan_data_bt_1.setBounds(693, 70, 198, 70);
  540. indexPanelA.add(f_scan_data_bt_1);
  541. // String[] hjtitles = new String[]{"焊机1","焊机2","焊机3"};
  542. // String[] hjvals = new String[]{"HJ001","HJ002","HJ003"};
  543. // mesRadioHj = new MesRadio(hjtitles,hjvals);
  544. // mesRadioHj.setSize(500,50);
  545. // mesRadioHj.setBounds(190,170,500,50);
  546. // indexPanelA.add(mesRadioHj);
  547. fxlabel = new JLabel("该工件为返修件,请仔细检查");
  548. fxlabel.setFont(new Font("微软雅黑", Font.PLAIN, 38));
  549. fxlabel.setBounds(81, 170, 810, 70);
  550. fxlabel.setForeground(Color.RED);
  551. fxlabel.setHorizontalAlignment(SwingConstants.CENTER);
  552. fxlabel.setVisible(false);
  553. indexPanelA.add(fxlabel);
  554. finish_ok_bt = new JButton("OK");
  555. finish_ok_bt.setEnabled(false);
  556. finish_ok_bt.addActionListener(new ActionListener() {
  557. public void actionPerformed(ActionEvent e) {
  558. if(work_status == 1 && check_quality_result){
  559. String sn = getBarcode(product_sn.getText());
  560. if(sn.isEmpty()){
  561. MesClient.setMenuStatus("工件码为空,请重试",-1);
  562. return;
  563. }
  564. getUser();
  565. String qret = "OK";
  566. Boolean sendret = DataUtil.sendQuality(nettyClient,sn,qret,user20);
  567. if(!sendret){
  568. MesClient.setMenuStatus("消息发送失败,请重试",-1);
  569. return;
  570. }else{
  571. // MesClient.resetScanA();
  572. // MesClient.scan_type = 1;
  573. // MesClient.scanBarcode();
  574. // MesClient.setMenuStatus("结果提交成功,请扫下一件",0);
  575. }
  576. }
  577. }
  578. });
  579. finish_ok_bt.setIcon(new ImageIcon(MesClient.class.getResource("/bg/ok_bg.png")));
  580. finish_ok_bt.setFont(new Font("微软雅黑", Font.PLAIN, 32));
  581. finish_ok_bt.setBounds(185, 291, 240, 80);
  582. finish_ok_bt.setEnabled(false);
  583. indexPanelA.add(finish_ok_bt);
  584. finish_ng_bt = new JButton("NG");
  585. finish_ng_bt.setEnabled(false);
  586. finish_ng_bt.addActionListener(new ActionListener() {
  587. public void actionPerformed(ActionEvent e) {
  588. if(work_status == 1 && check_quality_result){
  589. String sn = getBarcode(product_sn.getText());
  590. if(sn.isEmpty()){
  591. MesClient.setMenuStatus("工件码为空,请重试",-1);
  592. return;
  593. }
  594. getUser();
  595. String qret = "NG";
  596. Boolean sendret = DataUtil.sendQuality(nettyClient,sn,qret,user20);
  597. if(!sendret){
  598. MesClient.setMenuStatus("消息发送失败,请重试",-1);
  599. return;
  600. }else{
  601. // MesClient.resetScanA();
  602. // MesClient.scan_type = 1;
  603. // MesClient.scanBarcode();
  604. // MesClient.setMenuStatus("结果提交成功,请扫下一件",0);
  605. }
  606. }
  607. }
  608. });
  609. finish_ng_bt.setIcon(new ImageIcon(MesClient.class.getResource("/bg/ng_bg.png")));
  610. finish_ng_bt.setFont(new Font("微软雅黑", Font.PLAIN, 32));
  611. finish_ng_bt.setBounds(508, 291, 240, 80);
  612. finish_ng_bt.setEnabled(false);
  613. indexPanelA.add(finish_ng_bt);
  614. tabbedPane.addTab("工作面板", new ImageIcon(MesClient.class.getResource("/bg/a_side.png")), indexScrollPaneA, null);
  615. tabbedPane.setEnabledAt(0, true);
  616. // searchScrollPane = new JScrollPane((Component) null);
  617. indexPanelC = new JPanel();
  618. searchScrollPaneDj = new JScrollPane(indexPanelC);
  619. indexPanelC.setLayout(null);
  620. tabbedPane.addTab("开班点检", new ImageIcon(MesClient.class.getResource("/bg/menu_data_preprocess.png")), searchScrollPaneDj, null);
  621. indexPanelB = new JPanel();
  622. searchScrollPane = new JScrollPane(indexPanelB);
  623. indexPanelB.setLayout(null);
  624. tabbedPane.addTab("工作记录", new ImageIcon(MesClient.class.getResource("/bg/menu_data_preprocess.png")), searchScrollPane, null);
  625. tabbedPane.addChangeListener(new ChangeListener() {
  626. @Override
  627. public void stateChanged(ChangeEvent e) {
  628. JTabbedPane tabbedPane = (JTabbedPane) e.getSource();
  629. int selectedIndex = tabbedPane.getSelectedIndex();
  630. System.out.println("selectedIndex:"+selectedIndex);
  631. if(selectedIndex == 1){
  632. }
  633. }
  634. });
  635. }
  636. public static void setMenuStatus(String msg,int error){
  637. if(error == 0){
  638. MesClient.status_menu.setForeground(Color.GREEN);
  639. }else{
  640. MesClient.status_menu.setForeground(Color.RED);
  641. }
  642. MesClient.status_menu.setText(msg);
  643. }
  644. public static void getMaterailData(){
  645. try{
  646. JSONObject retObj = DataUtil.getBindMaterail();
  647. if(retObj.get("result")!=null&&retObj.get("result").toString().equalsIgnoreCase("true")) {
  648. java.util.List<BindMaterialResp> arrs = retObj.getList("data",BindMaterialResp.class);
  649. int i = 0;
  650. rowData = new Object[arrs.size()][7];
  651. for (BindMaterialResp bindMaterialResp:arrs){
  652. rowData[i][0] = bindMaterialResp.getMaterialTitle();
  653. rowData[i][1] = bindMaterialResp.getBatchSn();
  654. rowData[i][2] = bindMaterialResp.getLastTimes();
  655. rowData[i][3] = "";
  656. rowData[i][4] = bindMaterialResp.getCraft();
  657. rowData[i][5] = bindMaterialResp.getMaterialId();
  658. rowData[i][6] = bindMaterialResp.getType();
  659. i++;
  660. }
  661. bindBatchPanel();
  662. }
  663. }catch (Exception e){
  664. log.info(e.getMessage());
  665. }
  666. }
  667. public static void updateMaterailData(){
  668. try{
  669. JSONObject retObj = DataUtil.getBindMaterail();
  670. if(retObj.get("result")!=null&&retObj.get("result").toString().equalsIgnoreCase("true")) {
  671. List<BindMaterialResp> arrs = retObj.getList("data",BindMaterialResp.class);
  672. int i = 0;
  673. for (BindMaterialResp bindMaterialResp:arrs){
  674. rowData[i][0] = bindMaterialResp.getMaterialTitle();
  675. rowData[i][1] = bindMaterialResp.getBatchSn();
  676. rowData[i][2] = bindMaterialResp.getLastTimes();
  677. rowData[i][3] = "";
  678. rowData[i][4] = bindMaterialResp.getCraft();
  679. rowData[i][5] = bindMaterialResp.getMaterialId();
  680. rowData[i][6] = bindMaterialResp.getType();
  681. i++;
  682. }
  683. MesClient.table.repaint();
  684. }
  685. }catch (Exception e){
  686. log.info(e.getMessage());
  687. }
  688. }
  689. // 绑定物料批次码
  690. public static void scanBatchSn(BindMaterialResp bindMaterialResp) {
  691. //弹窗扫工件码
  692. String scanBarcodeTitle = "请扫物料:"+bindMaterialResp.getMaterialTitle();
  693. String scanBarcode = JOptionPane.showInputDialog(null, scanBarcodeTitle);
  694. if(scanBarcode!=null&&!scanBarcode.equalsIgnoreCase("")) {
  695. JSONObject retObj = DataUtil.saveBindMaterail(scanBarcode,bindMaterialResp.getCraft(),bindMaterialResp.getMaterialId(),bindMaterialResp.getType());
  696. if(retObj.get("result")!=null&&retObj.get("result").toString().equalsIgnoreCase("true")) {
  697. MesClient.setMenuStatus("扫物料:"+bindMaterialResp.getMaterialTitle()+"成功",0);
  698. updateMaterailData();
  699. }else{
  700. if(retObj.get("result")==null){
  701. MesClient.setMenuStatus("请求失败,请重试",-1);
  702. }else{
  703. if(retObj.get("result").toString().equalsIgnoreCase("false")){
  704. MesClient.setMenuStatus(retObj.getString("message"),-1);
  705. }
  706. }
  707. }
  708. }
  709. }
  710. public static void bindBatchPanel(){
  711. JPanel indexPanelBB = new JPanel();
  712. JPanel panel = new JPanel();
  713. panel.setBounds(0, 0, 990, 550);
  714. // panel.setBounds(81, 50, 810, 479);
  715. indexPanelBB.add(panel);
  716. panel.setLayout(new GridLayout(0, 1, 0, 0));
  717. table = new JTable(rowData, columnNames){
  718. public boolean isCellEditable(int row, int column) {
  719. if(column == 3){
  720. return true;
  721. }
  722. return false;
  723. }
  724. };
  725. table.setRowHeight(40);
  726. table.setEnabled(true);
  727. table.setFont(new Font("微软雅黑", Font.PLAIN, 14));
  728. table.getColumnModel().getColumn(3).setCellRenderer(new TableCellRendererButton());
  729. table.getColumnModel().getColumn(3).setCellEditor(new TableCellEditorButton());
  730. JScrollPane scrollPane = new JScrollPane(table);
  731. panel.add(scrollPane);
  732. JScrollPane indexScrollPaneB = new JScrollPane(indexPanelBB);
  733. indexPanelBB.setLayout(null);
  734. tabbedPane.addTab("绑定物料", new ImageIcon(MesClient.class.getResource("/bg/menu_data_preprocess.png")), indexScrollPaneB, null);
  735. }
  736. // 开启发送结果定时任务
  737. public static void startUpdateQualityTimer(){
  738. // 创建异步线程池
  739. ExecutorService executorService = Executors.newSingleThreadExecutor();
  740. // 提交任务
  741. executorService.submit(() -> {
  742. log.info("异步任务执行中...");
  743. // 模拟耗时操作
  744. try {
  745. while (true){
  746. try {
  747. // 确保连接已经打开
  748. if (JdbcUtils.conn == null || JdbcUtils.conn.isClosed()) {
  749. JdbcUtils.openConnection();
  750. }
  751. Statement statement = JdbcUtils.conn.createStatement();
  752. String selectSql = "SELECT id, bw FROM submit_record\n" +
  753. "WHERE state = 0 ORDER BY id DESC LIMIT 10";
  754. String updateSql = "UPDATE submit_record \n" +
  755. "SET state = '1'\n" +
  756. "WHERE id = ";
  757. ResultSet rs = statement.executeQuery(selectSql);
  758. while(rs.next()){
  759. int id = rs.getInt("id");
  760. String bw = rs.getString("bw");
  761. // 发送请求
  762. String url = "http://"+MesClient.mes_server_ip+":8980/js/a/mes/mesProductRecord/updateQualityByTiming";
  763. log.info("质量:"+bw);
  764. String s = HttpUtils.sendPostRequestJson(url, bw );
  765. log.info("结果:"+s);
  766. Boolean result = JSONObject.parseObject(s).getBoolean("result");
  767. if(result) {
  768. // 更改状态为 1
  769. statement.executeUpdate(updateSql + id);
  770. }
  771. }
  772. rs.close();
  773. statement.close();
  774. } catch (Exception e) {
  775. log.info(e.getMessage());
  776. }
  777. try {
  778. Thread.sleep(2000);
  779. }catch (Exception e){
  780. log.info(e.getMessage());
  781. }
  782. }
  783. } catch (Exception e) {
  784. log.info(e.getMessage());
  785. }
  786. log.info("异步任务执行完毕");
  787. });
  788. }
  789. }