Jump to content
Search In
  • More options...
Find results that contain...
Find results in...

Recommended Posts

Hi,

I am giving you code that lets you let the block do something when you switch it on with Redstone. It is of course for 1.16 but can updated with the same principles. You just have to code in the actions or statements into "onRedstoneActivated". This will work if the redstone is already on and you place it where to signal is leading towards being used in "onPlace". There is example code in here that is optional and can be deleted... I have taged it with "optional"

package com.blakegale.test;

import net.minecraft.block.Block;
import net.minecraft.block.BlockState;
import net.minecraft.entity.EntityType;
import net.minecraft.entity.SpawnReason;
import net.minecraft.util.DamageSource;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.server.ServerWorld;

public class DemonBlock extends Block {
	
	public DemonBlock(Properties properties) {
		super(properties);
	}
	
	//Being used as the redstone detection method
	@Override
	public void neighborChanged(BlockState state, World world, BlockPos pos, Block block, BlockPos pos_2, boolean Boolean) {
		if (redstoneIsActivated(world, pos)) { 
			onRedstoneActivated(world, pos, block, Boolean);
		}
	}
	
  	//Also being used as Redstone Detection except it automatically switches on when you place the block down
	@Override
	public void onPlace(BlockState state, World world, BlockPos pos, BlockState state_2, boolean Boolean) {
		if (redstoneIsActivated(world, pos)) {
			onRedstoneActivated(world, pos, state.getBlock(), Boolean);
		}
	}
	
	//if redstone signal is activated
	private boolean redstoneIsActivated(World world, BlockPos pos) {
		if (world.hasNeighborSignal(pos)) {
			return true;
		}
		return false;
	}
	
	//All of the block actions/statements when turned on by Redstone
	protected static final void onRedstoneActivated (World world, BlockPos pos, Block block, boolean Boolean) {

/*
 * 		actual body of statements, of when block is activated by Redstone
*/
		
		//example code, optional
		killAllPlayers (world, pos);
		
		//example code, optional
		EntityType.WITHER.spawn(((ServerWorld) world), null, null, new BlockPos(pos.getX(), pos.getY()+1, pos.getZ()), SpawnReason.COMMAND, Boolean, Boolean);
		
	}
	
	//The thing that kills all the players. This method is optional
	protected static final void killAllPlayers(World world, BlockPos pos) {
		for (int i = 0; i < world.players().size(); i++) {
			world.players().get(i).hurt((new DamageSource("activatingtheblock")).bypassArmor(), Float.MAX_VALUE);
		}
	}

}

This is just the block class name and package importations, with the constructor. This is created by creating the class, adding "extend Block", and creating a new instance of this in wherever you instantiate and register your block items and variables 

package com.blakegale.test;

import net.minecraft.block.Block;
import net.minecraft.block.BlockState;
import net.minecraft.entity.EntityType;
import net.minecraft.entity.SpawnReason;
import net.minecraft.util.DamageSource;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.server.ServerWorld;

public class DemonBlock extends Block {
	
	public DemonBlock(Properties properties) {
		super(properties);
	}

This code is activated when anything around it is changed. The if statement checks the neighbouring blocks if it is being powered by redstone and then calls the "onRedstoneIsActivated" method

	//Being used as the redstone detection method
	@Override
	public void neighborChanged(BlockState state, World world, BlockPos pos, Block block, BlockPos pos_2, boolean Boolean) {
		if (redstoneIsActivated(world, pos)) { 
			onRedstoneActivated(world, pos, block, Boolean);
		}
	}

Same story with this one but is activated as soon as it is placed and is used to automatically switch on if there's already redstone activated and will activate the actions show down below. You don't need this, lots things like iron doors don't turn on automatically do actions if you place them down next to activated Redstone Signal, instead of turning them on after they've been placed

  	//Also being used as Redstone Detection except it automatically switches on when you place the block down
	@Override
	public void onPlace(BlockState state, World world, BlockPos pos, BlockState state_2, boolean Boolean) {
		if (redstoneIsActivated(world, pos)) {
			onRedstoneActivated(world, pos, state.getBlock(), Boolean);
		}
	}
	

This one is the method is the one that is called when it's checking if it's being activated by redstone, if it does have a signal it will return true and that "true" will be used by the if statement to activate the code that does all the actions when it is turned off. After that is "return false;" which is the default and so will turn off the if statement and won't work

	//if redstone signal is activated
	private boolean redstoneIsActivated(World world, BlockPos pos) {
		if (world.hasNeighborSignal(pos)) {
			return true;
		}
		return false;
	}
	

This is the actual actions code method and will do whatever you want and is being called by the first two previous methods

