设置全局scenario值
This commit is contained in:
parent
8d31f6fdd1
commit
a5b56ac249
|
|
@ -111,7 +111,6 @@ public class BattleRootTask extends AbtParentTask {
|
||||||
@Override
|
@Override
|
||||||
public void execTask() {
|
public void execTask() {
|
||||||
log.info("===============================定时检查统计各种资源消耗量 begin====================================");
|
log.info("===============================定时检查统计各种资源消耗量 begin====================================");
|
||||||
|
|
||||||
Long deathConsume = null;
|
Long deathConsume = null;
|
||||||
Long injuredConsume = null;
|
Long injuredConsume = null;
|
||||||
Double ammunitionConsume = null;
|
Double ammunitionConsume = null;
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
package com.hivekion.statistic.service.impl;
|
package com.hivekion.statistic.service.impl;
|
||||||
|
|
||||||
|
import cn.hutool.core.collection.CollectionUtil;
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||||
import com.hivekion.baseData.entity.Fightpowerstaff;
|
import com.hivekion.baseData.entity.Fightpowerstaff;
|
||||||
import com.hivekion.baseData.entity.OrgSupplier;
|
import com.hivekion.baseData.entity.OrgSupplier;
|
||||||
|
|
@ -17,6 +18,8 @@ import com.hivekion.supplier.entity.SupplierRequest;
|
||||||
import com.hivekion.supplier.entity.SuppliesDict;
|
import com.hivekion.supplier.entity.SuppliesDict;
|
||||||
import com.hivekion.supplier.service.ISupplierRequestService;
|
import com.hivekion.supplier.service.ISupplierRequestService;
|
||||||
import com.hivekion.supplier.service.SuppliesDictService;
|
import com.hivekion.supplier.service.SuppliesDictService;
|
||||||
|
import com.hivekion.team.entity.Teaminfo;
|
||||||
|
import com.hivekion.team.service.ITeaminfoService;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
|
@ -43,11 +46,25 @@ public class ScenarioServiceImpl implements ScenarioService {
|
||||||
private ScenarioTaskService scenarioTaskService;
|
private ScenarioTaskService scenarioTaskService;
|
||||||
@Resource
|
@Resource
|
||||||
private ISupplierRequestService supplierRequestService;
|
private ISupplierRequestService supplierRequestService;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private ITeaminfoService teamInfoService;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private ScenarioResourceService resourceService;
|
||||||
@Override
|
@Override
|
||||||
public ScenarioInfo listScenarioInfo(Integer scenarioId, String roomId, String resourceId) {
|
public ScenarioInfo listScenarioInfo(Integer scenarioId, String roomId, String resourceId) {
|
||||||
ScenarioInfo scenarioInfo = new ScenarioInfo();
|
ScenarioInfo scenarioInfo = new ScenarioInfo();
|
||||||
//获取分队信息
|
//获取分队信息
|
||||||
|
Map<Integer, Teaminfo> map = teamInfoService.teamInfoMap();
|
||||||
|
Map<String, ScenarioResource> resourceMap = resourceService.resourceMap();
|
||||||
ScenarioResource resourceInstance = scenarioResourceService.getById(resourceId);
|
ScenarioResource resourceInstance = scenarioResourceService.getById(resourceId);
|
||||||
|
if (resourceMap.get(resourceId) != null) {
|
||||||
|
ScenarioResource resource = resourceMap.get(resourceId);
|
||||||
|
if (map.get(resource.getResourceId()) != null) {
|
||||||
|
scenarioInfo.getTeam().setTeamName(map.get(resource.getResourceId()).getName());
|
||||||
|
}
|
||||||
|
}
|
||||||
//获取关联的组织机构信息
|
//获取关联的组织机构信息
|
||||||
ScenarioOrgPost post = new ScenarioOrgPost();
|
ScenarioOrgPost post = new ScenarioOrgPost();
|
||||||
post.setResourceId(resourceId);
|
post.setResourceId(resourceId);
|
||||||
|
|
@ -55,50 +72,60 @@ public class ScenarioServiceImpl implements ScenarioService {
|
||||||
List<Integer> orgList = orgPostList.stream().map(ScenarioOrgPost::getOrgId)
|
List<Integer> orgList = orgPostList.stream().map(ScenarioOrgPost::getOrgId)
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
List<Fightpowerstaff> staffList = null;
|
List<Fightpowerstaff> staffList = null;
|
||||||
|
List<OrgSupplier> suppliers = null;
|
||||||
if(!orgList.isEmpty()){
|
if(!orgList.isEmpty()){
|
||||||
staffList = fightpowerstaffService.queryByOrgIds(orgList);
|
staffList = fightpowerstaffService.queryByOrgIds(orgList);
|
||||||
|
if(CollectionUtil.isEmpty(staffList)){
|
||||||
|
staffList = new ArrayList<>();
|
||||||
|
}
|
||||||
|
//获取物资信息
|
||||||
|
suppliers = orgSupplierService.selectByOrgIds(orgList);
|
||||||
|
if(suppliers==null||suppliers.isEmpty()){
|
||||||
|
suppliers = new ArrayList<>();
|
||||||
|
}
|
||||||
|
Map<String, SuppliesDict> supplierMap = suppliesDictService.supplierDictMap();
|
||||||
|
|
||||||
|
suppliers.forEach(supplier -> {
|
||||||
|
|
||||||
|
SuppliesDict dict = supplierMap.get(supplier.getSupplierId());
|
||||||
|
|
||||||
|
if (dict != null) {
|
||||||
|
switch (dict.getCode()) {
|
||||||
|
case "FOOD":
|
||||||
|
scenarioInfo.getFood().setTotal(scenarioInfo.getFood().getTotal()+supplier.getAccount());
|
||||||
|
scenarioInfo.getFood().setCurrent(scenarioInfo.getFood().getCurrent()+supplier.getAccount());
|
||||||
|
break;
|
||||||
|
case "WATER":
|
||||||
|
scenarioInfo.getWater().setTotal(scenarioInfo.getWater().getTotal()+supplier.getAccount());
|
||||||
|
scenarioInfo.getWater().setCurrent(scenarioInfo.getWater().getCurrent()+supplier.getAccount());
|
||||||
|
break;
|
||||||
|
case "FUEL":
|
||||||
|
scenarioInfo.getFuel().setTotal(scenarioInfo.getFuel().getTotal()+supplier.getAccount());
|
||||||
|
scenarioInfo.getFuel().setCurrent(scenarioInfo.getFuel().getCurrent()+supplier.getAccount());
|
||||||
|
break;
|
||||||
|
case "MEDICAL":
|
||||||
|
scenarioInfo.getMedical().setTotal( scenarioInfo.getMedical().getTotal()+supplier.getAccount());
|
||||||
|
scenarioInfo.getMedical().setCurrent( scenarioInfo.getMedical().getCurrent()+supplier.getAccount());
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "AMMUNITION":
|
||||||
|
scenarioInfo.getAmmunition().setTotal( scenarioInfo.getAmmunition().getTotal()+supplier.getAccount());
|
||||||
|
scenarioInfo.getAmmunition().setCurrent(scenarioInfo.getAmmunition().getCurrent()+supplier.getAccount());
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}else{
|
}else{
|
||||||
staffList = new ArrayList<>();
|
staffList = new ArrayList<>();
|
||||||
|
orgPostList = new ArrayList<>();
|
||||||
|
suppliers = new ArrayList<>();
|
||||||
}
|
}
|
||||||
//获取物资信息
|
|
||||||
List<OrgSupplier> suppliers = orgSupplierService.selectByOrgIds(orgList);
|
|
||||||
if(suppliers==null||suppliers.isEmpty()){
|
|
||||||
return new ScenarioInfo();
|
|
||||||
}
|
|
||||||
Map<String, SuppliesDict> supplierMap = suppliesDictService.supplierDictMap();
|
|
||||||
|
|
||||||
suppliers.forEach(supplier -> {
|
scenarioInfo.getTeam().setType(resourceInstance.getType());
|
||||||
|
scenarioInfo.getTeam().setLat(resourceInstance.getLat());
|
||||||
SuppliesDict dict = supplierMap.get(supplier.getSupplierId());
|
scenarioInfo.getTeam().setLng(resourceInstance.getLng());
|
||||||
|
|
||||||
if (dict != null) {
|
|
||||||
switch (dict.getCode()) {
|
|
||||||
case "FOOD":
|
|
||||||
scenarioInfo.getFood().setTotal(scenarioInfo.getFood().getTotal()+supplier.getAccount());
|
|
||||||
scenarioInfo.getFood().setCurrent(scenarioInfo.getFood().getCurrent()+supplier.getAccount());
|
|
||||||
break;
|
|
||||||
case "WATER":
|
|
||||||
scenarioInfo.getWater().setTotal(scenarioInfo.getWater().getTotal()+supplier.getAccount());
|
|
||||||
scenarioInfo.getWater().setCurrent(scenarioInfo.getWater().getCurrent()+supplier.getAccount());
|
|
||||||
break;
|
|
||||||
case "FUEL":
|
|
||||||
scenarioInfo.getFuel().setTotal(scenarioInfo.getFuel().getTotal()+supplier.getAccount());
|
|
||||||
scenarioInfo.getFuel().setCurrent(scenarioInfo.getFuel().getCurrent()+supplier.getAccount());
|
|
||||||
break;
|
|
||||||
case "MEDICAL":
|
|
||||||
scenarioInfo.getMedical().setTotal( scenarioInfo.getMedical().getTotal()+supplier.getAccount());
|
|
||||||
scenarioInfo.getMedical().setCurrent( scenarioInfo.getMedical().getCurrent()+supplier.getAccount());
|
|
||||||
break;
|
|
||||||
|
|
||||||
case "AMMUNITION":
|
|
||||||
scenarioInfo.getAmmunition().setTotal( scenarioInfo.getAmmunition().getTotal()+supplier.getAccount());
|
|
||||||
scenarioInfo.getAmmunition().setCurrent(scenarioInfo.getAmmunition().getCurrent()+supplier.getAccount());
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
ScenarioTask scenarioTask = new ScenarioTask();
|
ScenarioTask scenarioTask = new ScenarioTask();
|
||||||
scenarioTask.setScenarioId(scenarioId);
|
scenarioTask.setScenarioId(scenarioId);
|
||||||
|
|
@ -107,9 +134,13 @@ public class ScenarioServiceImpl implements ScenarioService {
|
||||||
|
|
||||||
|
|
||||||
List<ScenarioTask> scenarioTasks = scenarioTaskService.queryTaskList(scenarioTask);
|
List<ScenarioTask> scenarioTasks = scenarioTaskService.queryTaskList(scenarioTask);
|
||||||
|
if(CollectionUtil.isEmpty(scenarioTasks)){
|
||||||
|
scenarioTasks =new ArrayList<>();
|
||||||
|
}
|
||||||
List<SupplierRequest> supplierRequests = supplierRequestService.list(new QueryWrapper<SupplierRequest>().eq("FROM_RESOURCE_ID",resourceId));
|
List<SupplierRequest> supplierRequests = supplierRequestService.list(new QueryWrapper<SupplierRequest>().eq("FROM_RESOURCE_ID",resourceId));
|
||||||
|
if(CollectionUtil.isEmpty(supplierRequests)){
|
||||||
|
supplierRequests =new ArrayList<>();
|
||||||
|
}
|
||||||
scenarioInfo.setScenarioTasks(scenarioTasks);
|
scenarioInfo.setScenarioTasks(scenarioTasks);
|
||||||
scenarioInfo.setStaffList(staffList);
|
scenarioInfo.setStaffList(staffList);
|
||||||
scenarioInfo.setOrgPostList(orgPostList);
|
scenarioInfo.setOrgPostList(orgPostList);
|
||||||
|
|
|
||||||
|
|
@ -39,7 +39,7 @@ public class WebsocketMsgWrapper {
|
||||||
responseCmdInfo.setRoom(roomId);
|
responseCmdInfo.setRoom(roomId);
|
||||||
try {
|
try {
|
||||||
JSONObject msgObj = (JSONObject) JSON.parse(msg);
|
JSONObject msgObj = (JSONObject) JSON.parse(msg);
|
||||||
if(msgObj.getString("cmdType").equals("scenarioInfo")){
|
if(msgObj.getString("cmdType").equals("scenarioRunningInfo")){
|
||||||
if( redisUtil == null) {
|
if( redisUtil == null) {
|
||||||
redisUtil = SpringUtil.getBean(RedisUtil.class);
|
redisUtil = SpringUtil.getBean(RedisUtil.class);
|
||||||
}
|
}
|
||||||
|
|
@ -52,8 +52,25 @@ public class WebsocketMsgWrapper {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
responseCmdInfo.setData(JSONArray.toJSONString(allScenario));
|
responseCmdInfo.setData(JSONArray.toJSONString(allScenario));
|
||||||
|
responseCmdInfo.setCmdType("scenarioInfo");
|
||||||
}
|
}
|
||||||
responseCmdInfo.setCmdType("scenarioInfo");
|
if(msgObj.getString("cmdType").equals("scenarioInfo")){
|
||||||
|
List<ScenarioResource> scenarioResourceList = this.scenarioResourceService.list(new QueryWrapper<ScenarioResource>().eq("scenario_id",scenarioId));
|
||||||
|
ScenarioService scenarioService = SpringUtil.getBean(ScenarioService.class);
|
||||||
|
if(scenarioService != null){
|
||||||
|
JSONArray allScenario = new JSONArray();
|
||||||
|
for(ScenarioResource scenarioResource : scenarioResourceList) {
|
||||||
|
ScenarioInfo scenarioInfo = scenarioService.listScenarioInfo(scenarioResource.getScenarioId(), roomId, scenarioResource.getId());
|
||||||
|
String scenarioInfoStr = com.alibaba.fastjson2.JSON.toJSONString(scenarioInfo);
|
||||||
|
allScenario.add(scenarioInfoStr);
|
||||||
|
}
|
||||||
|
responseCmdInfo.setData(JSONArray.toJSONString(allScenario));
|
||||||
|
}else {
|
||||||
|
log.warn("=============scenarioService is null================================");
|
||||||
|
}
|
||||||
|
responseCmdInfo.setCmdType("scenarioInfo");
|
||||||
|
}
|
||||||
|
|
||||||
Global.sendCmdInfoQueue.add(responseCmdInfo);
|
Global.sendCmdInfoQueue.add(responseCmdInfo);
|
||||||
}catch (Exception ex){
|
}catch (Exception ex){
|
||||||
ex.printStackTrace();
|
ex.printStackTrace();
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user