mirror of
				https://github.com/mcMMO-Dev/mcMMO.git
				synced 2025-10-25 23:43:44 +02:00 
			
		
		
		
	Fix GT replant sometimes planting floating plants
This commit is contained in:
		| @@ -11,8 +11,11 @@ import org.bukkit.block.BlockState; | ||||
| import org.bukkit.block.data.Ageable; | ||||
| import org.bukkit.block.data.BlockData; | ||||
| import org.bukkit.block.data.Directional; | ||||
| import org.bukkit.block.data.type.Cocoa; | ||||
| import org.bukkit.event.block.BlockBreakEvent; | ||||
| import org.bukkit.scheduler.BukkitRunnable; | ||||
| import org.jetbrains.annotations.NotNull; | ||||
| import org.jetbrains.annotations.Nullable; | ||||
|  | ||||
| public class DelayedCropReplant extends BukkitRunnable { | ||||
|  | ||||
| @@ -21,7 +24,7 @@ public class DelayedCropReplant extends BukkitRunnable { | ||||
|     private final Material cropMaterial; | ||||
|     private boolean wasImmaturePlant; | ||||
|     private final BlockBreakEvent blockBreakEvent; | ||||
|     private BlockFace cropFace; | ||||
|     private @Nullable BlockFace cropFace; | ||||
|  | ||||
|     /** | ||||
|      * Replants a crop after a delay setting the age to desiredCropAge | ||||
| @@ -48,6 +51,7 @@ public class DelayedCropReplant extends BukkitRunnable { | ||||
|     public void run() { | ||||
|         Block cropBlock = cropLocation.getBlock(); | ||||
|         BlockState currentState = cropBlock.getState(); | ||||
|         PlantAnchorType plantAnchorType = PlantAnchorType.NORMAL; | ||||
|  | ||||
|         //Remove the metadata marking the block as recently replanted | ||||
|         new markPlantAsOld(blockBreakEvent.getBlock().getLocation()).runTaskLater(mcMMO.p, 10); | ||||
| @@ -81,6 +85,10 @@ public class DelayedCropReplant extends BukkitRunnable { | ||||
|                 directional.setFacing(cropFace); | ||||
|  | ||||
|                 newState.setBlockData(directional); | ||||
|  | ||||
|                 if(newData instanceof Cocoa) { | ||||
|                     plantAnchorType = PlantAnchorType.COCOA; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             //Age the crop | ||||
| @@ -89,15 +97,69 @@ public class DelayedCropReplant extends BukkitRunnable { | ||||
|             newState.setBlockData(ageable); | ||||
|  | ||||
|  | ||||
|             newState.update(true); | ||||
|             newState.update(true, true); | ||||
|  | ||||
|             //Play an effect | ||||
|             ParticleEffectUtils.playGreenThumbEffect(cropLocation); | ||||
|             new PhysicsBlockUpdate(newState.getBlock(), cropFace, plantAnchorType).runTaskLater(mcMMO.p, 1); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private enum PlantAnchorType { | ||||
|         NORMAL, | ||||
|         COCOA | ||||
|     } | ||||
|  | ||||
|     private static class PhysicsBlockUpdate extends BukkitRunnable { | ||||
|         private final Block plantBlock; | ||||
|         private final PlantAnchorType plantAnchorType; | ||||
|         private BlockFace plantFace; | ||||
|  | ||||
|         private PhysicsBlockUpdate(@NotNull Block plantBlock, @Nullable BlockFace plantFace, @NotNull PlantAnchorType plantAnchorType) { | ||||
|             this.plantBlock = plantBlock; | ||||
|             this.plantAnchorType = plantAnchorType; | ||||
|  | ||||
|             if(plantFace != null) { | ||||
|                 this.plantFace = plantFace; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         @Override | ||||
|         public void run() { | ||||
|             //Update neighbors | ||||
|             switch (plantAnchorType) { | ||||
|                 case COCOA: | ||||
|                     checkPlantIntegrity(plantFace); | ||||
|                     break; | ||||
|                 case NORMAL: | ||||
|                     checkPlantIntegrity(BlockFace.DOWN); | ||||
|                     break; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private void checkPlantIntegrity(@NotNull BlockFace blockFace) { | ||||
|             Block neighbor = plantBlock.getRelative(blockFace); | ||||
|  | ||||
|             if(plantAnchorType == PlantAnchorType.COCOA) { | ||||
|                 if(!neighbor.getType().toString().toLowerCase().contains("jungle")) { | ||||
|                     plantBlock.breakNaturally(); | ||||
|                 } | ||||
|             } else { | ||||
|                 switch (neighbor.getType()) { | ||||
|                     case AIR: | ||||
|                     case CAVE_AIR: | ||||
|                     case WATER: | ||||
|                     case LAVA: | ||||
|                         plantBlock.breakNaturally(); | ||||
|                         break; | ||||
|                     default: | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|  | ||||
|  | ||||
|     private static class markPlantAsOld extends BukkitRunnable { | ||||
|  | ||||
|         private final Location cropLoc; | ||||
|   | ||||
| @@ -28,7 +28,7 @@ public class StringUtils { | ||||
|     } | ||||
|  | ||||
|     public static String ticksToSeconds(double ticks) { | ||||
|         return shortDecimal.format(ticks / 20) + "s"; | ||||
|         return shortDecimal.format(ticks / 20); | ||||
|     } | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 nossr50
					nossr50