	//All of the block actions/statements when turned on by Redstone
	protected static final void onRedstoneActivated (World world, BlockPos pos, Block block, boolean Boolean) {

/*
 * 		actual body of statements, of when block is activated by Redstone
*/
		
		//example code, optional
		killAllPlayers (world, pos);
		
		//example code, optional
		EntityType.WITHER.spawn(((ServerWorld) world), null, null, new BlockPos(pos.getX(), pos.getY()+1, pos.getZ()), SpawnReason.COMMAND, Boolean, Boolean);
		
	}

This statement (underneath the comments) calls a method that will kill all the player. You don't need it

		//example code, optional
		killAllPlayers (world, pos);

Like this:

	//The thing that kills all the players. This method is optional
	protected static final void killAllPlayers(World world, BlockPos pos) {
		for (int i = 0; i < world.players().size(); i++) {
			world.players().get(i).hurt((new DamageSource("activatingtheblock")).bypassArmor(), Float.MAX_VALUE);
		}
	}

What it does is it gets an array or the code equivalent of a list of information and gets the "size()" or how many players are listed on the server

 

This:

		//example code, optional
		EntityType.WITHER.spawn(((ServerWorld) world), null, null, new BlockPos(pos.getX(), pos.getY()+1, pos.getZ()), SpawnReason.COMMAND, Boolean, Boolean);

takes the EntityType "Wither" and spawns it in the world. You don't need this either

Edited by Noxxous
Had to explain all of the different functions of the code
Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Recently Browsing

    No registered users viewing this page.

  • Posts

    • Then give us a log of you running on a supported java version.
    • i already tried downloading java 8,  the servers always worked up until now  
    • Whenever i start it this showns   C:\Users\sidne\OneDrive\Desktop\Japanese Themed>java -Xmx4096M -Xms4096M -jar forgeserver.jar nogui 2021-04-16 07:33:50,531 main WARN Advanced terminal features are not available in this environment [07:33:50] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher running: args [--gameDir, ., --launchTarget, fmlserver, --fml.forgeVersion, 35.1.4, --fml.mcpVersion, 20201102.104115, --fml.mcVersion, 1.16.4, --fml.forgeGroup, net.minecraftforge, nogui] [07:33:50] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher 8.0.6+85+master.325de55 starting: java version 16 by Oracle Corporation Exception in thread "main" java.lang.IllegalAccessError: class cpw.mods.modlauncher.SecureJarHandler (in unnamed module @0x55a1c291) cannot access class sun.security.util.ManifestEntryVerifier (in module java.base) because module java.base does not export sun.security.util to unnamed module @0x55a1c291         at cpw.mods.modlauncher.SecureJarHandler.lambda$static$1(SecureJarHandler.java:41)         at cpw.mods.modlauncher.api.LamdbaExceptionUtils.uncheck(LamdbaExceptionUtils.java:95)         at cpw.mods.modlauncher.SecureJarHandler.<clinit>(SecureJarHandler.java:41)         at cpw.mods.modlauncher.Launcher.lambda$new$6(Launcher.java:55)         at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708)         at cpw.mods.modlauncher.api.TypesafeMap.computeIfAbsent(TypesafeMap.java:52)         at cpw.mods.modlauncher.api.TypesafeMap.computeIfAbsent(TypesafeMap.java:47)         at cpw.mods.modlauncher.Environment.computePropertyIfAbsent(Environment.java:62)         at cpw.mods.modlauncher.Launcher.<init>(Launcher.java:55)         at cpw.mods.modlauncher.Launcher.main(Launcher.java:66)         at net.minecraftforge.server.ServerMain$Runner.runLauncher(ServerMain.java:63)         at net.minecraftforge.server.ServerMain$Runner.access$100(ServerMain.java:60)         at net.minecraftforge.server.ServerMain.main(ServerMain.java:57) C:\Users\sidne\OneDrive\Desktop\Japanese Themed>PAUSE Press any key to continue . . . PLEASE HELP  
    • I know that the latest version of forge no longer uses the forge but the mojang mappings therefore i cannot find some methods is there a list or something similar where i can find the new name of the method I would find the methods myself, if not most of the classes look like this: here are some methods with their old names VoxelShapes#combineAndSimplify Block#updatePostPlacement Block#allowsMovement does anyone know the new mapping names? and does anyone have any idea why many classes are not readable / look strange?  
  • Topics

  • Who's Online (See full list)

×
×
  • Create New...

Important Information

By using this site, you agree to our Privacy Policy.