From f962534ae431779f3e341365af2e30fdd0afeb0f Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期日, 13 十月 2024 16:20:13 +0800
Subject: [PATCH] 点位在线率恢复为取优云和海康数据

---
 ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java |  112 ++++++++++++++++++++++++++++++-------------------------
 1 files changed, 61 insertions(+), 51 deletions(-)

diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
index dad7b84..0438581 100644
--- a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
+++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
@@ -240,9 +240,6 @@
                 notAddList.add(workOrder);
                 continue;
             }
-            //鏁板瓧鍓嶉潰琛�0
-            workOrderNum++;
-            workOrder.setWorkOrderNo(IdUtils.workOrderNO(now, String.format("%05d", workOrderNum)));
             if (Objects.nonNull(point.getUnitId())) {
                 workOrder.setUnitId(Math.toIntExact(point.getUnitId()));
             }
@@ -265,7 +262,12 @@
         if (CollectionUtils.isEmpty(waitAddList)) {
             return Boolean.TRUE;
         }
-        //璁板綍宸ュ崟鏁�
+        //璁板綍宸ュ崟鏁�,琛ュ厖宸ュ崟鍙�
+        for (WorkOrder workOrder : waitAddList) {
+            //鏁板瓧鍓嶉潰琛�0
+            workOrderNum++;
+            workOrder.setWorkOrderNo(IdUtils.workOrderNO(now, String.format("%05d", workOrderNum)));
+        }
         redisCache.setCacheObject(RedisConstant.WORKORDER_NUM, workOrderNum);
         redisCache.releaseLock(RedisConstant.WORKORDER_NUM_LOCK, requestId);
         // 淇濆瓨宸ュ崟鍜屾晠闅滅被鍨�
