Jump to content

[1.12.2][SOLVED] Issue with update() in tile entity


Recommended Posts

Posted
7 hours ago, jabelar said:

Well it is a "cheat" in the sense that ITickable should not need any such silliness. Think about it -- a furnace happily cooks something as an ITickable and any animated tile entity is happily updated every tick. You should really find the root cause of the problem. But if it works I guess use it. Something is still wrong with your implementation in my opinion though and it might bite you later.

 When I get deeper in to modding, I'll probably be able to find the root cause of my problem. Now i just want to continue my mod development.

 

Thank you all for help !

  • Like 1
Posted

Can it be ? Have I solved my problem ?!

I've added the following method to my tile entity, and update() hasn't failed yet!

 

@Override
public void onLoad() {
		 posB = this.getPos();
	 }

 

This code changes the way I get the BlockPos, which i used to get from a set method in tile entity i called from onBlockPlacedBy.

 @diesieben07

 

 

 

Posted
1 hour ago, uncleofbob said:

Can it be ? Have I solved my problem ?!

I've added the following method to my tile entity, and update() hasn't failed yet!

 


@Override
public void onLoad() {
		 posB = this.getPos();
	 }

 

This code changes the way I get the BlockPos, which i used to get from a set method in tile entity i called from onBlockPlacedBy.

 @diesieben07 ?

Why the hell are you storing your TE's position? TEs already do this, that's what getPos() does.

  • Like 1

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Posted

I really don't get why this isn't working for you. I have tile entities in my mods and I simply implement the ITickable interface and I can watch them process things per tick exactly as expected. I don't do any of this scheduling updates stuff. You can try my example mod and look at the TileEntityCompactor here: https://github.com/jabelar/ExampleMod-1.12/blob/master/src/main/java/com/blogspot/jabelarminecraft/examplemod/tileentities/TileEntityCompactor.java

  • Like 1

Check out my tutorials here: http://jabelarminecraft.blogspot.com/

Posted (edited)

Hi again! It's working now! It was all related to how I used the position wrong.

Somehow update() ran when the block was placed in certain quadrants related to the first block i placed. This made me change the way I get my Tile entity pos.

Now I just access "this.getPos()" in methods that need it. The onLoad() wasn't necessary either.

 

And yes, I scrapped the scheduleBlockUpdate workaround!

 

Again, thank you all for replies and using your time on my problem! :)

 

Edited by uncleofbob
Posted
1 hour ago, uncleofbob said:

Hi again! It's working now! It was all related to how I used the position wrong.

Somehow update() ran when the block was placed in certain quadrants related to the first block i placed. This made me change the way I get my Tile entity pos.

Now I just access "this.getPos()" in methods that need it. The onLoad() wasn't necessary either.

 

And yes, I scrapped the scheduleBlockUpdate workaround!

 

Again, thank you all for replies and using your time on my problem! :)

 

I don't understand what you mean by this? I was testing with just System.out messages and got nothing in the logs (junk or server). Could you please show us the code involved?

Posted

I know the names of block and tile entity class is a bit odd. And my use of variables could be less. It will be changed.

 

Block:

public class JdwBlockBitumen extends Block implements IHasModel, ITileEntityProvider{
	
	public JdwBlockBitumen(String name, Material material) 
	{
		super(material);
		setUnlocalizedName(name);
		setRegistryName(name);
		setCreativeTab(CreativeTabs.MISC);
		setHarvestLevel("pick_axe", 1);
		
	}
	
	@Override
	public boolean hasTileEntity(IBlockState state) {
		return true;
	}
	
	@Override
	public TileEntity createNewTileEntity(final World worldIn, int meta) {
		return new JdwOSDigger();
	}
	
	@Override
	public void onBlockAdded(World worldIn, BlockPos pos, IBlockState state) {
	}
	

	@Override
	public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ)
    {
        if (!worldIn.isRemote )
        {
            final JdwOSDigger tileEntity = (JdwOSDigger) worldIn.getTileEntity(pos);
            
            if(tileEntity != null) {

            	tileEntity.toggleActive();  	
            }      
        }

            return true;
        
    }
	@Override
	public void onBlockPlacedBy(World worldIn, BlockPos pos, IBlockState state, EntityLivingBase placer, ItemStack stack) {
	
	}
  
	@Override
	public void breakBlock(World worldIn, BlockPos pos, IBlockState state) {
		super.breakBlock(worldIn, pos, state);
	}
	
	
	//registers model
	@Override
	public void registerModels() 
	{
		DerpWorld.proxy.registerItemRenderer(Item.getItemFromBlock(this), 0, "inventory");
	}


}

Tile Entity:

public class JdwOSDigger extends TileEntity implements ITickable{

	
	private boolean aktivitas;
	private List<BlockPos> AREA = new ArrayList<BlockPos>();
	private int radi;
	private int index;
	private int tickCounter;
	
