structure scanning work
All checks were successful
studiorailgun/Renderer/pipeline/head This commit looks good
All checks were successful
studiorailgun/Renderer/pipeline/head This commit looks good
This commit is contained in:
parent
99402e5656
commit
6ab5c3de67
@ -1690,6 +1690,11 @@ Code cleanup
|
||||
More code cleanup
|
||||
Cleanup some TODOs
|
||||
|
||||
(05/06/2025)
|
||||
Refactor block actions
|
||||
Placing fabs/blocks triggers structure scanning service
|
||||
Try closing ai manager threads on engine close
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@ -134,6 +134,9 @@ public class ThreadManager {
|
||||
TerrainChunk.haltThreads();
|
||||
FoliageModel.haltThreads();
|
||||
BlockChunkEntity.haltThreads();
|
||||
if(Globals.aiManager != null && Globals.aiManager.getPathfindingService() != null){
|
||||
Globals.aiManager.getPathfindingService().shutdown();
|
||||
}
|
||||
|
||||
//
|
||||
//interrupt all threads
|
||||
|
||||
@ -13,7 +13,6 @@ import electrosphere.client.block.BlockChunkData;
|
||||
import electrosphere.client.terrain.cache.ChunkData;
|
||||
import electrosphere.engine.Globals;
|
||||
import electrosphere.entity.Entity;
|
||||
import electrosphere.entity.state.item.ServerChargeState;
|
||||
import electrosphere.logger.LoggerInterface;
|
||||
import electrosphere.net.parser.net.message.TerrainMessage;
|
||||
import electrosphere.net.server.ServerConnectionHandler;
|
||||
@ -22,7 +21,6 @@ import electrosphere.net.template.ServerProtocolTemplate;
|
||||
import electrosphere.server.datacell.Realm;
|
||||
import electrosphere.server.datacell.ServerWorldData;
|
||||
import electrosphere.server.datacell.utils.EntityLookupUtils;
|
||||
import electrosphere.server.physics.block.editing.ServerBlockEditing;
|
||||
import electrosphere.server.physics.fluid.manager.ServerFluidChunk;
|
||||
import electrosphere.server.physics.terrain.editing.TerrainEditing;
|
||||
import electrosphere.server.physics.terrain.manager.ServerTerrainChunk;
|
||||
@ -89,20 +87,15 @@ public class TerrainProtocol implements ServerProtocolTemplate<TerrainMessage> {
|
||||
case REQUESTEDITBLOCK: {
|
||||
LoggerInterface.loggerNetworking.DEBUG("(Server) Received request to edit block at " + message.getworldX() + " " + message.getworldY() + " " + message.getworldZ());
|
||||
Entity targetEntity = EntityLookupUtils.getEntityById(connectionHandler.getPlayerEntityId());
|
||||
// Realm playerRealm = Globals.realmManager.getEntityRealm(targetEntity);
|
||||
Vector3i worldPos = new Vector3i(message.getworldX(),message.getworldY(),message.getworldZ());
|
||||
Vector3i blockPos = new Vector3i(message.getvoxelX(),message.getvoxelY(),message.getvoxelZ());
|
||||
BlockActions.editBlock(targetEntity, worldPos, blockPos, (short)message.getblockType(), message.getblockEditSize());
|
||||
// ServerBlockEditing.editBlockArea(playerRealm, worldPos, blockPos, (short)message.getblockType(), (short)message.getblockMetadata(), message.getblockEditSize());
|
||||
// ServerChargeState.attemptRemoveCharges(targetEntity, 1);
|
||||
BlockActions.editBlockArea(targetEntity, worldPos, blockPos, (short)message.getblockType(), message.getblockEditSize());
|
||||
} break;
|
||||
case REQUESTPLACEFAB: {
|
||||
Vector3i worldPos = new Vector3i(message.getworldX(),message.getworldY(),message.getworldZ());
|
||||
Vector3i blockPos = new Vector3i(message.getvoxelX(),message.getvoxelY(),message.getvoxelZ());
|
||||
Entity targetEntity = EntityLookupUtils.getEntityById(connectionHandler.getPlayerEntityId());
|
||||
Realm playerRealm = Globals.realmManager.getEntityRealm(targetEntity);
|
||||
ServerBlockEditing.placeBlockFab(playerRealm, worldPos, blockPos, message.getblockRotation(), message.getfabPath());
|
||||
ServerChargeState.attemptRemoveCharges(targetEntity, 1);
|
||||
BlockActions.placeFab(targetEntity, worldPos, blockPos, message.getblockRotation(), message.getfabPath());
|
||||
} break;
|
||||
//all ignored message types
|
||||
case UPDATEFLUIDDATA:
|
||||
|
||||
@ -16,6 +16,11 @@ import electrosphere.server.player.BlockActions;
|
||||
*/
|
||||
public class PlaceBlockNode implements AITreeNode {
|
||||
|
||||
/**
|
||||
* Size of the edit to apply
|
||||
*/
|
||||
static final int EDIT_SIZE = 1;
|
||||
|
||||
@Override
|
||||
public AITreeNodeResult evaluate(Entity entity, Blackboard blackboard) {
|
||||
Vector3d position = BeginStructureNode.getStructureBuildTarget(blackboard);
|
||||
@ -24,7 +29,7 @@ public class PlaceBlockNode implements AITreeNode {
|
||||
|
||||
short blockType = BeginStructureNode.getBuildBlock(blackboard);
|
||||
|
||||
BlockActions.editBlock(entity, chunkPos, blockPos, blockType, 1);
|
||||
BlockActions.editBlockArea(entity, chunkPos, blockPos, blockType, EDIT_SIZE);
|
||||
|
||||
SolveBuildMaterialNode.clearBuildTarget(blackboard);
|
||||
|
||||
|
||||
@ -27,9 +27,11 @@ public class NearbyEntityService implements AIService {
|
||||
for(AI ai : Globals.aiManager.getAIList()){
|
||||
Entity entity = ai.getParent();
|
||||
Realm realm = Globals.realmManager.getEntityRealm(entity);
|
||||
Vector3d position = EntityUtils.getPosition(entity);
|
||||
Collection<Entity> nearbyEntities = realm.getDataCellManager().entityLookup(position, NearbyEntityService.SEARCH_DIST);
|
||||
NearbyEntityService.setNearbyEntities(ai.getBlackboard(), nearbyEntities);
|
||||
if(realm != null){
|
||||
Vector3d position = EntityUtils.getPosition(entity);
|
||||
Collection<Entity> nearbyEntities = realm.getDataCellManager().entityLookup(position, NearbyEntityService.SEARCH_DIST);
|
||||
NearbyEntityService.setNearbyEntities(ai.getBlackboard(), nearbyEntities);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -7,9 +7,12 @@ import electrosphere.entity.Entity;
|
||||
import electrosphere.entity.state.equip.ServerToolbarState;
|
||||
import electrosphere.entity.state.item.ServerChargeState;
|
||||
import electrosphere.entity.types.common.CommonEntityUtils;
|
||||
import electrosphere.entity.types.creature.CreatureUtils;
|
||||
import electrosphere.game.data.block.BlockType;
|
||||
import electrosphere.game.data.item.Item;
|
||||
import electrosphere.net.server.player.Player;
|
||||
import electrosphere.server.datacell.Realm;
|
||||
import electrosphere.server.datacell.ServerWorldData;
|
||||
import electrosphere.server.physics.block.editing.ServerBlockEditing;
|
||||
|
||||
/**
|
||||
@ -25,7 +28,7 @@ public class BlockActions {
|
||||
* @param blockType The type of block to edit to
|
||||
* @param editSize The size of the edit
|
||||
*/
|
||||
public static void editBlock(Entity creature, Vector3i chunkPos, Vector3i blockPos, short blockType, int editSize){
|
||||
public static void editBlockArea(Entity creature, Vector3i chunkPos, Vector3i blockPos, short blockType, int editSize){
|
||||
Realm playerRealm = Globals.realmManager.getEntityRealm(creature);
|
||||
if(ServerToolbarState.hasServerToolbarState(creature)){
|
||||
//check that we have the block equipped
|
||||
@ -34,6 +37,10 @@ public class BlockActions {
|
||||
String equippedItemType = CommonEntityUtils.getEntitySubtype(equippedItem);
|
||||
BlockType blockTypeData = Globals.gameConfigCurrent.getBlockData().getTypeFromId((int)blockType);
|
||||
String goalBlockEntityId = Item.getBlockTypeId(blockTypeData);
|
||||
if(CreatureUtils.hasControllerPlayerId(creature)){
|
||||
Player player = Globals.playerManager.getPlayerFromId(CreatureUtils.getControllerPlayerId(creature));
|
||||
Globals.structureScanningService.queue(player, ServerWorldData.convertLocalBlockToRealSpace(chunkPos, blockPos));
|
||||
}
|
||||
|
||||
if(equippedItemType.equals(goalBlockEntityId)){
|
||||
//place the block
|
||||
@ -43,4 +50,22 @@ public class BlockActions {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Places a fab
|
||||
* @param creature The creature placing the fab
|
||||
* @param chunkPos The chunk position to place at
|
||||
* @param blockPos The block position to place at
|
||||
* @param blockRotation The rotation to apply to the fab
|
||||
* @param fabPath The path to the fab itself
|
||||
*/
|
||||
public static void placeFab(Entity creature, Vector3i chunkPos, Vector3i blockPos, int blockRotation, String fabPath){
|
||||
Realm playerRealm = Globals.realmManager.getEntityRealm(creature);
|
||||
ServerBlockEditing.placeBlockFab(playerRealm, chunkPos, blockPos, blockRotation, fabPath);
|
||||
ServerChargeState.attemptRemoveCharges(creature, 1);
|
||||
if(CreatureUtils.hasControllerPlayerId(creature)){
|
||||
Player player = Globals.playerManager.getPlayerFromId(CreatureUtils.getControllerPlayerId(creature));
|
||||
Globals.structureScanningService.queue(player, ServerWorldData.convertLocalBlockToRealSpace(chunkPos, blockPos));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -2,10 +2,13 @@ package electrosphere.server.service;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
import java.util.Set;
|
||||
|
||||
import org.joml.Vector3d;
|
||||
|
||||
import electrosphere.engine.signal.Signal.SignalType;
|
||||
import electrosphere.logger.LoggerInterface;
|
||||
import electrosphere.engine.Globals;
|
||||
import electrosphere.engine.signal.SignalServiceImpl;
|
||||
import electrosphere.net.server.player.Player;
|
||||
@ -55,7 +58,22 @@ public class StructureScanningService extends SignalServiceImpl {
|
||||
* Simulates the service
|
||||
*/
|
||||
public void simulate(){
|
||||
|
||||
Set<Entry<Player,ScanningJob>> jobs = playerTimeoutMap.entrySet();
|
||||
for(Entry<Player,ScanningJob> job : jobs){
|
||||
if(job.getValue().targetFrame <= Globals.timekeeper.getNumberOfSimFramesElapsed()){
|
||||
//run this job
|
||||
playerTimeoutMap.remove(job.getKey());
|
||||
StructureScanningService.scanForStructure(job.getValue());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Executes a scanning job
|
||||
* @param job The job
|
||||
*/
|
||||
protected static void scanForStructure(ScanningJob job){
|
||||
LoggerInterface.loggerEngine.WARNING("Scan structure at " + job.position);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Loading…
Reference in New Issue
Block a user