@@ -764,56 +766,64 @@
 
     @Override
     public synchronized String getFrameImgByDevice(String deviceId, String channelId, String workOrderNo) throws Exception {
-        String url = String.format(this.rtspServer + "/api/play/start/%s/%s", deviceId, channelId);
+        String url = String.format(this.rtspServer + "/api/play/start/img/%s/%s", deviceId, channelId);
         String result = HttpUtils.sendGet(url);
-        log.info("鎷垮埌鍙栨祦鍝嶅簲缁撴灉锛�" + result);
+        log.info("鎷垮埌鍙栨祦鍥剧墖鍝嶅簲缁撴灉锛�" + result);
         WVPResult wvpResult = JSON.parseObject(result, WVPResult.class);
-        String imgUrl = null;
-        if (wvpResult.getCode() == 0) {
-            JSONObject data = (JSONObject) wvpResult.getData();
-            String rtspUrl = data.getString("fmp4"); // 鍙杕p4鍦板潃
-            if (StringUtils.hasText(rtspUrl)) {
-                System.out.println("鐩爣鍦板潃锛�" + rtspUrl);
-                FFmpegFrameGrabber grabber = null;
-                try {
-                    grabber = new FFmpegFrameGrabber(rtspUrl);
-//                    grabber.setOption("rtsp_transport", "tcp"); // 浣跨敤tcp鐨勬柟寮忥紝涓嶇劧浼氫涪鍖呭緢涓ラ噸
-//                    grabber.setVideoOption("probesize", "10000"); // 璁剧疆鎹曡幏鍒嗘瀽鐨勬渶澶у瓧鑺�
-                    grabber.start();
-                    Frame frame = grabber.grabImage(); // 鐩存帴鎹曡幏涓�甯�
-                    if (frame != null) {
-                        System.out.println("鎴愬姛鎹曡幏涓�甯�");
-                        // 灏咶rame杞崲涓篗at
-                        OpenCVFrameConverter.ToMat converter = new OpenCVFrameConverter.ToMat();
-                        Mat mat = converter.convertToMat(frame);
-
-                        imgUrl = workOrderNo + "_" + IdUtils.fastSimpleUUID() + ".png";
-                        // 鐢熸垚鍥剧墖璺緞
-                        String imgPath = PlatformConfig.getProfile() + "/" + imgUrl;
-                        System.out.println("鍥剧墖淇濆瓨鍦板潃锛�" + imgPath);
-                        imgUrl = Constants.RESOURCE_PREFIX + "/" + imgUrl;
-                        // 淇濆瓨鍥剧墖
-                        opencv_imgcodecs.imwrite(imgPath, mat);
-                    } else {
-                        System.out.println("鏈崟鑾峰埌甯�");
-                    }
-                } catch (FrameGrabber.Exception e) {
-                    e.printStackTrace();
-                } finally {
-                    if (grabber != null) {
-                        try {
-                            grabber.stop(); // 鍋滄鎹曡幏
-                        } catch (FrameGrabber.Exception e) {
-                            e.printStackTrace();
-                        }
-                    }
-                }
-            }
-        } else {
-            System.out.println("璇锋眰澶辫触锛岄敊璇爜锛�" + wvpResult.getCode() + "--" + wvpResult.getMsg());
+        if(wvpResult.getCode() == 0) {
+            Object imgUrl = (Object) wvpResult.getData();
+            imgUrl = Objects.isNull(imgUrl) ? "" : imgUrl;
+            log.info("鎷垮埌鍙栨祦鍥剧墖锛�" + imgUrl);
+            return (String) imgUrl;
         }
-        System.out.println("鍥剧墖URL锛�" + imgUrl);
-        return imgUrl;
+        return null;
+//        WVPResult wvpResult = JSON.parseObject(result, WVPResult.class);
+//        String imgUrl = null;
+//        if (wvpResult.getCode() == 0) {
+//            JSONObject data = (JSONObject) wvpResult.getData();
+//            String rtspUrl = data.getString("fmp4"); // 鍙杕p4鍦板潃
+//            if (StringUtils.hasText(rtspUrl)) {
+//                System.out.println("鐩爣鍦板潃锛�" + rtspUrl);
+//                FFmpegFrameGrabber grabber = null;
+//                try {
+//                    grabber = new FFmpegFrameGrabber(rtspUrl);
+////                    grabber.setOption("rtsp_transport", "tcp"); // 浣跨敤tcp鐨勬柟寮忥紝涓嶇劧浼氫涪鍖呭緢涓ラ噸
+////                    grabber.setVideoOption("probesize", "10000"); // 璁剧疆鎹曡幏鍒嗘瀽鐨勬渶澶у瓧鑺�
+//                    grabber.start();
+//                    Frame frame = grabber.grabImage(); // 鐩存帴鎹曡幏涓�甯�
+//                    if (frame != null) {
+//                        System.out.println("鎴愬姛鎹曡幏涓�甯�");
+//                        // 灏咶rame杞崲涓篗at
+//                        OpenCVFrameConverter.ToMat converter = new OpenCVFrameConverter.ToMat();
+//                        Mat mat = converter.convertToMat(frame);
+//
+//                        imgUrl = workOrderNo + "_" + IdUtils.fastSimpleUUID() + ".png";
+//                        // 鐢熸垚鍥剧墖璺緞
+//                        String imgPath = PlatformConfig.getProfile() + "/" + imgUrl;
+//                        System.out.println("鍥剧墖淇濆瓨鍦板潃锛�" + imgPath);
+//                        imgUrl = Constants.RESOURCE_PREFIX + "/" + imgUrl;
+//                        // 淇濆瓨鍥剧墖
+//                        opencv_imgcodecs.imwrite(imgPath, mat);
+//                    } else {
+//                        System.out.println("鏈崟鑾峰埌甯�");
+//                    }
+//                } catch (FrameGrabber.Exception e) {
+//                    e.printStackTrace();
+//                } finally {
+//                    if (grabber != null) {
+//                        try {
+//                            grabber.stop(); // 鍋滄鎹曡幏
+//                        } catch (FrameGrabber.Exception e) {
+//                            e.printStackTrace();
+//                        }
+//                    }
+//                }
+//            }
+//        } else {
+//            System.out.println("璇锋眰澶辫触锛岄敊璇爜锛�" + wvpResult.getCode() + "--" + wvpResult.getMsg());
+//        }
+//        System.out.println("鍥剧墖URL锛�" + imgUrl);
+//        return imgUrl;
     }
 
     @Override

--
Gitblit v1.8.0