From d20202956f68bd5a7ea98d70f1ff11fe99cf9e5c Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期五, 16 九月 2022 10:43:48 +0800
Subject: [PATCH] fix
---
ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java | 117 +++++++++++++++++++++++++++++++++++++++++++---------------
1 files changed, 87 insertions(+), 30 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 937d537..c845b76 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
@@ -15,8 +15,10 @@
import com.sandu.ximon.admin.utils.response.VnnoxPlayerListResponse;
import com.sandu.ximon.admin.utils.response.VnnoxPlayerResponse;
import com.sandu.ximon.admin.utils.response.VnnoxResult;
+import com.sandu.ximon.admin.utils.response.VnnoxResultResponse;
import com.sandu.ximon.admin.vo.NovaPushResultVO;
import com.sandu.ximon.admin.vo.NovaScreenShorUrlVO;
+import com.sandu.ximon.admin.vo.NovaWeatherVO;
import com.sandu.ximon.dao.domain.LedPlayerEntity;
import com.sandu.ximon.dao.domain.LedPlayerInfoEntity;
import com.sandu.ximon.dao.domain.LedV2RegisterResultEntity;
@@ -47,6 +49,7 @@
private LedPlayerEntityService ledPlayerEntityService;
private VnnoxProgramAPIUtil vnnoxProgramAPIUtil;
+ private CountDownLatchUtil countDownLatchUtil;
/**
* 璁惧鏍¢獙娉ㄥ唽
@@ -154,7 +157,7 @@
// 鏍规嵁灞忓箷鐘舵�佽皟鏁碦EDIS鏍囪瘑浣�
for (String playerId : vnnoxResult.getSuccess()) {
- redisUtils.set(VnnoxConstant.REDIS_SCREEN_STATUS + playerId, screenStatus, VnnoxConstant.REDIS_MAX_SAVE_TIME);
+ redisUtils.set(VnnoxConstant.REDIS_SCREEN_STATUS + playerId, screenStatus);
}
return result;
}
@@ -171,7 +174,7 @@
VnnoxResult vnnoxResult = vnnoxAPIUtil.volChange(playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()), vol);
// 鏍规嵁闊抽噺璋冩暣REDIS鏍囪瘑浣�
for (String playerId : vnnoxResult.getSuccess()) {
- redisUtils.set(VnnoxConstant.REDIS_VOL + playerId, vol, VnnoxConstant.REDIS_MAX_SAVE_TIME);
+ redisUtils.set(VnnoxConstant.REDIS_VOL + playerId, vol, VnnoxConstant.STATUS_TIME);
}
List<String> success = vnnoxResult.getSuccess();
List<String> fail = vnnoxResult.getFail();
@@ -212,7 +215,7 @@
VnnoxResult vnnoxResult = vnnoxAPIUtil.brightnessChange(playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()), brightness);
// 鏍规嵁浜害璋冩暣REDIS鏍囪瘑浣�
for (String playerId : vnnoxResult.getSuccess()) {
- redisUtils.set(VnnoxConstant.REDIS_BRIGHTNESS + playerId, brightness, VnnoxConstant.REDIS_MAX_SAVE_TIME);
+ redisUtils.set(VnnoxConstant.REDIS_BRIGHTNESS + playerId, brightness, VnnoxConstant.STATUS_TIME);
}
List<String> success = vnnoxResult.getSuccess();
List<String> fail = vnnoxResult.getFail();
@@ -286,7 +289,7 @@
// 鎵归噺鎴睆
- public List<NovaScreenShorUrlVO> getScreenShotUrl(List<NovaPushResultVO> playerIds) {
+ public List<NovaScreenShorUrlVO> getScreenShotUrl(List<NovaPushResultVO> playerIds) throws InterruptedException {
List<NovaScreenShorUrlVO> screenShorUrlList = new ArrayList<>();
//浠巔layerIds涓幏鍙杙layerId
@@ -306,6 +309,7 @@
break;
} else {
num++;
+ Thread.sleep(500);
}
}
screenShorUrlVO.setShortUrl(url);
@@ -497,10 +501,26 @@
/**
* 鑾峰彇缂撳瓨鏁版嵁
*
- * @param list
+ * @param
* @return
*/
public List<LedPlayerEntity> setCacheInfo(List<LedPlayerEntity> ledList) {
+ List<String> temp = new ArrayList<>();
+ for (LedPlayerEntity item : ledList) {
+ String playerId = item.getPlayerId();
+ if (redisUtils.get(VnnoxConstant.REDIS_VOL + playerId) == null
+ || redisUtils.get(VnnoxConstant.REDIS_BRIGHTNESS + playerId) == null) {
+ temp.add(item.getPlayerId());
+ }
+ }
+ if (temp.size() > 0) {
+ List<List<String>> split = CollectionUtil.split(temp, 100);
+ for (List<String> playIds : split) {
+ System.out.println(playIds.size());
+ vnnoxAPIUtil.asyncStatus(playIds);
+ }
+ }
+
List<List<LedPlayerEntity>> split = CollectionUtil.split(ledList, 100);
for (List<LedPlayerEntity> list : split) {
for (LedPlayerEntity playerEntity : list) {
@@ -517,14 +537,15 @@
result = redisUtils.get(VnnoxConstant.REDIS_VOL + playerId);
Integer vol = 0;
if (null != result) {
- vol = Integer.parseInt(result);
+ vol = Float.valueOf(result).intValue();
+
}
cache.setVol(vol);
// 璁剧疆灞忓箷浜害
result = redisUtils.get(VnnoxConstant.REDIS_BRIGHTNESS + playerId);
Integer brightness = 0;
if (null != result) {
- brightness = Integer.parseInt(result);
+ brightness = Float.valueOf(result).intValue();
}
cache.setBrightness(brightness);
@@ -543,35 +564,27 @@
}
- public VnnoxResult publishWaterData(String playerId, A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage poleSensorEntity) {
+ public VnnoxResult WaterData(String playerId, Long duration, A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage poleSensorEntity) {
List<String> playerIds = new ArrayList<>();
playerIds.add(playerId);
- AirDataProgram playerProgram = new AirDataProgram();
+ NovaWeatherVO playerProgram = new NovaWeatherVO();
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);
- /**
- * 璇虹摝鎺ㄩ�佸ぇ姘旀暟鎹� 鏃ュ織璁板綍寮�濮�
- //// */
-// String content = "{璇虹摝playerId锛�" + playerId + ",鑺傜洰鍐呭锛�" + JSON.toJSONString(playerProgram) + " }";
-// StoreOperationRecordsUtils.storeOperationData(null, null, "澶ф皵鏁版嵁鎺ㄩ�佸埌璇虹摝", content);
- /**
- * 璇虹摝鎺ㄩ�佸ぇ姘旀暟鎹� 鏃ュ織璁板綍缁撴潫
- */
- return vnnoxProgramAPIUtil.normalProgram(playerProgram).getData();
+ NovaWeatherVO.AttributeDTO attributeDTO = new NovaWeatherVO.AttributeDTO();
+ attributeDTO.setDuration(duration);
+ playerProgram.setAttribute(attributeDTO);
+ List<NovaWeatherVO.PageDTO.WidgetsDTO> widgets = setWeather(duration, poleSensorEntity);
+ NovaWeatherVO.PageDTO page = new NovaWeatherVO.PageDTO();
+ page.setWidgets(widgets);
+ playerProgram.setPage(page);
+
+ return vnnoxProgramAPIUtil.emergencyProgram(playerProgram).getData();
}
- private List<PlayerWidget> generateWaterAndSensorWidget(A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage poleSensorEntity) {
+ private List<NovaWeatherVO.PageDTO.WidgetsDTO> setWeather(Long duration, A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage poleSensorEntity) {
- List widgetList = new ArrayList<>();
+ List<NovaWeatherVO.PageDTO.WidgetsDTO> widgets = new ArrayList<>();
List<String> list = new ArrayList<>();
if (Objects.nonNull(poleSensorEntity)) {
list.add("鐜鐩戞祴锛�");
@@ -581,11 +594,49 @@
list.add("pm10锛�" + poleSensorEntity.getPm10() + "渭g/m鲁");
list.add("鐢查啗锛�" + poleSensorEntity.getEch2o() + "渭g/m鲁");
list.add("CO2锛�" + poleSensorEntity.getCo2() + "ppm");
+ } else {
+ list.add("澶ф皵璁惧涓嶅湪绾�");
+ list.add("鐩墠鏄浐瀹氭暟鎹細");
+ list.add("鐜鐩戞祴锛�");
+ list.add("娓╁害锛� 40掳");
+ list.add("婀垮害锛� 60%");
+ list.add("pm25锛�0.58 渭g/m鲁");
+ list.add("pm10锛�0.58 渭g/m鲁");
+ list.add("鐢查啗锛�99.9 渭g/m鲁");
+ list.add("CO2锛�200 ppm");
}
- widgetList.add(new PlayerWidget().generateScrollUpTextWidget("weather", 1, 100000L, list, "#FFFFFF", 15, new PlayerLayout("0%", "5%", "100%", "100%")));
- return widgetList;
+ List<NovaWeatherVO.PageDTO.WidgetsDTO.LinesDTO> lines = new ArrayList<>();
+
+ list.forEach(
+ txt -> {
+ List<NovaWeatherVO.PageDTO.WidgetsDTO.LinesDTO.TextAttributesDTO> textAttributes = new ArrayList<>();
+
+ NovaWeatherVO.PageDTO.WidgetsDTO.LinesDTO linesDTO = new NovaWeatherVO.PageDTO.WidgetsDTO.LinesDTO();
+ NovaWeatherVO.PageDTO.WidgetsDTO.LinesDTO.TextAttributesDTO textAttributesDTO = new NovaWeatherVO.PageDTO.WidgetsDTO.LinesDTO.TextAttributesDTO();
+ textAttributesDTO.setContent(txt);
+ textAttributes.add(textAttributesDTO);
+ System.out.println(txt + "鏂囨湰鍐呭");
+ linesDTO.setTextAttributes(textAttributes);
+ lines.add(linesDTO);
+ }
+ );
+
+ NovaWeatherVO.PageDTO.WidgetsDTO widgetsDTO = new NovaWeatherVO.PageDTO.WidgetsDTO();
+ NovaWeatherVO.PageDTO.WidgetsDTO.ScrollAttributeDTO scrollAttribute = new NovaWeatherVO.PageDTO.WidgetsDTO.ScrollAttributeDTO();
+
+ NovaWeatherVO.PageDTO.WidgetsDTO.LayoutDTO layout = new NovaWeatherVO.PageDTO.WidgetsDTO.LayoutDTO();
+
+ widgetsDTO.setScrollAttribute(scrollAttribute);
+ widgetsDTO.setLayout(layout);
+ widgetsDTO.setLines(lines);
+
+ widgetsDTO.setDuration(duration);
+ widgets.add(widgetsDTO);
+ System.out.println(lines + "鎾斁鍐呭");
+
+ return widgets;
}
@@ -600,4 +651,10 @@
}
}
+
+ public void asyncStatus(List<String> playerIds) {
+ VnnoxResultResponse vnnoxResultResponse = vnnoxAPIUtil.asyncStatus(playerIds);
+
+ }
+
}
--
Gitblit v1.9.3