|
|
@@ -15,6 +15,8 @@ package com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.service.imp
|
|
15
|
15
|
import cn.hutool.core.bean.BeanUtil;
|
|
16
|
16
|
import cn.hutool.core.collection.CollStreamUtil;
|
|
17
|
17
|
import cn.hutool.core.collection.CollectionUtil;
|
|
|
18
|
+import cn.hutool.core.date.DateUnit;
|
|
|
19
|
+import cn.hutool.core.date.DateUtil;
|
|
18
|
20
|
import cn.hutool.core.util.ObjectUtil;
|
|
19
|
21
|
import com.alibaba.excel.EasyExcel;
|
|
20
|
22
|
import com.alibaba.excel.write.style.column.SimpleColumnWidthStyleStrategy;
|
|
|
@@ -23,13 +25,11 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
23
|
25
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
24
|
26
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
25
|
27
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
28
|
+import com.unis.basic.info.modular.orgInfo.entity.OrgInfo;
|
|
26
|
29
|
import com.unis.basic.info.modular.orgInfo.mapper.OrgInfoMapper;
|
|
27
|
30
|
import com.unis.common.page.CommonPageRequest;
|
|
28
|
31
|
import com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.param.*;
|
|
29
|
|
-import com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.vo.CameraAndNvrDetailVO;
|
|
30
|
|
-import com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.vo.StatisticalAnalysisPageVO;
|
|
31
|
|
-import com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.vo.StatisticalAnalysisVO;
|
|
32
|
|
-import com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.vo.CameraAndNvrVO;
|
|
|
32
|
+import com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.vo.*;
|
|
33
|
33
|
import com.unis.equipmentOnlineRateAssessment.modular.monitorNvr.entity.MonitorNvr;
|
|
34
|
34
|
import com.unis.equipmentOnlineRateAssessment.modular.monitorNvr.mapper.MonitorNvrMapper;
|
|
35
|
35
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
@@ -42,7 +42,13 @@ import com.unis.equipmentOnlineRateAssessment.modular.monitorCamera.service.Moni
|
|
42
|
42
|
|
|
43
|
43
|
import javax.xml.crypto.Data;
|
|
44
|
44
|
import java.io.File;
|
|
|
45
|
+import java.math.BigDecimal;
|
|
|
46
|
+import java.text.DecimalFormat;
|
|
45
|
47
|
import java.text.SimpleDateFormat;
|
|
|
48
|
+import java.time.Instant;
|
|
|
49
|
+import java.time.LocalDateTime;
|
|
|
50
|
+import java.time.LocalTime;
|
|
|
51
|
+import java.time.ZoneId;
|
|
46
|
52
|
import java.util.ArrayList;
|
|
47
|
53
|
import java.util.Date;
|
|
48
|
54
|
import java.util.List;
|
|
|
@@ -227,4 +233,168 @@ public class MonitorCameraServiceImpl extends ServiceImpl<MonitorCameraMapper, M
|
|
227
|
233
|
|
|
228
|
234
|
}
|
|
229
|
235
|
|
|
|
236
|
+ /**
|
|
|
237
|
+ * 在线巡检-分页
|
|
|
238
|
+ *
|
|
|
239
|
+ * @author hjc
|
|
|
240
|
+ * @date 2024/06/21 10:07
|
|
|
241
|
+ */
|
|
|
242
|
+ @Override
|
|
|
243
|
+ public Page<OnlineInspectionPageVO> onlineInspectionPage(OnlineInspectionPageParam pageParam) {
|
|
|
244
|
+
|
|
|
245
|
+
|
|
|
246
|
+ Page<OnlineInspectionPageVO> page = new Page<>(pageParam.getCurrent(), pageParam.getSize());
|
|
|
247
|
+ Date minDate = null;
|
|
|
248
|
+ Date maxDate = null;
|
|
|
249
|
+ if (ObjectUtil.isNotEmpty(pageParam.getWarnTime())) {
|
|
|
250
|
+ Date warnTime = pageParam.getWarnTime();
|
|
|
251
|
+ LocalDateTime localDateTime = LocalDateTime.ofInstant(Instant.ofEpochMilli(warnTime.getTime()), ZoneId.systemDefault());
|
|
|
252
|
+
|
|
|
253
|
+ // 通过LocalDateTime的 with方法设置某天的最小值和最大值!!
|
|
|
254
|
+ LocalDateTime minDateTime = localDateTime.with(LocalTime.MIN);
|
|
|
255
|
+ // 格式化日期
|
|
|
256
|
+ minDate = Date.from(minDateTime.atZone(ZoneId.systemDefault()).toInstant());
|
|
|
257
|
+
|
|
|
258
|
+ LocalDateTime maxDateTime = localDateTime.with(LocalTime.MAX);
|
|
|
259
|
+ maxDate = Date.from(maxDateTime.atZone(ZoneId.systemDefault()).toInstant());
|
|
|
260
|
+
|
|
|
261
|
+
|
|
|
262
|
+ }
|
|
|
263
|
+ return monitorCameraMapper.onlineInspectionPage(page, pageParam.getZcdzCityName(),
|
|
|
264
|
+ pageParam.getWarnTime(), maxDate, minDate);
|
|
|
265
|
+
|
|
|
266
|
+ }
|
|
|
267
|
+
|
|
|
268
|
+ /*
|
|
|
269
|
+ *
|
|
|
270
|
+ * 在线巡检-详情
|
|
|
271
|
+ *
|
|
|
272
|
+ * @author hjc
|
|
|
273
|
+ * @date 2024/06/21 10:07
|
|
|
274
|
+ */
|
|
|
275
|
+ @Override
|
|
|
276
|
+ public MonitorCameraVO onlineInspectionDetail(MonitorCameraIdParam monitorCameraIdParam) {
|
|
|
277
|
+
|
|
|
278
|
+ MonitorCameraVO vo = new MonitorCameraVO();
|
|
|
279
|
+ MonitorCamera monitorCamera = this.queryEntity(monitorCameraIdParam.getId());
|
|
|
280
|
+ BeanUtil.copyProperties(monitorCamera, vo);
|
|
|
281
|
+ OrgInfo orgInfo = orgInfoMapper.selectById(monitorCamera.getOrgId());
|
|
|
282
|
+ if (ObjectUtil.isNotEmpty(orgInfo)) {
|
|
|
283
|
+ vo.setOrgName(orgInfo.getOrgName());
|
|
|
284
|
+ }
|
|
|
285
|
+ return vo;
|
|
|
286
|
+ }
|
|
|
287
|
+
|
|
|
288
|
+ /**
|
|
|
289
|
+ * 自动考核-分页
|
|
|
290
|
+ *
|
|
|
291
|
+ * @author hjc
|
|
|
292
|
+ * @date 2024/06/21 10:07
|
|
|
293
|
+ */
|
|
|
294
|
+ @Override
|
|
|
295
|
+ public Page<AutomatedAssessmentsPageVO> AutomatedAssessmentsPage(AutomatedAssessmentsPageParam pageParam) {
|
|
|
296
|
+
|
|
|
297
|
+ Page<AutomatedAssessmentsPageVO> page = new Page<>(pageParam.getCurrent(), pageParam.getSize());
|
|
|
298
|
+
|
|
|
299
|
+ AutomatedAssessmentsPageVO vo = new AutomatedAssessmentsPageVO();
|
|
|
300
|
+ //获取摄像头总数量
|
|
|
301
|
+ Integer cameraAllNum = monitorCameraMapper.selectAll(pageParam.getOrgId());
|
|
|
302
|
+ //获取摄像头在线数量
|
|
|
303
|
+ Integer cameraOnlineNum = monitorCameraMapper.selectCameraOnlineNum(pageParam.getOrgId());
|
|
|
304
|
+ //获取摄像头离线数量
|
|
|
305
|
+ Integer cameraOfflineNum = monitorCameraMapper.selectCameraOfflineNum(pageParam.getOrgId());
|
|
|
306
|
+
|
|
|
307
|
+ //获取摄像头在线率
|
|
|
308
|
+ BigDecimal cameraOnlineRate = null;
|
|
|
309
|
+ //获取摄像头离线率
|
|
|
310
|
+ BigDecimal cameraOfflineRate = null;
|
|
|
311
|
+
|
|
|
312
|
+ if (cameraAllNum != 0) {
|
|
|
313
|
+
|
|
|
314
|
+ cameraOnlineRate = BigDecimal.valueOf(cameraOnlineNum)
|
|
|
315
|
+ .divide(BigDecimal.valueOf(cameraAllNum), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100));
|
|
|
316
|
+
|
|
|
317
|
+ cameraOfflineRate = BigDecimal.valueOf(cameraOfflineNum)
|
|
|
318
|
+ .divide(BigDecimal.valueOf(cameraAllNum), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100));
|
|
|
319
|
+ }
|
|
|
320
|
+ //获取NVR总数量
|
|
|
321
|
+ Integer nvrAllNum = monitorNvrMapper.selectAllNum(pageParam.getOrgId());
|
|
|
322
|
+
|
|
|
323
|
+ vo.setCameraAllNum(cameraAllNum);
|
|
|
324
|
+ vo.setCameraOnlineNum(cameraOnlineNum);
|
|
|
325
|
+ vo.setCameraOfflineNum(cameraOfflineNum);
|
|
|
326
|
+ vo.setCameraOnlineRate(cameraOnlineRate);
|
|
|
327
|
+ vo.setCameraOfflineRate(cameraOfflineRate);
|
|
|
328
|
+ vo.setNvrAllNum(nvrAllNum);
|
|
|
329
|
+
|
|
|
330
|
+ ArrayList<AutomatedAssessmentsPageVO> list = new ArrayList<>();
|
|
|
331
|
+ list.add(vo);
|
|
|
332
|
+
|
|
|
333
|
+ page.setRecords(list);
|
|
|
334
|
+ page.setTotal(list.size());
|
|
|
335
|
+
|
|
|
336
|
+ return page;
|
|
|
337
|
+
|
|
|
338
|
+ }
|
|
|
339
|
+
|
|
|
340
|
+ /**
|
|
|
341
|
+ * 自动考核-导出
|
|
|
342
|
+ *
|
|
|
343
|
+ * @author hjc
|
|
|
344
|
+ * @date 2024/06/21 10:07
|
|
|
345
|
+ */
|
|
|
346
|
+ @Override
|
|
|
347
|
+ public void AutomatedAssessmentsExport() {
|
|
|
348
|
+ String path = "D://";
|
|
|
349
|
+ File folder = new File(path);
|
|
|
350
|
+ if (!folder.isDirectory()) {
|
|
|
351
|
+ folder.mkdirs();
|
|
|
352
|
+ }
|
|
|
353
|
+ SimpleDateFormat format = new SimpleDateFormat("yyyyMMdd");
|
|
|
354
|
+ String dateStr = format.format(new Date());
|
|
|
355
|
+ String fileName = path + dateStr + "自动考核数据表" + ".xlsx";
|
|
|
356
|
+
|
|
|
357
|
+ EasyExcel.write(fileName, AutomatedAssessmentsExportVO.class)
|
|
|
358
|
+ .sheet("自动考核数据表")
|
|
|
359
|
+ .doWrite(this::data);
|
|
|
360
|
+ }
|
|
|
361
|
+
|
|
|
362
|
+ private List<AutomatedAssessmentsExportVO> data() {
|
|
|
363
|
+ AutomatedAssessmentsExportVO vo = new AutomatedAssessmentsExportVO();
|
|
|
364
|
+ //获取摄像头总数量
|
|
|
365
|
+ Integer cameraAllNum = monitorCameraMapper.selectAll(null);
|
|
|
366
|
+ //获取摄像头在线数量
|
|
|
367
|
+ Integer cameraOnlineNum = monitorCameraMapper.selectCameraOnlineNum(null);
|
|
|
368
|
+ //获取摄像头离线数量
|
|
|
369
|
+ Integer cameraOfflineNum = monitorCameraMapper.selectCameraOfflineNum(null);
|
|
|
370
|
+ //获取摄像头在线率
|
|
|
371
|
+ BigDecimal cameraOnlineRate = null;
|
|
|
372
|
+ //获取摄像头离线率
|
|
|
373
|
+ BigDecimal cameraOfflineRate = null;
|
|
|
374
|
+
|
|
|
375
|
+ if (cameraAllNum != 0) {
|
|
|
376
|
+
|
|
|
377
|
+ cameraOnlineRate = BigDecimal.valueOf(cameraOnlineNum)
|
|
|
378
|
+ .divide(BigDecimal.valueOf(cameraAllNum), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100));
|
|
|
379
|
+
|
|
|
380
|
+ cameraOfflineRate = BigDecimal.valueOf(cameraOfflineNum)
|
|
|
381
|
+ .divide(BigDecimal.valueOf(cameraAllNum), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100));
|
|
|
382
|
+
|
|
|
383
|
+ }
|
|
|
384
|
+ //获取NVR总数量
|
|
|
385
|
+ Integer nvrAllNum = monitorNvrMapper.selectAllNum(null);
|
|
|
386
|
+
|
|
|
387
|
+ vo.setCameraAllNum(cameraAllNum);
|
|
|
388
|
+ vo.setCameraOnlineNum(cameraOnlineNum);
|
|
|
389
|
+ vo.setCameraOfflineNum(cameraOfflineNum);
|
|
|
390
|
+ vo.setCameraOnlineRate(cameraOnlineRate);
|
|
|
391
|
+ vo.setCameraOfflineRate(cameraOfflineRate);
|
|
|
392
|
+ vo.setNvrAllNum(nvrAllNum);
|
|
|
393
|
+
|
|
|
394
|
+ List<AutomatedAssessmentsExportVO> list = new ArrayList<>();
|
|
|
395
|
+ list.add(vo);
|
|
|
396
|
+
|
|
|
397
|
+ return list;
|
|
|
398
|
+ }
|
|
|
399
|
+
|
|
230
|
400
|
}
|