	public JdwOSDigger() {
		radi = 0;
		index = 0;
		tickCounter = 0;
		aktivitas = false;		
	}

	
	public void toggleActive() {
		if (aktivitas) {
			aktivitas = false;
			System.out.println("Activated: " + aktivitas + ",   Is valid?: " + !this.isInvalid());
		}
		else {
			aktivitas = true;
			System.out.println("Activated: " + aktivitas + " ,   Is valid? " + !this.isInvalid());
			mapQuarry(6, this.getPos());  //here is where I call the Tile Entity pos
			
		}
	}
	
	
	public void mapQuarry (int radi, BlockPos pos) {
	
		List<BlockPos> l = new ArrayList<BlockPos>();
		int[] squares = new int[radi];
		BlockPos qC = null; 
		int bx, by, bz = 0;

		for(int k = 0; k<4; k++) {

			switch(k){
			case 0: qC = pos.add(radi+1, 0, radi+1); 
					break;
			case 1: qC = pos.add(-(radi+1), 0, radi+1); 
					break;
			case 2: qC = pos.add(radi+1, 0, -(radi+1)); 
					break;
			case 3: qC = pos.add(-(radi+1), 0, -(radi+1)); 
					break;
			}
			
			for(int e = 0; e<radi/2; e++) {
				for(int i = -radi+e; i <= radi-e; i++) {
					for (int j = -radi+e; j<=radi-e; j++) {
						bx = qC.getX() + i;
						bz = qC.getZ() + j;
						by = qC.getY() - 1 - e;
						
						BlockPos pos2 = new BlockPos( bx , by, bz );
						l.add(pos2);

					}
				}
			}
		}
		
		AREA.addAll(l);	
		System.out.println("map quarry finished, Testing AREA[4] : " + AREA.get(4));
	}	
  
	public void readFromNBT(NBTTagCompound compound)
    {
        super.readFromNBT(compound);
        aktivitas = compound.getBoolean("hore");
       tickCounter = compound.getInteger("kuse");
       index = compound.getInteger("lespe");
    }
	
    public NBTTagCompound writeToNBT(NBTTagCompound compound)
    {
        super.writeToNBT(compound);
        //compound.setByte();
       compound.setInteger("lespe", index);
       compound.setInteger("kuse", tickCounter);
       compound.setBoolean("hore", aktivitas);
        return compound;
    }

    @Override
	public void update() 
	{
		if (!world.isRemote){
			if(aktivitas)  {
				tickCounter++;
				if (tickCounter==20) {
					world.destroyBlock(AREA.get(index), false);
					System.out.println("Destroyed block at:  " + AREA.get(index) );
					index++;
					tickCounter = 0;
				}
			}
		}
	}

 

 

 

  • Like 1
Posted
34 minutes ago, uncleofbob said:

@Override public void update() { if (!world.isRemote){ if(aktivitas) { tickCounter++; if (tickCounter==20) { world.destroyBlock(AREA.get(index), false); System.out.println("Destroyed block at: " + AREA.get(index) ); index++; tickCounter = 0; } } } }

This was the part I was interested in. But after reading your post again I think I understood and replaced everything with the get methods in my update method. I'm getting it to work with the classes now as well. If your's breaks again, try replacing the world member with the getWorld method too.

 

Thanks for keeping on this, I had to write almost a hundred recipe files today so I haven't had time to dig more on it. lol It didn't occur to me to look at the members being referenced in the functions.

  • Like 1

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
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.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • When I first heard about Bitcoin back in 2018, I was skeptical. The idea of a decentralized, digital currency seemed too good to be true. But I was intrigued as I learned more about the technology behind it and its potential. I started small, investing just a few hundred dollars, dipping my toes into the cryptocurrency waters. At first, it was exhilarating to watch the value of my investment grow exponentially. I felt like I was part of the future, an early adopter of this revolutionary new asset. But that euphoria was short-lived. One day, I logged into my digital wallet only to find it empty - my Bitcoin had vanished without a trace. It turned out that the online exchange I had trusted had been hacked, and my funds were stolen. I was devastated, both financially and emotionally. All the potential I had seen in Bitcoin was tainted by the harsh reality that with decentralization came a lack of regulation and oversight. My hard-earned money was gone, lost to the ether of the digital world. This experience taught me a painful lesson about the price of trust in the uncharted territory of cryptocurrency. While the technology holds incredible promise, the risks can be catastrophic if you don't approach it with extreme caution. My Bitcoin investment gamble had failed, and I was left to pick up the pieces, wiser but poorer for having placed my faith in the wrong hands. My sincere appreciation goes to MUYERN TRUST HACKER. You are my hero in recovering my lost funds. Send a direct m a i l ( muyerntrusted ( @ ) mail-me ( . )c o m ) or message on whats app : + 1 ( 4-4-0 ) ( 3 -3 -5 ) ( 0-2-0-5 )
    • You could try posting a log (if there is no log at all, it may be the launcher you are using, the FAQ may have info on how to enable the log) as described in the FAQ, however this will probably need to be reported to/remedied by the mod author.
    • So me and a couple of friends are playing with a shitpost mod pack and one of the mods in the pack is corail tombstone and for some reason there is a problem with it, where on death to fire the player will get kicked out of the server and the tombstone will not spawn basically deleting an entire inventory, it doesn't matter what type of fire it is, whether it's from vanilla fire/lava, or from modded fire like ice&fire/lycanites and it's common enough to where everyone on the server has experienced at least once or twice and it doesn't give any crash log. a solution to this would be much appreciated thank you!
    • It is 1.12.2 - I have no idea if there is a 1.12 pack
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.