From 86d0558a3b81c12d03a2d90113490e7c5e147c54 Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期二, 24 九月 2024 15:27:13 +0800
Subject: [PATCH] 大屏公安部考核数据

---
 ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java |  101 ++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 92 insertions(+), 9 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 a946f0c..1770465 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
@@ -37,10 +37,7 @@
 import com.ycl.utils.redis.RedisCache;
 import com.ycl.utils.uuid.IdUtils;
 import constant.Constants;
-import enumeration.general.NotifyTypeEnum;
-import enumeration.general.UrgentLevelEnum;
-import enumeration.general.WorkOrderDistributeWayEnum;
-import enumeration.general.WorkOrderStatusEnum;
+import enumeration.general.*;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.lang3.ObjectUtils;
@@ -73,7 +70,6 @@
 @RequiredArgsConstructor
 public class WorkOrderServiceImpl extends ServiceImpl<WorkOrderMapper, WorkOrder> implements WorkOrderService {
 
-    private final WorkOrderMapper workOrderMapper;
     private final YwPointService ywPointService;
     private final WorkOrderAuditingRecordMapper workOrderAuditingRecordMapper;
     private final WorkOrderAuditingRecordService workOrderAuditingRecordService;
@@ -82,9 +78,8 @@
     private final WorkOrderDistributeRecordMapper workOrderDistributeRecordMapper;
     private final WorkOrderErrorTypeServiceImpl workOrderErrorTypeService;
     private final SysConfigMapper configMapper;
-    private final ServerConfig serverConfig;
     private final ReportMapper reportMapper;
-    private final SysDictDataMapper dictDataMapper;
+    private final WorkOrderCheckImgMapper workOrderCheckImgMapper;
 
     @Value("${rtsp.server:http://127.0.0.1:7788}")
     private String rtspServer;
@@ -402,7 +397,7 @@
         List<WorkOrderYwConditionRecordVO> ywConditionList = workOrderYwConditionRecordMapper.selectYwConditionByYwId(workOrderNo);
         ywConditionList.stream().forEach(item -> {
             if (Objects.nonNull(item.getSysMsg()) && item.getSysMsg()) {
-                item.setCommitUserName("绯荤粺娑堟伅");
+                item.setUnitName("绯荤粺娑堟伅");
             }
         });
         return ywConditionList;
@@ -667,7 +662,25 @@
 
     @Override
     public List<WorkOrderRegionVO> workOrderRegion(DashboardQuery dashboardQuery) {
-        return baseMapper.workOrderRegion(dashboardQuery);
+        //鍒濆鍖栨墍鏈夊尯鍩熸暟鎹�
+        List<WorkOrderRegionVO> vos = new ArrayList<>();
+        for (AreaDeptEnum value : AreaDeptEnum.values()) {
+            WorkOrderRegionVO vo = new WorkOrderRegionVO();
+            vo.setArea(value.getName());
+            vo.setDoneNum(0);
+            vo.setTodoNum(0);
+            vos.add(vo);
+        }
+        List<WorkOrderRegionVO> workOrderRegionVOS = baseMapper.workOrderRegion(dashboardQuery);
+        for (WorkOrderRegionVO vo : vos) {
+            for (WorkOrderRegionVO workOrder : workOrderRegionVOS) {
+                //璧嬪��
+                if(vo.getArea().equals(workOrder.getArea())){
+                    BeanUtils.copyProperties(workOrder,vo);
+                }
+            }
+        }
+        return vos;
     }
 
 
@@ -685,6 +698,8 @@
                 FFmpegFrameGrabber grabber = null;
                 try {
                     grabber = FFmpegFrameGrabber.createDefault(rtspUrl);
+                    //璁剧疆10s瓒呮椂
+                    grabber.setTimeout(10000);
                     grabber.start();
                     Frame frame = grabber.grabImage(); // 鐩存帴鎹曡幏涓�甯�
                     if (frame != null) {
@@ -722,6 +737,67 @@
         }
         System.out.println("鍥剧墖URL锛�" + imgUrl);
         return imgUrl;
+    }
+
+    @Override
+    public void saveFrameImgByDevice(String deviceId, String channelId, String workOrderNo) {
+        String url = String.format(this.rtspServer + "/api/play/start/%s/%s", deviceId, channelId);
+        String result = HttpUtils.sendGet(url);
+        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 = FFmpegFrameGrabber.createDefault(rtspUrl);
+                    //璁剧疆10s瓒呮椂
+                    grabber.setTimeout(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();
+                        }
+                        // 閫氬父涓嶉渶瑕佽皟鐢╮elease()锛屽洜涓簊top()浼氬鐞嗚祫婧愰噴鏀�
+                        // grabber.release(); // 閲婃斁璧勬簮
+                    }
+                }
+            }
+        } else {
+            System.out.println("璇锋眰澶辫触锛岄敊璇爜锛�" + wvpResult.getCode());
+        }
+        System.out.println("鍥剧墖URL锛�" + imgUrl);
+        if (StringUtils.hasText(imgUrl)) {
+            WorkOrderCheckImg img = new WorkOrderCheckImg();
+            img.setWorkOrderNo(workOrderNo);
+            img.setImgUrl(imgUrl);
+            img.setCreateTime(new Date());
+            workOrderCheckImgMapper.insert(img);
+        }
     }
 
     @Override
@@ -791,6 +867,13 @@
         List<SysDictData> errorList = workOrderErrorTypeService.getBaseMapper().getErrorList(workOrder.getWorkOrderNo());
         List<String> errList = errorList.stream().map(SysDictData::getDictLabel).collect(Collectors.toList());
         workOrder.setErrorTypeList(errList);
+        // 妫�娴嬪浘鐗�
+        List<WorkOrderCheckImg> imgList = new LambdaQueryChainWrapper<>(workOrderCheckImgMapper)
+                .eq(WorkOrderCheckImg::getWorkOrderNo, workOrderNo)
+                .orderByDesc(WorkOrderCheckImg::getCreateTime)
+                .last("limit 20")
+                .list();
+        workOrder.setImgList(imgList);
         return Result.ok().data(workOrder);
     }
 }

--
Gitblit v1.8.0