hangzhoumesParent/common/pom.xml
@@ -200,6 +200,16 @@ <groupId>com.github.yulichang</groupId> <artifactId>mybatis-plus-join-boot-starter</artifactId> <version>1.4.12</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> </dependencies> hangzhoumesParent/common/servicebase/src/main/java/com/mes/common/config/WebSocketConfig.java
New file @@ -0,0 +1,18 @@ package com.mes.common.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.socket.server.standard.ServerEndpointExporter; @Configuration public class WebSocketConfig { /** * bean注册:会自动扫描带有@ServerEndpoint注解声明的Websocket Endpoint(端点),注册成为Websocket bean。 * 要注意,如果项目使用外置的servlet容器,而不是直接使用springboot内置容器的话,就不要注入ServerEndpointExporter,因为它将由容器自己提供和管理。 */ @Bean public ServerEndpointExporter serverEndpointExporter() { return new ServerEndpointExporter(); } } hangzhoumesParent/common/servicebase/src/main/java/com/mes/glassinfo/entity/GlassInfo.java
@@ -2,9 +2,10 @@ import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableId; import java.io.Serializable; import lombok.Data; import lombok.EqualsAndHashCode; import java.io.Serializable; /** * <p> @@ -57,6 +58,16 @@ private String filmsid; /** * 层数 */ private int layer; /** * 总层数 */ private int totalLayer; /** * 磨前宽 */ private Double edgWidth; hangzhoumesParent/common/servicebase/src/main/java/com/mes/glassinfo/entity/OptimizeGlassinfo.java
@@ -43,6 +43,16 @@ private String glassType; /** * 层数 */ private int layer; /** * 总层数 */ private int totalLayer; /** * 小片宽(加磨量) */ private Double pWidth; hangzhoumesParent/common/servicebase/src/main/java/com/mes/glassinfo/service/impl/GlassInfoServiceImpl.java
@@ -1,6 +1,7 @@ package com.mes.glassinfo.service.impl; import com.baomidou.dynamic.datasource.annotation.DS; import com.github.yulichang.base.MPJBaseServiceImpl; import com.github.yulichang.query.MPJQueryWrapper; import com.mes.glassinfo.entity.GlassInfo; import com.mes.glassinfo.entity.OptimizeGlassinfo; @@ -11,7 +12,6 @@ import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import com.github.yulichang.base.MPJBaseServiceImpl; import java.util.ArrayList; import java.util.List; @@ -35,7 +35,7 @@ List<OptimizeGlassinfo> optimizeGlassinfos=null; if (engineeringId != null) { optimizeGlassinfos = optimizeProjectMapper.selectJoinList(OptimizeGlassinfo.class, new MPJQueryWrapper<OptimizeProject>() .select("b.process_id,t.type,b.width,b.height,t.glass_thickness,t.glass_type,b.p_width,b.p_height,b.stock_id,b.heat_layout_id,b.heat_layout_sort,b.x_axis,b.y_axis,b.project_no,b.glass_id") .select("b.process_id,t.type,b.width,b.height,t.glass_thickness,t.glass_type,b.p_width,b.p_height,b.layer, b.total_layer, b.stock_id,b.heat_layout_id,b.heat_layout_sort,b.x_axis,b.y_axis,b.project_no,b.glass_id") .leftJoin("optimize_detail b on t.project_no=b.project_no") .eq("t.state",100) .eq("t.project_no", engineeringId)); @@ -56,6 +56,8 @@ glassInfo.setWidth(map.getWidth()); glassInfo.setHeight(map.getHeight()); glassInfo.setEdgWidth(map.getPWidth()); glassInfo.setLayer(map.getLayer()); glassInfo.setTotalLayer(map.getTotalLayer()); glassInfo.setEdgHeight(map.getPHeight()); glassInfo.setThickness(map.getGlassThickness()); glassInfo.setPatternSequence(map.getStockId());// hangzhoumesParent/common/servicebase/src/main/java/com/mes/tools/S7control.java
@@ -3,6 +3,7 @@ import com.github.xingshuangs.iot.protocol.s7.enums.EPlcType; import com.github.xingshuangs.iot.protocol.s7.service.MultiAddressWrite; import com.github.xingshuangs.iot.protocol.s7.service.S7PLC; import java.util.ArrayList; import java.util.List; @@ -24,13 +25,20 @@ s7PLC.close(); } } /** * 重启西门子s7通讯连接 */ public void reStartS7client() { public boolean reStartS7client() { if (s7PLC != null) { try { s7PLC.hotRestart(); return true; } catch (Exception ex) { return false; } } return false; } @@ -47,14 +55,24 @@ * @param address 地址 * @param data word的值 */ public void writeWord(String address, int data) { public boolean writeWord(String address, int data) { if (s7PLC == null) { return; return false; } else if(!s7PLC.checkConnected()) { s7PLC.hotRestart(); } boolean result = false; int tryCount = 2; do { try { s7PLC.writeUInt16(address, data); result = true; } catch (Exception ex) { reStartS7client(); } finally { tryCount -= 1; } } while (!result && tryCount > 0); return result; } /** @@ -63,20 +81,31 @@ * @param address 地址 * @param datas word的值 */ public void writeWord(String address, List<Integer> datas) { public boolean writeWord(String address, List<Integer> datas) { if (s7PLC == null) { return; return false; } else if(!s7PLC.checkConnected()) { s7PLC.hotRestart(); } boolean result = false; int tryCount = 2; // s7PLC.write(address, data); List<String> addresslist = getAddressList(address, datas.size(), 16); MultiAddressWrite addressWrite = new MultiAddressWrite(); for (int i = 0; i < datas.size(); i++) { addressWrite.addUInt16(addresslist.get(i), datas.get(i)); } do { try { s7PLC.writeMultiData(addressWrite); result = true; } catch (Exception ex) { reStartS7client(); } finally { tryCount -= 1; } } while (!result && tryCount > 0); return result; } /** @@ -93,14 +122,24 @@ * @param address 地址 * @param data Bit的值 */ public void writeBit(String address, Boolean data) { public boolean writeBit(String address, Boolean data) { if (s7PLC == null) { return; return false; } else if(!s7PLC.checkConnected()) { s7PLC.hotRestart(); } boolean result = false; int tryCount = 2; do { try { s7PLC.writeBoolean(address, data); result = true; } catch (Exception ex) { reStartS7client(); } finally { tryCount -= 1; } } while (!result && tryCount > 0); return result; } /** @@ -109,20 +148,30 @@ * @param address 地址 * @param datas bit的值 */ public void writeBit(List<String> address, List<Boolean> datas) { public boolean writeBit(List<String> address, List<Boolean> datas) { if (s7PLC == null) { return; return false; } else if(!s7PLC.checkConnected()) { s7PLC.hotRestart(); } // s7PLC.write(address, data); MultiAddressWrite addressWrite = new MultiAddressWrite(); for (int i = 0; i < address.size(); i++) { addressWrite.addBoolean(address.get(i), datas.get(i)); } boolean result = false; int tryCount = 2; do { try { s7PLC.writeMultiData(addressWrite); result = true; } catch (Exception ex) { reStartS7client(); } finally { tryCount -= 1; } } while (!result && tryCount > 0); return result; } /** @@ -131,20 +180,31 @@ * @param address 地址 * @param datas word的值 */ public void writeBit(String address, List<Boolean> datas) { public boolean writeBit(String address, List<Boolean> datas) { if (s7PLC == null) { return; return false; } else if(!s7PLC.checkConnected()) { s7PLC.hotRestart(); } // s7PLC.write(address, data); List<String> addresslist = getAddressList(address, datas.size(), 1); MultiAddressWrite addressWrite = new MultiAddressWrite(); for (int i = 0; i < datas.size(); i++) { addressWrite.addBoolean(addresslist.get(i), datas.get(i)); } boolean result = false; int tryCount = 2; do { try { s7PLC.writeMultiData(addressWrite); result = true; } catch (Exception ex) { reStartS7client(); } finally { tryCount -= 1; } } while (!result && tryCount > 0); return result; } /** @@ -153,15 +213,24 @@ * @param address 地址 * @param datas byte的值 */ public void writeByte(String address, byte[] datas) { public boolean writeByte(String address, byte[] datas) { if (s7PLC == null) { return; return false; } else if(!s7PLC.checkConnected()) { s7PLC.hotRestart(); } // s7PLC.write(address, data); boolean result = false; int tryCount = 2; do { try { s7PLC.writeByte(address, datas); result = true; } catch (Exception ex) { reStartS7client(); } finally { tryCount -= 1; } } while (!result && tryCount > 0); return result; } /** @@ -174,16 +243,17 @@ if (s7PLC == null) { return null; } List<Integer> result = null; try { return s7PLC.readUInt16(address); result = s7PLC.readUInt16(address); } catch (Exception e) { s7PLC.hotRestart(); System.out.println("读取 " + address + " 失败:" + e.getMessage()); return null; } } } finally { return result; } } /** @@ -197,15 +267,15 @@ if (s7PLC == null) { return null; } List<Integer> result = null; List<String> addresslist = getAddressList(address, count, 16); try { return s7PLC.readUInt16(addresslist); result = s7PLC.readUInt16(addresslist); } catch (Exception e) { s7PLC.hotRestart(); System.out.println("读取 " + address + " 失败:" + e.getMessage()); return null; } finally { return result; } } @@ -221,14 +291,15 @@ return null; } // List<String> addresslist = GetAddressList(address, count, 16); byte[] bytes = null; try { return s7PLC.readByte(address, count); bytes = s7PLC.readByte(address, count); } catch (Exception e) { // 处理异常 s7PLC.hotRestart(); System.out.println("读取 " + address + " 失败:" + e.getMessage()); return null; } finally { return bytes; } } @@ -243,14 +314,15 @@ if (s7PLC == null) { return null; } List<Boolean> values = new ArrayList<>(); try { return s7PLC.readBoolean(addresslist); values = s7PLC.readBoolean(addresslist); } catch (Exception e) { // 处理异常 s7PLC.hotRestart(); return null; } finally { return values; } } /* //读取不连续地址bit @@ -274,22 +346,21 @@ }*/ //读取字符串 public String readString(String address) { if (s7PLC == null) { return null; } String result = null; try { return s7PLC.readString(address); result = s7PLC.readString(address); } catch (Exception e) { s7PLC.hotRestart(); System.out.println("读取 " + address + " 失败:" + e.getMessage()); return null; } finally { return result; } } //读取时间 @@ -297,27 +368,36 @@ if (s7PLC == null) { return null; } Long result = null; try { return s7PLC.readTime(address); result = s7PLC.readTime(address); } catch (Exception e) { s7PLC.hotRestart(); System.out.println("读取 " + address + " 失败:" + e.getMessage()); return null; } finally { return result; } } public void writetime(String address, long datas) { public boolean writetime(String address, long datas) { if (s7PLC == null) { return; return false; } else if(!s7PLC.checkConnected()) { s7PLC.hotRestart(); } boolean result = false; int tryCount = 2; do { try { s7PLC.writeTime(address, datas); // 将数据写入单个地址 result = true; } catch (Exception ex) { reStartS7client(); } finally { tryCount -= 1; } } while (!result && tryCount > 0); return result; } @@ -332,15 +412,16 @@ if (s7PLC == null) { return null; } List<Boolean> values = new ArrayList<>(); List<String> addresslist = getAddressList(address, count, 1); try { return s7PLC.readBoolean(addresslist); values = s7PLC.readBoolean(addresslist); } catch (Exception e) { s7PLC.hotRestart(); System.out.println("读取 " + address + " 失败:" + e.getMessage()); return null; } finally { return values; } } ; hangzhoumesParent/common/servicebase/src/main/java/com/mes/tools/WebSocketServer.java
File was renamed from hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/common/WebSocketServer.java @@ -1,4 +1,4 @@ package com.mes.common; package com.mes.tools; import cn.hutool.json.JSONObject; import cn.hutool.json.JSONUtil; @@ -22,12 +22,6 @@ public static ConfigurableApplicationContext applicationContext; // 解决无法注入mapper问题 //使用方法 // homeMapper=WebSocketServer.applicationContext.getBean(HomeMapper.class); public static void setApplicationContext(ConfigurableApplicationContext configurableApplicationContext) { WebSocketServer.applicationContext = configurableApplicationContext; } private static final Logger log = LoggerFactory.getLogger(WebSocketServer.class); private List<String> messages; /** @@ -35,8 +29,8 @@ */ public static final Map<String, ArrayList<WebSocketServer>> sessionMap = new ConcurrentHashMap<>(); String username; Session session; public String username; public Session session; public WebSocketServer() { this.messages = new ArrayList<>(); @@ -111,8 +105,6 @@ JSONObject jsonObject = new JSONObject(); jsonObject.set("message", text); this.messages.add(text); this.sendMessage(jsonObject.toString()); // JSONUtil.toJsonStr(jsonObject) } @OnError hangzhoumesParent/moduleService/CacheGlassModule/pom.xml
@@ -22,6 +22,11 @@ <artifactId>sqljdbc4</artifactId> <version>4.0</version> </dependency> <dependency> <groupId>org.samba.jcifs</groupId> <artifactId>jcifs</artifactId> <version>1.2.19</version> </dependency> <!-- <dependency>--> <!-- <groupId>com.github.yulichang</groupId>--> <!-- <artifactId>mybatis-plus-join-boot-starter</artifactId>--> hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/common/S7object.java
@@ -53,8 +53,9 @@ } byte[] getplcvlues = plccontrol.readByte(PlcMesObject.getPlcAddressBegin(), PlcMesObject.getPlcAddressLength()); if (getplcvlues != null) { PlcMesObject.setPlcParameterList(getplcvlues); } } } } hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/common/SmbTool.java
New file @@ -0,0 +1,71 @@ package com.mes.common; import jcifs.smb.NtlmPasswordAuthentication; import jcifs.smb.SmbFile; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; public class SmbTool { public static String USER_DOMAIN=null;//共享计算机ip "192.168.3.102"; public static String USER_ACCOUNT=null;//登录共享文件夹 用户名 "aaa",如果是共享是无密码模式 此处值设置为 null; public static String USER_PWS=null;//登录共享文件夹 密码"guoyujie",如果是共享是无密码模式 此处值设置为 null; /** * test 测试示例 */ private void test() { int index= SmbTool.getDescriptionIndex("log","P20240522");//输入切割机共享文件夹名字、工程号,返回当前工程正在切割的版图号 System.out.print(index); } /** * smbGetall 返回指定目录下的文件名字 * @param GoalUrl 远端目录("smb://192.168.2.100//ceshi//") */ public static String[] smbGetallFilenames(String GoalUrl) { NtlmPasswordAuthentication auth=new NtlmPasswordAuthentication(USER_DOMAIN,USER_ACCOUNT,USER_PWS); List<String> filenames=new ArrayList<>(); try { SmbFile remoteFile = new SmbFile(GoalUrl,auth); if (remoteFile == null) { return filenames.toArray(new String[]{}); } if (remoteFile.exists()) { SmbFile[] listFiles = remoteFile.listFiles(); for(int i = 0; i < listFiles.length; i++) { filenames.add(listFiles[i].getName()); } } } catch (Exception e) { e.printStackTrace(); } return filenames.toArray(new String[]{}); } /** * getDescriptionIndex 根据工程号,返回当前正在切割的版图号 * @param folderName 共享文件夹名字 * @param project_no 工程号 */ public static int getDescriptionIndex(String folderName,String project_no) { SimpleDateFormat formatter= new SimpleDateFormat("yyyyMMdd"); Date date = new Date(System.currentTimeMillis()); System.out.println(formatter.format(date)); String[] getfilenames= smbGetallFilenames("smb://"+USER_DOMAIN+"/"+folderName+"/"+formatter.format(date)+"/"); for (int i = 0; i < getfilenames.length; i++) { String[] splitvalues= getfilenames[i].split("_"); if (splitvalues.length>=3&&splitvalues[1].trim().equals(project_no)) { String[] indexstr= splitvalues[2].trim().split("\\."); if (indexstr.length>1) { return Integer.parseInt(indexstr[0]); } } } return -1; } } hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/edgstoragecage/entity/EdgStorageCageDetails.java
@@ -31,6 +31,11 @@ /** * 设备id */ private String engineerId; /** * 设备id */ private Integer deviceId; /** hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/edgstoragecage/service/impl/EdgStorageCageServiceImpl.java
@@ -108,12 +108,9 @@ .select(EdgStorageCageDetails::getGlassId, EdgStorageCageDetails::getWidth, EdgStorageCageDetails::getHeight, EdgStorageCageDetails::getId) .leftJoin(EdgStorageCageDetails.class, on -> on .eq(EdgStorageCageDetails::getDeviceId, EdgStorageCage::getDeviceId) .eq(EdgStorageCageDetails::getState, Const.GLASS_STATE_IN) .eq(EdgStorageCageDetails::getSlot, EdgStorageCage::getSlot)) ); // return baseMapper.selectJoinMaps(new MPJQueryWrapper<EdgStorageCage>().selectAll(EdgStorageCage.class) // .select("escd.glass_id","escd.flow_card_id","escd.width","escd.height") // .leftJoin("edg_storage_cage_details escd on t.device_id=escd.device_id and t.slot=escd.slot") // ); } /** hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/glassinfo/entity/GlassInfo.java
File was deleted hangzhoumesParent/moduleService/CacheGlassModule/src/main/java/com/mes/job/CacheGlassTask.java
@@ -5,9 +5,7 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.github.yulichang.query.MPJQueryWrapper; import com.github.yulichang.wrapper.MPJLambdaWrapper; import com.mes.common.S7object; import com.mes.common.WebSocketServer; import com.mes.common.config.Const; import com.mes.device.PlcParameterObject; import com.mes.edgglasstask.entity.EdgGlassTaskInfo; @@ -20,6 +18,7 @@ import com.mes.glassinfo.service.GlassInfoService; import com.mes.taskcache.entity.TaskCache; import com.mes.taskcache.service.TaskCacheService; import com.mes.tools.WebSocketServer; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.springframework.beans.BeanUtils; @@ -143,34 +142,64 @@ */ private void inTo(String glassId, String confirmationWrodAddress, String currentSlot) { log.info("1、按照玻璃id:{}获取玻璃小片信息,当前格子为:{}", glassId, currentSlot); GlassInfo glassInfo = glassInfoService.getOne(new LambdaQueryWrapper<GlassInfo>().eq(GlassInfo::getGlassId, glassId)); //TODO: 查询玻璃 if (glassInfo == null) { log.info("2、此玻璃编号不存在"); return; } log.info("2、获取到的玻璃信息为{}", glassInfo); //添加进片任务 查找空格 EdgStorageCage nearestEmpty = edgStorageCageService.selectNearestEmpty(Integer.parseInt(currentSlot), Boolean.FALSE); Assert.isTrue(null != nearestEmpty, "格子已满"); log.info("3、查询卧式理片笼里面的空格:{}", nearestEmpty); log.info("2、查询卧式理片笼里面的空格:{}", nearestEmpty); log.info("4、将玻璃信息插入卧式理片笼,当前玻璃信息:{}", glassInfo); //查询玻璃并进行交换 GlassInfo glassInfo = queryAndChangeGlass(glassId); log.info("3、将玻璃信息插入卧式理片笼,当前玻璃信息:{}", glassInfo); EdgStorageCageDetails details = new EdgStorageCageDetails(); BeanUtils.copyProperties(glassInfo, details); details.setState(Const.GLASS_STATE_IN); details.setSlot(nearestEmpty.getSlot()); details.setDeviceId(nearestEmpty.getDeviceId()); edgStorageCageDetailsService.save(details); log.info("5、玻璃信息已存入理片笼详情表,玻璃信息为{}", details); log.info("4、玻璃信息已存入理片笼详情表,玻璃信息为{}", details); //添加进片任务 boolean taskCache = saveTaskCache(details.getGlassId(), 0, nearestEmpty.getSlot(), Const.GLASS_CACHE_TYPE_IN); log.info("6、生成进片任务信息存入任务表是否完成:{}", taskCache); log.info("5、生成进片任务信息存入任务表是否完成:{}", taskCache); S7object.getinstance().plccontrol.writeWord(confirmationWrodAddress, (short) 1); log.info("7、发送确认字完成"); log.info("6、发送确认字完成"); } /** * 查询玻璃并进行交换 * * @param glassId * @return */ public GlassInfo queryAndChangeGlass(String glassId) { GlassInfo glassInfo = glassInfoService.getOne(new LambdaQueryWrapper<GlassInfo>().eq(GlassInfo::getGlassId, glassId)); Assert.isFalse(null == glassInfo, "玻璃信息不存在"); //按照玻璃尺寸 LambdaQueryWrapper<GlassInfo> queryWrapper = new LambdaQueryWrapper<GlassInfo>() .eq(GlassInfo::getWidth, glassInfo.getWidth()) .eq(GlassInfo::getHeight, glassInfo.getHeight()) .eq(GlassInfo::getThickness, glassInfo.getThickness()) .eq(GlassInfo::getFilmsid, glassInfo.getFilmsid()) .eq(GlassInfo::getTotalLayer, glassInfo.getTotalLayer()) .eq(GlassInfo::getLayer, glassInfo.getLayer()) .eq(GlassInfo::getEngineerId, glassInfo.getEngineerId()) .notInSql(GlassInfo::getGlassId, "select distinct glass_id from edg_storage_cage_details " + "where engineer_id = '" + glassInfo.getEngineerId() + "' and width = " + glassInfo.getWidth() + " and height = " + glassInfo.getHeight()) .orderByAsc(GlassInfo::getTemperingLayoutId) .orderBy(Boolean.TRUE, sequenceOrder, GlassInfo::getTemperingFeedSequence) .last("Limit 1"); GlassInfo swapGlassInfo = glassInfoService.getOne(queryWrapper); if (swapGlassInfo != null && !glassInfo.getGlassId().equals(swapGlassInfo.getGlassId())) { String swapGlassId = swapGlassInfo.getGlassId(); swapGlassInfo.setGlassId(glassId); glassInfo.setGlassId(swapGlassId); glassInfoService.updateById(swapGlassInfo); glassInfoService.updateById(glassInfo); return swapGlassInfo; } return glassInfo; } /** @@ -182,7 +211,7 @@ * @param glassId * @param currentSlot */ private boolean outTo(int out08Glassstate, int out10Glassstate, String confirmationWrodAddress, String glassId, int currentSlot) { public boolean outTo(int out08Glassstate, int out10Glassstate, String confirmationWrodAddress, String glassId, int currentSlot) { //逻辑步骤: // 0、A09、A10是否空闲,是否可以执行出片任务 // 1、获取钢化版图是否超过阈值 @@ -219,37 +248,59 @@ endcell = queryLineByGlassInfo(a09EdgGlass, a10EdgGlass, glassInfo, out08Glassstate, out10Glassstate); } else { //判断两条线是否都空闲 endcell = out08Glassstate == 1 || out10Glassstate == 2 ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; endcell = out10Glassstate == 2 ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; if ((out08Glassstate == 0 && out10Glassstate == 0) || (out08Glassstate == 1 && out10Glassstate == 1)) { EdgStorageCageDetails a09EdgGlass = queryGlassByTaskCache(Const.A09_OUT_TARGET_POSITION, Const.GLASS_CACHE_TYPE_OUT); EdgStorageCageDetails a10EdgGlass = queryGlassByTaskCache(Const.A10_OUT_TARGET_POSITION, Const.GLASS_CACHE_TYPE_OUT); if (a09EdgGlass == null && a10EdgGlass == null) { MPJLambdaWrapper<EdgStorageCageDetails> wrapper = new MPJLambdaWrapper<>(); wrapper.select(EdgStorageCageDetails::getWidth, EdgStorageCageDetails::getHeight) .selectCount(EdgStorageCageDetails::getGlassId, EdgStorageCageDetails::getCount) .groupBy(EdgStorageCageDetails::getWidth, EdgStorageCageDetails::getHeight) .last("order by count(t.glass_id) desc limit 2"); MPJQueryWrapper<EdgStorageCageDetails> wrapper = new MPJQueryWrapper<>(); wrapper.select("count(t.glass_id), t.width, t.height") .eq("t.state", Const.GLASS_STATE_IN) .groupBy("t.width, t.height"); if (endcell == Const.A10_OUT_TARGET_POSITION) { wrapper.innerJoin("(select glass_id, case when height <= width then width else height end as first_length, " + "case when width < height then width else height end as second_length from edg_storage_cage_details) t1 " + "on t.glass_id = t1.glass_id and t1.first_length <3500 and t1.second_length<2600 "); } wrapper.last("order by count(t.glass_id) desc limit 2"); List<EdgStorageCageDetails> list = edgStorageCageDetailsService.list(wrapper); if (CollectionUtil.isEmpty(list)) { GlassInfo one = glassInfoService.getOne(new LambdaQueryWrapper<GlassInfo>() .eq(GlassInfo::getGlassId, glassId)); MPJQueryWrapper<GlassInfo> queryWrapper = new MPJQueryWrapper<GlassInfo>() .selectAll(GlassInfo.class).eq("t.glass_id", glassId); if (endcell == Const.A10_OUT_TARGET_POSITION) { queryWrapper.innerJoin("(select glass_id, case when height <= width then width else height end as first_length, " + "case when width < height then width else height end as second_length from glass_info) t1 " + "on t.glass_id = t1.glass_id and t1.first_length <3500 and t1.second_length<2600 "); } GlassInfo one = glassInfoService.getOne(queryWrapper); if (one != null) { EdgStorageCageDetails resultDetails = new EdgStorageCageDetails(); BeanUtils.copyProperties(one, resultDetails); glassInfo = resultDetails; } else { log.info("获取笼内玻璃和带进片玻璃为空或者不符合磨边尺寸"); } } else { glassInfo = queryMinGlass(list.get(0).getWidth(), list.get(0).getHeight(), glassId); } } else if (a09EdgGlass != null && a10EdgGlass != null) { List<EdgStorageCageDetails> a09Count = queryGlassByTaskLine(Const.A09_OUT_TARGET_POSITION); List<EdgStorageCageDetails> a10Count = queryGlassByTaskLine(Const.A09_OUT_TARGET_POSITION); List<EdgStorageCageDetails> a10Count = queryGlassByTaskLine(Const.A10_OUT_TARGET_POSITION); endcell = a09Count.size() > a10Count.size() ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; glassInfo = a09Count.size() > a10Count.size() ? queryMinGlass(a09EdgGlass.getWidth(), a09EdgGlass.getHeight(), glassId) : queryMinGlass(a10EdgGlass.getWidth(), a10EdgGlass.getHeight(), glassId); } else { endcell = a09EdgGlass != null ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; //按照历史任务获取需要执行的路线,如果该条线笼内无玻璃 走其他逻辑 endcell = a09EdgGlass == null ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; List<EdgStorageCageDetails> details = queryGlassByTaskLine(endcell); if (CollectionUtil.isEmpty(details)) { int othercell = endcell == Const.A10_OUT_TARGET_POSITION ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; glassInfo = queryChangeGlassInfo(othercell, glassId); } else { glassInfo = a09EdgGlass != null ? queryMinGlass(a09EdgGlass.getWidth(), a09EdgGlass.getHeight(), glassId) : queryMinGlass(a10EdgGlass.getWidth(), a10EdgGlass.getHeight(), glassId); } } } else { List<EdgStorageCageDetails> edgStorageCageDetails = queryGlassByTaskLine(endcell); @@ -410,41 +461,14 @@ boolean b10 = a10EdgStorageCageDetails != null && a10EdgStorageCageDetails.getHeight().equals(glassInfo.getHeight()) && a10EdgStorageCageDetails.getWidth().equals(glassInfo.getWidth()); //存在出片任务 07为空 if (a08EdgStorageCageDetails == null && a10EdgStorageCageDetails == null) { return queryLineNoTask(out08Glassstate, out10Glassstate); } else { if (b08) { return queryLineHasTask(out08Glassstate); } if (b10) { return queryLineHasTask(out10Glassstate); return out10Glassstate == 2 ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; } return queryLineNoTask(out08Glassstate, out10Glassstate); if (b08) { return out08Glassstate == 2 ? Const.A10_OUT_TARGET_POSITION : Const.A09_OUT_TARGET_POSITION; } return out10Glassstate == 2 ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; } /** * 获取有任务后的出片逻辑 */ private Integer queryLineHasTask(int outGlassstate) { return outGlassstate == 2 ? Const.A10_OUT_TARGET_POSITION : Const.A09_OUT_TARGET_POSITION; } /** * 获取无任务后的出片逻辑 * * @return */ private Integer queryLineNoTask(int out08Glassstate, int out10Glassstate) { if (out08Glassstate == 2) { return Const.A10_OUT_TARGET_POSITION; } if (out10Glassstate == 2 || out08Glassstate == 1) { return Const.A09_OUT_TARGET_POSITION; } return Const.A10_OUT_TARGET_POSITION; } /** * 按照尺寸出玻璃 @@ -453,14 +477,18 @@ * @param glassId * @return */ private EdgStorageCageDetails queryChangeGlassInfo(int endcell, String glassId) { public EdgStorageCageDetails queryChangeGlassInfo(int endcell, String glassId) { //获取笼子内数量前二的玻璃数量 MPJLambdaWrapper<EdgStorageCageDetails> wrapper = new MPJLambdaWrapper<>(); wrapper.select(EdgStorageCageDetails::getWidth, EdgStorageCageDetails::getHeight) .selectCount(EdgStorageCageDetails::getGlassId, EdgStorageCageDetails::getCount) .eq(EdgStorageCageDetails::getState, Const.GLASS_STATE_IN) .groupBy(EdgStorageCageDetails::getWidth, EdgStorageCageDetails::getHeight) .last("order by count(t.glass_id) desc limit 2"); MPJQueryWrapper<EdgStorageCageDetails> wrapper = new MPJQueryWrapper<>(); wrapper.select("count(t.glass_id), t.width, t.height") .eq("t.state", Const.GLASS_STATE_IN) .groupBy("t.width, t.height"); if (endcell == Const.A09_OUT_TARGET_POSITION) { wrapper.innerJoin("(select glass_id, case when height <= width then width else height end as first_length, " + "case when width < height then width else height end as second_length from edg_storage_cage_details) t1 " + "on t.glass_id = t1.glass_id and t1.first_length <3500 and t1.second_length<2600 "); } wrapper.last("order by count(t.glass_id) desc limit 2"); List<EdgStorageCageDetails> list = edgStorageCageDetailsService.list(wrapper); if (CollectionUtil.isEmpty(list)) { return null; hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/common/WebSocketServer.java
File was deleted hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/glassinfo/entity/GlassInfo.java
File was deleted hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java
@@ -9,14 +9,13 @@ import com.mes.bigstoragetask.service.BigStorageCageFeedTaskService; import com.mes.bigstoragetask.service.BigStorageCageOutTaskService; import com.mes.common.S7object; import com.mes.common.WebSocketServer; import com.mes.device.PlcParameterObject; import com.mes.edgstoragetask.service.TaskCacheService; import com.mes.glassinfo.entity.GlassInfo; import com.mes.glassinfo.service.GlassInfoService; import com.mes.menu.service.SysMenuService; import com.mes.tools.WebSocketServer; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; hangzhoumesParent/moduleService/LoadGlassModule/src/main/java/com/mes/common/S7object.java
@@ -52,8 +52,9 @@ } byte[] getplcvlues = plccontrol.readByte(PlcMesObject.getPlcAddressBegin(), PlcMesObject.getPlcAddressLength()); if(getplcvlues!=null) { PlcMesObject.setPlcParameterList(getplcvlues); } } } } hangzhoumesParent/moduleService/LoadGlassModule/src/main/java/com/mes/common/WebSocketServer.java
File was deleted hangzhoumesParent/moduleService/LoadGlassModule/src/main/java/com/mes/uppattenusage/service/impl/UpPattenUsageServiceImpl.java
@@ -11,13 +11,14 @@ import com.mes.pp.mapper.OptimizeProjectMapper; import com.mes.uppattenusage.entity.OptimizeUpPattenUsage; import com.mes.uppattenusage.entity.UpPattenUsage; import com.mes.uppattenusage.service.UpPattenUsageService; import com.mes.uppattenusage.mapper.UpPattenUsageMapper; import com.mes.uppattenusage.service.UpPattenUsageService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.*; import java.util.ArrayList; import java.util.List; /** * <p> @@ -57,7 +58,7 @@ List<OptimizeUpPattenUsage> upPattenUsageList = null; if (engineeringId != null) { upPattenUsageList = optimizeProjectMapper.selectJoinList(OptimizeUpPattenUsage.class, new MPJQueryWrapper<OptimizeProject>() .select("t.project_no,t.glass_type,b.width,b.height,REGEXP_REPLACE(t.glass_thickness,'\\D','')as glass_thickness,b.stock_id") .select("t.project_no,t.glass_type,b.realwidth as width,b.realheight as height ,REGEXP_REPLACE(t.glass_thickness,'\\D','')as glass_thickness,b.stock_id") .leftJoin("optimize_layout b on t.project_no=b.project_no") .eq("b.project_no", engineeringId)); } hangzhoumesParent/moduleService/LoadGlassModule/src/main/java/com/mes/workstation/entity/GlassInfo.java
File was deleted hangzhoumesParent/moduleService/LoadGlassModule/src/main/java/com/mes/workstation/service/impl/UpWorkstationServiceImpl.java
@@ -90,7 +90,7 @@ @Override public String updateMesInkageLoad(short inKageWord) { PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; log.info("修改设备两栋请求为{}:0联线;1联动", inKageWord); log.info("修改设备联动请求为{}:0离线;1联动", inKageWord); S7object.getinstance().plccontrol.writeWord(plcParameterObject.getPlcParameter("InkageStatus").getAddress(), inKageWord); return "success"; } hangzhoumesParent/moduleService/LoadGlassModule/src/main/resources/application.yml
@@ -7,5 +7,5 @@ name: loadGlass mybatis-plus: mapper-locations: classpath*:mapper/*.xml # configuration: # log-impl: org.apache.ibatis.logging.stdout.StdOutImpl 打印sql语句 configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl hangzhoumesParent/moduleService/TemperingGlassModule/src/main/java/com/mes/temperingglass/entity/GlassInfo.java
File was deleted hangzhoumesParent/moduleService/UnLoadGlassModule/pom.xml
@@ -30,12 +30,6 @@ <artifactId>sqljdbc4</artifactId> <version>4.0</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> </dependencies> <properties> hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/UnLoadGlassApplication.java
@@ -1,12 +1,10 @@ package com.mes; import com.mes.tools.WebSocketServer; import lombok.extern.slf4j.Slf4j; import org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; import org.springframework.context.ConfigurableApplicationContext; import org.springframework.scheduling.annotation.EnableScheduling; import springfox.documentation.swagger2.annotations.EnableSwagger2; @@ -23,11 +21,8 @@ @EnableScheduling public class UnLoadGlassApplication { public static void main(String[] args) { SpringApplication springApplication = new SpringApplication(UnLoadGlassApplication.class); ConfigurableApplicationContext applicationContext = springApplication.run(args); WebSocketServer.setApplicationContext(applicationContext); SpringApplication.run(UnLoadGlassApplication.class, args); } } hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/impl/DownGlassInfoServiceImpl.java
@@ -1,23 +1,12 @@ package com.mes.downglassinfo.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.mes.downglassinfo.entity.DownGlassInfo; import com.mes.downglassinfo.entity.DownGlassTask; import com.mes.downglassinfo.mapper.DownGlassInfoMapper; import com.mes.downglassinfo.service.DownGlassInfoService; import com.mes.downglassinfo.service.DownGlassTaskService; import com.mes.downworkstation.entity.DownWorkstation; import com.mes.downworkstation.mapper.DownWorkstationMapper; import com.mes.downworkstation.service.DownWorkstationService; import com.mes.downworkstation.service.DownWorkstationTaskService; import com.mes.tools.WebSocketServer; import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; import java.util.List; @Service public class DownGlassInfoServiceImpl extends ServiceImpl<DownGlassInfoMapper, DownGlassInfo> implements DownGlassInfoService { hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/glassinfo/entity/GlassInfo.java
File was deleted hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/job/DownCacheGlassTask.java
@@ -1,37 +1,23 @@ package com.mes.job; import cn.hutool.core.collection.CollectionUtil; import cn.hutool.core.lang.Assert; import cn.hutool.json.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.mes.common.S7object; import com.mes.common.config.Const; import com.mes.device.PlcParameterObject; import com.mes.downglassinfo.entity.DownGlassInfo; import com.mes.downglassinfo.mapper.DownGlassInfoMapper; import com.mes.downglassinfo.entity.DownGlassTask; import com.mes.downglassinfo.service.DownGlassInfoService; import com.mes.downstorage.entity.DownStorageCage; import com.mes.downglassinfo.service.DownGlassTaskService; import com.mes.downstorage.entity.DownStorageCageDetails; import com.mes.downstorage.service.DownStorageCageDetailsService; import com.mes.downstorage.service.DownStorageCageService; import com.mes.downworkstation.entity.DownWorkstation; import com.mes.downworkstation.entity.DownWorkstationTask; import com.mes.downworkstation.service.DownWorkstationService; import com.mes.downworkstation.service.DownWorkstationTaskService; import com.mes.glassinfo.entity.GlassInfo; import com.mes.glassinfo.service.GlassInfoService; import com.mes.downglassinfo.entity.DownGlassTask; import com.mes.downglassinfo.service.DownGlassTaskService; import com.mes.tools.WebSocketServer; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import java.util.ArrayList; import java.util.Date; import java.util.List; /** hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/tools/WebSocketConfig.java
File was deleted hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/tools/WebSocketServer.java
File was deleted