From 4c81937edc9c4d30726f36423ca4f733a751aa93 Mon Sep 17 00:00:00 2001 From: Ordo Flammae Date: Wed, 27 Nov 2019 19:35:49 -0600 Subject: [PATCH] Added Radioactive Cloud object. --- .../RadioactiveCloud.java | 30 ++++++++++++++++++- Server/src/main/resources/config.properties | 1 + 2 files changed, 30 insertions(+), 1 deletion(-) diff --git a/Plugin Radioactive Cloud/src/main/java/net/simon987/pluginradioactivecloud/RadioactiveCloud.java b/Plugin Radioactive Cloud/src/main/java/net/simon987/pluginradioactivecloud/RadioactiveCloud.java index ccc16aa..3999d86 100644 --- a/Plugin Radioactive Cloud/src/main/java/net/simon987/pluginradioactivecloud/RadioactiveCloud.java +++ b/Plugin Radioactive Cloud/src/main/java/net/simon987/pluginradioactivecloud/RadioactiveCloud.java @@ -1,4 +1,32 @@ package net.simon987.pluginradioactivecloud; -public class RadioactiveCloud { +import net.simon987.server.GameServer; +import net.simon987.server.game.objects.ControllableUnit; +import net.simon987.server.game.objects.Enterable; +import net.simon987.server.game.objects.GameObject; +import net.simon987.server.game.objects.Radioactive; + +public class RadioactiveCloud extends GameObject implements Radioactive, Enterable { + private final static int CORRUPTION_BLOCK_SIZE = + GameServer.INSTANCE.getConfig().getInt("radioactive_cloud_corruption_block_size"); + + /** + * Called when an object attempts to walk directly into a Enterable object + * + * @param object The game object that attempted to enter + * @return true if successful, false to block the object + */ + @Override + public boolean enter(GameObject object) { + if (object instanceof ControllableUnit) { + ((ControllableUnit) object).getCpu().getMemory().corrupt(CORRUPTION_BLOCK_SIZE); + } + + return true; + } + + @Override + public char getMapInfo() { + return 0; + } } diff --git a/Server/src/main/resources/config.properties b/Server/src/main/resources/config.properties index 7f85c34..7bf0cf6 100644 --- a/Server/src/main/resources/config.properties +++ b/Server/src/main/resources/config.properties @@ -93,6 +93,7 @@ electric_box_damage=5 electric_box_energy_given=70 #RadioactiveObstacle radioactive_obstacle_corruption_block_size=10 +radioactive_cloud_corruption_block_size=40 #SecretKey secret_key=