From cda9d3a12240ad659efc11603862487d946715b2 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 27 四月 2022 18:14:08 +0800
Subject: [PATCH] fix
---
ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java | 117 +++++++++++++++++++++++++++++++++++++++++++++++++---------
1 files changed, 99 insertions(+), 18 deletions(-)
diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java
index c861d80..21791b3 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java
@@ -1,11 +1,15 @@
package com.sandu.ximon.admin.service;
import com.sandu.common.execption.BusinessException;
-import com.sandu.common.log.Log;
import com.sandu.ximon.admin.config.VnnoxConstant;
-import com.sandu.ximon.admin.utils.LogUtils;
+import com.sandu.ximon.admin.dto.nova.AirDataProgram;
+import com.sandu.ximon.admin.dto.nova.PlayerLayout;
+import com.sandu.ximon.admin.dto.nova.PlayerPage;
+import com.sandu.ximon.admin.dto.nova.PlayerWidget;
+import com.sandu.ximon.admin.manager.iot.frame.inner.report.A5AtmosphereHeartbeatReportInnerFrame;
import com.sandu.ximon.admin.utils.RedisUtils;
import com.sandu.ximon.admin.utils.VnnoxAPIUtil;
+import com.sandu.ximon.admin.utils.VnnoxProgramAPIUtil;
import com.sandu.ximon.admin.utils.request.VnnoxScreenStatusType;
import com.sandu.ximon.admin.utils.response.VnnoxPlayerListResponse;
import com.sandu.ximon.admin.utils.response.VnnoxPlayerResponse;
@@ -18,10 +22,7 @@
import org.springframework.transaction.annotation.Transactional;
import java.net.URISyntaxException;
-import java.util.Date;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
import java.util.stream.Collectors;
/**
@@ -39,6 +40,8 @@
private RedisUtils redisUtils;
// @Autowired
private LedPlayerEntityService ledPlayerEntityService;
+ // @Autowired
+ private VnnoxProgramAPIUtil vnnoxProgramAPIUtil;
/**
* 璁惧鏍¢獙娉ㄥ唽
@@ -186,14 +189,40 @@
return map;
}
+// //閲嶅惎
+// public VnnoxResult reboot(List<LedPlayerEntity> playerList) {
+// return vnnoxAPIUtil.reboot(
+// playerList.stream().map(
+// item -> item.getPlayerId()
+// ).collect(Collectors.toList())
+// );
+// }
+
//閲嶅惎
- public VnnoxResult reboot(List<LedPlayerEntity> playerList) {
- return vnnoxAPIUtil.reboot(
- playerList.stream().map(
- item -> item.getPlayerId()
- ).collect(Collectors.toList())
- );
+ public VnnoxResult reboot(List<String> playerList) {
+ return vnnoxAPIUtil.reboot(playerList);
}
+
+ /**
+ * 鍚屾鎾斁
+ *
+ * @param
+ * @return
+ */
+ public VnnoxResult syncPlay(List<String> playerList, Integer option) {
+ return vnnoxAPIUtil.syncPlay(playerList, option);
+ }
+
+ /**
+ * 瀵规椂
+ *
+ * @param
+ * @return
+ */
+ public VnnoxResult ntpSync(List<String> playerList, boolean enable) {
+ return vnnoxAPIUtil.ntpSync(playerList, enable);
+ }
+
public boolean updateDataName(Long id, String name) {
LedPlayerEntity byId = ledPlayerEntityService.getById(id);
@@ -208,39 +237,40 @@
/**
* 鑾峰彇缂撳瓨鏁版嵁
+ *
* @param list
* @return
*/
public List<LedPlayerEntity> setCacheInfo(List<LedPlayerEntity> list) {
- for(LedPlayerEntity playerEntity: list) {
+ for (LedPlayerEntity playerEntity : list) {
String playerId = playerEntity.getPlayerId();
LedPlayerInfoEntity cache = new LedPlayerInfoEntity();
// 璁剧疆灞忓箷鐘舵��
String result = redisUtils.get(VnnoxConstant.REDIS_SCREEN_STATUS + playerId);
Integer screenStatus = 1;
- if(null != result) {
+ if (null != result) {
screenStatus = Integer.parseInt(result);
}
cache.setScreenStatus(screenStatus);
// 璁剧疆灞忓箷闊抽噺
result = redisUtils.get(VnnoxConstant.REDIS_VOL + playerId);
Integer vol = 0;
- if(null != result) {
+ if (null != result) {
vol = Integer.parseInt(result);
}
cache.setVol(vol);
// 璁剧疆灞忓箷浜害
result = redisUtils.get(VnnoxConstant.REDIS_BRIGHTNESS + playerId);
Integer brightness = 0;
- if(null != result) {
+ if (null != result) {
brightness = Integer.parseInt(result);
}
cache.setBrightness(brightness);
// 璁剧疆缂╃暐鍥捐闂矾寰�
result = redisUtils.get(VnnoxConstant.REDIS_SCREEN_SHOT + playerId);
- System.out.println(playerId+"鐨勮矾寰勭粨鏋�:-----------------------------"+result);
- if(null != result) {
+ System.out.println(playerId + "鐨勮矾寰勭粨鏋�:-----------------------------" + result);
+ if (null != result) {
playerEntity.setScreenShotUrl(result);
} else {
playerEntity.setScreenShotUrl("");
@@ -252,4 +282,55 @@
}
+ public VnnoxResult publishWaterData(String playerId, A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage poleSensorEntity) {
+ List<String> playerIds = new ArrayList<>();
+ playerIds.add(playerId);
+ AirDataProgram playerProgram = new AirDataProgram();
+ playerProgram.setPlayerIds(playerIds);
+ PlayerPage playerPage = new PlayerPage();
+ playerPage.setName("AirData page");
+ List<PlayerWidget> widgetList = generateWaterAndSensorWidget(poleSensorEntity);
+ playerPage.setWidgets(widgetList);
+ List<PlayerPage> list = new ArrayList<>();
+ list.add(playerPage);
+ playerProgram.setPages(list);
+ playerProgram.setNoticeUrl(VnnoxConstant.NOTIFY_URL);
+
+ return vnnoxProgramAPIUtil.normalProgram(playerProgram).getData();
+ }
+
+
+ private List<PlayerWidget> generateWaterAndSensorWidget(A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage poleSensorEntity) {
+ List widgetList = new ArrayList<>();
+ List<String> list = new ArrayList<>();
+// if (Objects.nonNull(waterDataEntity)) {
+// list.add("姘磋川鐜鐩戞祴瀹炴椂鏁版嵁锛�");
+// list.add("ph锛�"+waterDataEntity.getPh());
+// list.add("婧惰В姘э細"+waterDataEntity.getDoData() + "(mg/L)");
+// list.add("鐢靛鐜囷細"+waterDataEntity.getEc() + "(10^(-6)S)");
+// list.add("娴婂害锛�"+waterDataEntity.getNtu() + "NTU");
+// }
+ if (Objects.nonNull(poleSensorEntity)) {
+// list.add("鐜鐩戞祴锛�");
+ list.add("娓╁害锛�" + poleSensorEntity.getTemperature() + "掳");
+ list.add("婀垮害锛�" + poleSensorEntity.getHumidity() + "%");
+ list.add("pm25锛�" + poleSensorEntity.getPm25() + "渭g/m鲁");
+ list.add("pm10锛�" + poleSensorEntity.getPm10() + "渭g/m鲁");
+ list.add("鐢查啗锛�" + poleSensorEntity.getEch2o() + "渭g/m鲁");
+ list.add("CO2锛�" + poleSensorEntity.getCo2() + "ppm");
+ }
+
+ widgetList.add(new PlayerWidget().generateScrollUpTextWidget(
+ "water",
+ 1,
+ 100000L,
+ list,
+ "#FFFFFF",
+ 15,
+ new PlayerLayout("0%", "5%", "100%", "100%")
+ ));
+
+ return widgetList;
+ }
+
}
--
Gitblit v1.9.3