战斗任务消耗资源代码
This commit is contained in:
parent
5ece6ee204
commit
b6dde358d4
|
|
@ -3,11 +3,8 @@ package com.hivekion.room.bean;
|
||||||
import com.hivekion.room.RoomManager;
|
import com.hivekion.room.RoomManager;
|
||||||
import com.hivekion.room.func.TaskAction;
|
import com.hivekion.room.func.TaskAction;
|
||||||
import com.hivekion.scenario.entity.ScenarioTask;
|
import com.hivekion.scenario.entity.ScenarioTask;
|
||||||
import java.util.concurrent.LinkedBlockingQueue;
|
|
||||||
import java.util.concurrent.ScheduledExecutorService;
|
import java.util.concurrent.*;
|
||||||
import java.util.concurrent.ThreadFactory;
|
|
||||||
import java.util.concurrent.ThreadPoolExecutor;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
import org.springframework.web.reactive.function.client.WebClient;
|
import org.springframework.web.reactive.function.client.WebClient;
|
||||||
|
|
||||||
|
|
@ -75,6 +72,22 @@ public abstract class AbtParentTask implements TaskAction {
|
||||||
public boolean getRoomStatus() {
|
public boolean getRoomStatus() {
|
||||||
return RoomManager.isRunning(roomId);
|
return RoomManager.isRunning(roomId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void createBattleTaskOnTimingHandle(BizTaskOnTiming bizTaskOnTiming){
|
||||||
|
ScheduledExecutorService schedule = Executors.newScheduledThreadPool(
|
||||||
|
1);
|
||||||
|
schedule.scheduleWithFixedDelay(() -> {
|
||||||
|
bizTaskOnTiming.execTask();
|
||||||
|
}, 0, 10, TimeUnit.SECONDS);
|
||||||
|
//房间统一管理定时器;房间关闭后,定时器销毁
|
||||||
|
addScheduledExecutorServiceRefenceToRoom(schedule);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
interface BizTaskOnTiming{
|
||||||
|
|
||||||
|
public void execTask();
|
||||||
}
|
}
|
||||||
|
|
||||||
// 自定义线程工厂
|
// 自定义线程工厂
|
||||||
|
|
|
||||||
|
|
@ -69,7 +69,7 @@ public class BattleRootTask extends AbtParentTask {
|
||||||
public void doSomeThing() {
|
public void doSomeThing() {
|
||||||
this.initBean();
|
this.initBean();
|
||||||
if(this.getRoomStatus()) {
|
if(this.getRoomStatus()) {
|
||||||
long initduringTime = this.getDuringTime();
|
long initDuringTime = this.getDuringTime();
|
||||||
StatisticBean statisticBean = statisticService.statistic(scenarioTask.getResourceId());
|
StatisticBean statisticBean = statisticService.statistic(scenarioTask.getResourceId());
|
||||||
// statisticBean.getAmmunition().getCurrent()
|
// statisticBean.getAmmunition().getCurrent()
|
||||||
//初始化本次战斗任务各种资源数
|
//初始化本次战斗任务各种资源数
|
||||||
|
|
@ -80,90 +80,91 @@ public class BattleRootTask extends AbtParentTask {
|
||||||
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"water",statisticBean.getWater().getCurrent());
|
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"water",statisticBean.getWater().getCurrent());
|
||||||
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"person",statisticBean.getPerson().getCurrent());
|
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"person",statisticBean.getPerson().getCurrent());
|
||||||
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"team",statisticBean.getPerson().getCurrent());
|
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"team",statisticBean.getPerson().getCurrent());
|
||||||
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"duringTime",initduringTime);
|
redisUtil.hset(scenarioTask.getScenarioId()+"-"+roomId+"-"+scenarioTask.getResourceId(),"duringTime",initDuringTime);
|
||||||
log.info("===============================初始化本次战斗任务各种资源数====================================");
|
log.info("===============================初始化本次战斗任务各种资源数====================================");
|
||||||
|
|
||||||
//定时检查统计各种资源消耗量
|
//定时检查统计各种资源消耗量
|
||||||
ScheduledExecutorService schedule = Executors.newScheduledThreadPool(
|
this.createBattleTaskOnTimingHandle(new BizTaskOnTiming() {
|
||||||
1);
|
@Override
|
||||||
schedule.scheduleWithFixedDelay(() -> {
|
public void execTask() {
|
||||||
log.info("===============================定时检查统计各种资源消耗量 begin====================================");
|
log.info("===============================定时检查统计各种资源消耗量 begin====================================");
|
||||||
Double teamConsume = null;
|
Double teamConsume = null;
|
||||||
Long personConsume = null;
|
Long personConsume = null;
|
||||||
Double ammunitionConsume = null;
|
Double ammunitionConsume = null;
|
||||||
Double foodConsume = null;
|
Double foodConsume = null;
|
||||||
Double waterConsume = null;
|
Double waterConsume = null;
|
||||||
Double fuelConsume = null;
|
Double fuelConsume = null;
|
||||||
Double medicalConsume = null;
|
Double medicalConsume = null;
|
||||||
JSONObject jsonObject = new JSONObject();
|
JSONObject jsonObject = new JSONObject();
|
||||||
try {
|
try {
|
||||||
long duringTime = getDuringTime();
|
long duringTime = getDuringTime();
|
||||||
long lastDuringTime = (long) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "duringTime");
|
long lastDuringTime = (long) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "duringTime");
|
||||||
long intervalDuringTime = duringTime - lastDuringTime;
|
long intervalDuringTime = duringTime - lastDuringTime;
|
||||||
double ammunition = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "ammunition");
|
double ammunition = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "ammunition");
|
||||||
double food = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "food");
|
double food = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "food");
|
||||||
double fuel = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "fuel");
|
double fuel = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "fuel");
|
||||||
double medical = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "medical");
|
double medical = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "medical");
|
||||||
double water = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "water");
|
double water = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "water");
|
||||||
int person = (int) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "person");
|
int person = (int) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "person");
|
||||||
double team = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "team");
|
double team = (double) redisUtil.hget(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "team");
|
||||||
|
|
||||||
//
|
//
|
||||||
teamConsume = intervalDuringTime * TEAM_SPREED;
|
teamConsume = intervalDuringTime * TEAM_SPREED;
|
||||||
personConsume = intervalDuringTime * PERSON_SPREED;
|
personConsume = intervalDuringTime * PERSON_SPREED;
|
||||||
ammunitionConsume = intervalDuringTime * AMMUNITION_SPREED;
|
ammunitionConsume = intervalDuringTime * AMMUNITION_SPREED;
|
||||||
foodConsume = intervalDuringTime * FOOD_SPREED;
|
foodConsume = intervalDuringTime * FOOD_SPREED;
|
||||||
waterConsume = intervalDuringTime * WATER_SPREED;
|
waterConsume = intervalDuringTime * WATER_SPREED;
|
||||||
fuelConsume = intervalDuringTime * FUEL_SPREED;
|
fuelConsume = intervalDuringTime * FUEL_SPREED;
|
||||||
medicalConsume = intervalDuringTime * MEDICAL_SPREED;
|
medicalConsume = intervalDuringTime * MEDICAL_SPREED;
|
||||||
|
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "ammunition", ammunition - ammunitionConsume);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "ammunition", ammunition - ammunitionConsume);
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "food", food - foodConsume);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "food", food - foodConsume);
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "fuel", fuel - fuelConsume);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "fuel", fuel - fuelConsume);
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "medical", medical - medicalConsume);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "medical", medical - medicalConsume);
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "water", water - waterConsume);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "water", water - waterConsume);
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "person", person - personConsume);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "person", person - personConsume);
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "team", team - teamConsume);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "team", team - teamConsume);
|
||||||
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "duringTime", duringTime);
|
redisUtil.hset(scenarioTask.getScenarioId() + "-" + roomId + "-" + scenarioTask.getResourceId(), "duringTime", duringTime);
|
||||||
}catch (Exception ex){
|
}catch (Exception ex){
|
||||||
log.error("==============================设置消耗信息失败=============================================",ex.getMessage());
|
log.error("==============================设置消耗信息失败=============================================",ex.getMessage());
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
//推送消耗數據
|
//推送消耗數據
|
||||||
ResponseCmdInfo<JSONObject> sendConsumeMsg = new ResponseCmdInfo<>();
|
ResponseCmdInfo<JSONObject> sendConsumeMsg = new ResponseCmdInfo<>();
|
||||||
jsonObject.put("teamConsume", teamConsume);
|
jsonObject.put("teamConsume", teamConsume);
|
||||||
jsonObject.put("personConsume", personConsume);
|
jsonObject.put("personConsume", personConsume);
|
||||||
jsonObject.put("ammunitionConsume", ammunitionConsume);
|
jsonObject.put("ammunitionConsume", ammunitionConsume);
|
||||||
jsonObject.put("foodConsume", foodConsume);
|
jsonObject.put("foodConsume", foodConsume);
|
||||||
jsonObject.put("waterConsume", waterConsume);
|
jsonObject.put("waterConsume", waterConsume);
|
||||||
jsonObject.put("fuelConsume", fuelConsume);
|
jsonObject.put("fuelConsume", fuelConsume);
|
||||||
jsonObject.put("medicalConsume", medicalConsume);
|
jsonObject.put("medicalConsume", medicalConsume);
|
||||||
sendConsumeMsg.setData(jsonObject);
|
sendConsumeMsg.setData(jsonObject);
|
||||||
Global.sendCmdInfoQueue.add(sendConsumeMsg);
|
Global.sendCmdInfoQueue.add(sendConsumeMsg);
|
||||||
}catch (Exception ex){
|
}catch (Exception ex){
|
||||||
log.error("==================推送消耗數據 失败============================================",ex.getMessage());
|
log.error("==================推送消耗數據 失败============================================",ex.getMessage());
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
LocalDateTime currentDateTime = new Date().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
|
|
||||||
List<SupplierRequest> requestList = new ArrayList<>();
|
|
||||||
Set<Map.Entry<String, Object>> consumeSet = jsonObject.entrySet();
|
|
||||||
for (Map.Entry<String, Object> consumeEntry : consumeSet) {
|
|
||||||
SupplierRequest supplierRequest = new SupplierRequest();
|
|
||||||
supplierRequest.setFromResourceId(scenarioTask.getResourceId());
|
|
||||||
supplierRequest.setSupplierNum((Double) consumeEntry.getValue());
|
|
||||||
supplierRequest.setSupplierType(consumeEntry.getKey());
|
|
||||||
supplierRequest.setGeneralTime(currentDateTime);
|
|
||||||
requestList.add(supplierRequest);
|
|
||||||
}
|
}
|
||||||
supplierRequestService.saveBatch(requestList);
|
|
||||||
}catch (Exception ex){
|
|
||||||
log.error("===========BattleRootTask supplierRequestService.saveBatch error====================",ex.getMessage());
|
|
||||||
}
|
|
||||||
log.info("===============================定时检查统计各种资源消耗量 end====================================");
|
|
||||||
}, 0, 10, TimeUnit.SECONDS);
|
|
||||||
|
|
||||||
//房间统一管理定时器;房间关闭后,定时器销毁
|
try {
|
||||||
addScheduledExecutorServiceRefenceToRoom(schedule);
|
LocalDateTime currentDateTime = new Date().toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
|
||||||
|
List<SupplierRequest> requestList = new ArrayList<>();
|
||||||
|
Set<Map.Entry<String, Object>> consumeSet = jsonObject.entrySet();
|
||||||
|
for (Map.Entry<String, Object> consumeEntry : consumeSet) {
|
||||||
|
SupplierRequest supplierRequest = new SupplierRequest();
|
||||||
|
supplierRequest.setFromResourceId(scenarioTask.getResourceId());
|
||||||
|
supplierRequest.setSupplierNum((Double) consumeEntry.getValue());
|
||||||
|
supplierRequest.setSupplierType(consumeEntry.getKey());
|
||||||
|
supplierRequest.setGeneralTime(currentDateTime);
|
||||||
|
requestList.add(supplierRequest);
|
||||||
|
}
|
||||||
|
supplierRequestService.saveBatch(requestList);
|
||||||
|
}catch (Exception ex){
|
||||||
|
log.error("===========BattleRootTask supplierRequestService.saveBatch error====================",ex.getMessage());
|
||||||
|
}
|
||||||
|
log.info("===============================定时检查统计各种资源消耗量 end====================================");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user