Jump to content

Problem with TileEntitySpecialRenderer


daafganggdg

Recommended Posts

Hey guys,

I have a block with a TileEntityXY and a TileEntitySpecialRenderer, when the block is added i get the TileEntity with world.getTileEntity and cast it to TileEntityXY then set a boolean of TileEntityXY to true, in the method

public void renderTileEntityAt(TileEntity entity, double x, double y, double z, float f) {

of my TileEntitySpecialRenderer

i cast the entity again to TileEntityXY and get the boolean. and boom its false?

I don't get what I'm doin wrong.. Am I missunderstanding how casting variables work? (And no, i cant use the metadata)

Link to comment
Share on other sites

Sounds like you didn't use

 

@Override
    public TileEntity createNewTileEntity(World world, int meta) { return new TileEntityXY(); }

 

in your block class. Casting the TileEntity in the constructor won't make it a TileEntityXY. So it never saves your boolean.

Link to comment
Share on other sites

I read it as

 

I have a block with a TileEntityXY and a TileEntitySpecialRenderer, when the onBlockPlaced is called, i get the TileEntity with world.getTileEntity and cast it to TileEntityXY then set a boolean of TileEntityXY to true.

 

Then, in the method

public void renderTileEntityAt(TileEntity entity, double x, double y, double z, float f) {

of my TileEntitySpecialRenderer

i cast the entity again to TileEntityXY and get the boolean. and boom its false?

I don't get what I'm doin wrong.. Am I missunderstanding how casting variables work? (And no, i cant use the metadata)

Link to comment
Share on other sites

GetDescriptionPacket is what packet gets sent when the tile entity needs to update data (I know it gets sent on world load, I'm not sure when else). onDataPacket is what happens when the packet gets received.

Check out my mod, Realms of Chaos, here.

 

If I helped you, be sure to press the "Thank You" button!

Link to comment
Share on other sites

When I do that package sending every time I render my block, isnt that going to slow down the performance?

cause the block is actually going to connect visually to other blocks, just in more possible ways than I could use the metadata for, So would it be a better idea I just check for the blocks around in my render method?

Link to comment
Share on other sites

Sry but I don't really understand what that should do.. I came up with that code

    public Packet getDescriptionPacket()
    {
    	NBTTagCompound nbt = new NBTTagCompound();
	for(int i = 0; i < 8; i++) {
		nbt.setBoolean("connections" + i, connections[i]);
	}	
        return new S35PacketUpdateTileEntity(var1, var2, var3, var4, nbt);
    }

what are the other parameters for the S35PacketUpdateTileEntity?

what do I have to do in the onDataPacket

and how is that goin to help me getting the booleans in my Renderer class?

Link to comment
Share on other sites

Uhhm Im not that sure anymore if I need that package thing, I tried it with checking for the same blocks to be around in my Renderer class, placed around 100 of my blocks into the world and i still have 60 fps (as always) and no spikes or anything, what do you think, is that a bad programming technique?

 

 

 

  public void renderModel(float f5,World world, int x, int y, int z) {

  Shape1.render(f5);

  if(world.getBlock(x-1, y, z) == FMItems.tableBlock){

  if(world.getBlock(x, y, z-1) == FMItems.tableBlock){

  if(world.getBlock(x-1, y, z-1) == FMItems.tableBlock){

 

  Type13.render(f5);

  } else {

 

  Type231.render(f5);

  Type232.render(f5);

  Type261.render(f5);

  Type262.render(f5);

  }

  } else {

 

  Type231.render(f5);

  Type232.render(f5);

  }

  } else if(world.getBlock(x, y, z-1) == FMItems.tableBlock){

 

  Type261.render(f5);

  Type262.render(f5);

  } else {

 

  Type321.render(f5);

  Type322.render(f5);

  }

 

 

  if(world.getBlock(x+1, y, z) == FMItems.tableBlock){

  if(world.getBlock(x, y, z-1) == FMItems.tableBlock){

  if(world.getBlock(x+1, y, z-1) == FMItems.tableBlock){

 

  Type11.render(f5);

  } else {

 

  Type241.render(f5);

  Type242.render(f5);

  Type251.render(f5);

  Type252.render(f5);

  }

  } else {

 

  Type241.render(f5);

  Type242.render(f5);

  }

  } else if(world.getBlock(x, y, z-1) == FMItems.tableBlock){

 

  Type251.render(f5);

  Type252.render(f5);

  } else {

 

  Type311.render(f5);

  Type312.render(f5);

  }

 

 

  if(world.getBlock(x+1, y, z) == FMItems.tableBlock){

  if(world.getBlock(x, y, z+1) == FMItems.tableBlock){

  if(world.getBlock(x+1, y, z+1) == FMItems.tableBlock){

 

  Type12.render(f5);

  } else {

 

  Type211.render(f5);

  Type212.render(f5);

  Type271.render(f5);

  Type272.render(f5);

  }

  } else {

 

  Type211.render(f5);

  Type212.render(f5);

  }

  } else if(world.getBlock(x, y, z+1) == FMItems.tableBlock){

 

  Type271.render(f5);

  Type272.render(f5);

  } else {

 

  Type341.render(f5);

  Type342.render(f5);

  }

 

 

  if(world.getBlock(x-1, y, z) == FMItems.tableBlock){

  if(world.getBlock(x, y, z+1) == FMItems.tableBlock){

  if(world.getBlock(x-1, y, z+1) == FMItems.tableBlock){

 

  Type14.render(f5);

  } else {

 

  Type221.render(f5);

  Type222.render(f5);

  Type281.render(f5);

  Type282.render(f5);

  }

  } else {

 

  Type221.render(f5);

  Type222.render(f5);

  }

  } else if(world.getBlock(x, y, z+1) == FMItems.tableBlock){

 

  Type281.render(f5);

  Type282.render(f5);

  } else {

 

  Type331.render(f5);

  Type332.render(f5);

  }

 

  }

 

 

 

Link to comment
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.
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.



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Minecraft opened, but when I went to create a new world I got another error. https://pastebin.com/mmdNztmW
    • java.lang.RuntimeException: Could not execute entrypoint stage 'main' due to errors, provided by 'terrablender'!     at net.fabricmc.loader.impl.FabricLoaderImpl.lambda$invokeEntrypoints$2(FabricLoaderImpl.java:388) ~[fabric-loader-0.15.11.jar:?]     at net.fabricmc.loader.impl.util.ExceptionUtil.gatherExceptions(ExceptionUtil.java:33) ~[fabric-loader-0.15.11.jar:?]     at net.fabricmc.loader.impl.FabricLoaderImpl.invokeEntrypoints(FabricLoaderImpl.java:386) ~[fabric-loader-0.15.11.jar:?]     at net.fabricmc.loader.impl.game.minecraft.Hooks.startServer(Hooks.java:63) ~[fabric-loader-0.15.11.jar:?]     at net.minecraft.server.Main.main(Main.java:112) ~[server-intermediary.jar:?]     at net.fabricmc.loader.impl.game.minecraft.MinecraftGameProvider.launch(MinecraftGameProvider.java:470) ~[fabric-loader-0.15.11.jar:?]     at net.fabricmc.loader.impl.launch.knot.Knot.launch(Knot.java:74) ~[fabric-loader-0.15.11.jar:?]     at net.fabricmc.loader.impl.launch.knot.KnotServer.main(KnotServer.java:23) ~[fabric-loader-0.15.11.jar:?]     at net.fabricmc.loader.impl.launch.server.FabricServerLauncher.main(FabricServerLauncher.java:69) ~[fabric-loader-0.15.11.jar:?] Caused by: java.lang.NoSuchFieldError: Class me.lortseam.completeconfig.data.BooleanEntry does not have member field 'boolean checkbox'     at me.lortseam.completeconfig.data.BooleanEntry.<init>(BooleanEntry.java:25) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at me.lortseam.completeconfig.data.Entry.create(Entry.java:42) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at me.lortseam.completeconfig.data.EntrySet.lambda$resolve$1(EntrySet.java:31) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:212) ~[?:?]     at java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:194) ~[?:?]     at java.util.Spliterators$ArraySpliterator.forEachRemaining(Spliterators.java:1024) ~[?:?]     at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:556) ~[?:?]     at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:546) ~[?:?]     at java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:151) ~[?:?]     at java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:174) ~[?:?]     at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:265) ~[?:?]     at java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:611) ~[?:?]     at me.lortseam.completeconfig.data.EntrySet.resolve(EntrySet.java:32) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at me.lortseam.completeconfig.data.Parent.resolveContainer(Parent.java:58) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at me.lortseam.completeconfig.data.Parent.resolve(Parent.java:110) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at me.lortseam.completeconfig.data.Config.lambda$new$0(Config.java:51) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at me.lortseam.completeconfig.data.Config.deserialize(Config.java:94) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at me.lortseam.completeconfig.data.Config.load(Config.java:121) ~[completeconfig-base-2.5.0-cd5950f26b406f27.jar:?]     at io.github.uhq_games.regions_unexplored.RegionsUnexplored.onTerraBlenderInitialized(RegionsUnexplored.java:70) ~[RegionsUnexploredFabric-0.5.31.20.1.jar:?]     at terrablender.core.TerraBlenderFabric.lambda$onInitialize$0(TerraBlenderFabric.java:40) ~[TerraBlender-fabric-1.20.1-3.0.1.7.jar:?]     at java.util.ArrayList.forEach(ArrayList.java:1597) ~[?:?]     at terrablender.core.TerraBlenderFabric.onInitialize(TerraBlenderFabric.java:38) ~[TerraBlender-fabric-1.20.1-3.0.1.7.jar:?]     at net.fabricmc.loader.impl.FabricLoaderImpl.invokeEntrypoints(FabricLoaderImpl.java:384) ~[fabric-loader-0.15.11.jar:?]  
    • Hi, I have the oficial launcher using the version 1.21, and forge 51.0.13, as soon as I start the installation the games crashes and gives me "exit code: 1", I haven't put any mods yet in the folder. Its the second time that uninstall and install everything and nothing works, checket my graphics and they are updated. https://pastebin.com/STPgEiVs   thanks!
    • Ty very much it worked
    • no clue what is going on, you guys seem more knowledgeable than I am. So here's my log as well as my mod list. Error Folder On Google Drive  
  • Topics

×
×
  • Create New...

Important Information

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