战斗任务消耗资源代码

This commit is contained in:
wangwenhua 2025-09-18 17:30:12 +08:00
parent 5ece6ee204
commit b6dde358d4
2 changed files with 98 additions and 84 deletions

View File

@ -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();
} }
// 自定义线程工厂 // 自定义线程工厂

View File

@ -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====================================");
}
});
} }