From 3dc714284a95fe9677a964ec039b2b547547e30d Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期二, 05 十一月 2024 11:20:37 +0800
Subject: [PATCH] 工单异步获取图片、工单导出时间参数bug

---
 ycl-server/src/main/java/com/ycl/task/WorkOrderImgTask.java |   56 +++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 35 insertions(+), 21 deletions(-)

diff --git a/ycl-server/src/main/java/com/ycl/task/WorkOrderImgTask.java b/ycl-server/src/main/java/com/ycl/task/WorkOrderImgTask.java
index 018a2b0..71b2aee 100644
--- a/ycl-server/src/main/java/com/ycl/task/WorkOrderImgTask.java
+++ b/ycl-server/src/main/java/com/ycl/task/WorkOrderImgTask.java
@@ -1,19 +1,29 @@
 package com.ycl.task;
 
 import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
+import com.ycl.config.PlatformConfig;
 import com.ycl.platform.domain.entity.DeviceInfo;
 import com.ycl.platform.domain.entity.WorkOrderCheckImg;
 import com.ycl.platform.domain.vo.DeviceInfoVO;
 import com.ycl.platform.mapper.DeviceInfoMapper;
 import com.ycl.platform.mapper.WorkOrderCheckImgMapper;
 import com.ycl.platform.service.WorkOrderService;
+import com.ycl.utils.DateUtils;
+import com.ycl.utils.uuid.IdUtils;
+import constant.Constants;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.bytedeco.javacv.FFmpegFrameGrabber;
+import org.bytedeco.javacv.Frame;
+import org.bytedeco.javacv.Java2DFrameConverter;
 import org.springframework.stereotype.Component;
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.StringUtils;
 
+import javax.imageio.ImageIO;
+import java.awt.image.BufferedImage;
+import java.io.File;
+import java.io.IOException;
 import java.util.ArrayList;
 import java.util.Calendar;
 import java.util.Date;
@@ -38,24 +48,25 @@
     private final DeviceInfoMapper deviceInfoMapper;
     private final WorkOrderCheckImgMapper workOrderCheckImgMapper;
 
-    private static final ExecutorService executorService = new ThreadPoolExecutor(8,
-            24,
-            5000,
-            TimeUnit.SECONDS,
-            new ArrayBlockingQueue<>(600),
-            new ThreadPoolExecutor.CallerRunsPolicy()
-    );
+//    private static final ExecutorService executorService = new ThreadPoolExecutor(8,
+//            10,
+//            5000,
+//            TimeUnit.SECONDS,
+//            new ArrayBlockingQueue<>(1024),
+//            new ThreadPoolExecutor.CallerRunsPolicy()
+//    );
 
-    public void run() {
+    public void run() throws FFmpegFrameGrabber.Exception {
         // 鏌ュ嚭鏈�杩戜竴鍛ㄧ殑鏁呴殰鐨勮澶�
         Date now = new Date();
         Calendar ca = Calendar.getInstance();
         ca.setTime(now);
         ca.add(Calendar.DATE, -6);
-        List<DeviceInfoVO> deviceList = workOrderService.hasErrorWorkOrderList(now, ca.getTime());
+        List<DeviceInfoVO> deviceList = workOrderService.hasErrorWorkOrderList(DateUtils.getDayStart(ca.getTime()), DateUtils.getDayEnd(now));
         if (CollectionUtils.isEmpty(deviceList)) {
             return;
         }
+        log.info("姝ゆ鍏辨娴嬪伐鍗曞浘鐗囧伐鍗曟暟" + deviceList.size());
         // 鏌ュ嚭鍥芥爣璁惧锛屽氨涓�鏉℃暟鎹�
         List<DeviceInfo> gbDevices = new LambdaQueryChainWrapper<>(deviceInfoMapper)
                 .orderByDesc(DeviceInfo::getUpdateTime)
@@ -65,19 +76,22 @@
             return;
         }
         for (DeviceInfoVO deviceInfo : deviceList) {
-            executorService.submit(() -> {
-                // 鍥芥爣璁惧鐨勭紪鐮佸氨鏄彇瑙嗛娴佺殑璁惧缂栫爜锛屽浗鏍囪澶囧氨涓�涓�傚浗鏍囪澶囩殑姣忎竴涓�氶亾浠h〃涓�涓憚鍍忓ご锛屼篃灏辨槸璁惧id鏄彇娴佺殑閫氶亾id
-                String frameImg = workOrderService.getFrameImgByDevice(gbDevices.get(0).getDeviceId(), deviceInfo.getDeviceId(), deviceInfo.getWorkOrderNo());
-                if (StringUtils.hasText(frameImg)) {
-                    WorkOrderCheckImg img = new WorkOrderCheckImg();
-                    img.setWorkOrderNo(deviceInfo.getWorkOrderNo());
-                    img.setImgUrl(frameImg);
-                    img.setCreateTime(new Date());
-                    workOrderCheckImgMapper.insert(img);
-                }
-            });
+            // 鍥芥爣璁惧鐨勭紪鐮佸氨鏄彇瑙嗛娴佺殑璁惧缂栫爜锛屽浗鏍囪澶囧氨涓�涓�傚浗鏍囪澶囩殑姣忎竴涓�氶亾浠h〃涓�涓憚鍍忓ご锛屼篃灏辨槸璁惧id鏄彇娴佺殑閫氶亾id
+            String frameImg = null;
+            try {
+                frameImg = workOrderService.getFrameImgByDevice(gbDevices.get(0).getDeviceId(), deviceInfo.getDeviceId(), deviceInfo.getWorkOrderNo());
+            } catch (Exception e) {
+                e.printStackTrace();
+                continue;
+            }
+            if (StringUtils.hasText(frameImg)) {
+                WorkOrderCheckImg img = new WorkOrderCheckImg();
+                img.setWorkOrderNo(deviceInfo.getWorkOrderNo());
+                img.setImgUrl(frameImg);
+                img.setCreateTime(new Date());
+                workOrderCheckImgMapper.insert(img);
+            }
         }
-        executorService.shutdown();
     }
 
 }

--
Gitblit v1.8.0