Jump to content

[Looking for explanation but SOLVED] Unprogrammed entity movement [1.7]


Recommended Posts

Posted

Hi

 

Show some code?

 

I've found position logging to be extremely useful for this type of problem eg

System.out.println("position on side " + (this.worldObj.isRemote() ? "client" : "server") + " is [" + this.posX + ", " + this.posY + ", " + this.posZ + "]"  );

(in one of the entity's tick update methods)

 

That will show you if it really is a client/server mismatch, and might help you figure out where to look next.

 

-TGG

 

 

 

Posted

Sorry, I should know better than to forget my code. Update: after adding a bit of code to the controller class (relating to bounding boxes and collision)  the controller and ship block go up after a second (possibly just after I mount it, happens automatically) but not back (instead of the seat).

 

According to:

class com.deb.debmodularships.entities.EntityController's position on side server is [-2475.5, 56.0, 785.5]

class com.deb.debmodularships.entities.EntityController's position on side client is [-2475.5, 56.0, 785.5]

 

class com.deb.debmodularships.entities.EntityController's position on side server is [-2475.5, 56.0, 785.5]

class com.deb.debmodularships.entities.EntityController's position on side client is [-2475.5, 57.0, 785.5]

 

it does seem to be a client issue.

 

Controller(screen, buttons)

package com.deb.debmodularships.entities;

import java.util.UUID;

import net.minecraft.entity.Entity;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.util.AxisAlignedBB;
import net.minecraft.world.World;

public class EntityController extends Entity {

public EntityShipSeat ShipCSeat = null;
public String ShipCSeatid = "";

public EntityController(World par1World) {
	super(par1World);
	this.setSize(1, 1);
}

@Override
protected void entityInit() {

}

@Override
public void readFromNBT(NBTTagCompound nbt) {
	super.readFromNBT(nbt);
	ShipCSeatid = nbt.getString("ShipCSeatid");
}

@Override
public void writeToNBT(NBTTagCompound nbt) {
	super.writeToNBT(nbt);
	nbt.setString("ShipCSeatid", ShipCSeat.getUniqueID().toString());
}

public void onUpdate() {
	//System.out.println(this.ShipCSeat);
	System.out.println(this.getClass() + "'s position on side " + (this.worldObj.isRemote ? "client" : "server") + " is [" + this.posX + ", " + this.posY + ", " + this.posZ + "]"  );
	if (ShipCSeat == null && this.ShipCSeatid != "") {
		this.worldObj.getLoadedEntityList();

		for (int i = 0; i < this.worldObj.getLoadedEntityList().size(); ++i) {
			if (this.worldObj.getLoadedEntityList().get(i) instanceof EntityShipSeat) {
				EntityShipSeat tested = (EntityShipSeat)this.worldObj.getLoadedEntityList().get(i);
				if (UUID.fromString(this.ShipCSeatid).equals(tested.getUniqueID())) {
					this.ShipCSeat = (EntityShipSeat)this.worldObj.getLoadedEntityList().get(i);
				}
			}
    		}
	}
}

@Override
public AxisAlignedBB getCollisionBox(Entity par1Entity)
{
	return this.boundingBox;
}

/**
 * returns the bounding box for this entity
 */
@Override
public AxisAlignedBB getBoundingBox()
{
	return this.boundingBox;
}

@Override
public boolean canBePushed()
    {
        return false;
    }

@Override
public boolean canBeCollidedWith()
{
	return true;
}

//IGNORE

@Override
protected void readEntityFromNBT(NBTTagCompound var1) {
	// TODO Auto-generated method stub

}

@Override
protected void writeEntityToNBT(NBTTagCompound var1) {
	// TODO Auto-generated method stub

}
}

 

Ship Block (plain)

package com.deb.debmodularships.entities;

import java.util.UUID;

import scala.reflect.internal.Trees.This;
import net.minecraft.entity.Entity;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.util.AxisAlignedBB;
import net.minecraft.world.World;

public class EntityShipBlock extends Entity {

public EntityController controller = null;
String controllerid = "";

public EntityShipBlock(World par1World) {
	super(par1World);
	this.setSize(1, 1);
}

@Override
public boolean interactFirst(EntityPlayer player) {
	//player.mountEntity(controller.ShipCSeat);
	if (this.controller != null && this.controller.ShipCSeat != null) {
		System.out.println(this.controller.ShipCSeat);
		player.mountEntity(controller.ShipCSeat);
	}
        return true;
    }

@Override
protected void entityInit() {
	AxisAlignedBB.getBoundingBox(-0.5d, -0.5d, -0.5d, 0.5d, 0.5d, 0.5d);
}

@Override
public void readFromNBT(NBTTagCompound nbt) {
	super.readFromNBT(nbt);
	this.controllerid = nbt.getString("controllerid");
}

@Override
public void writeToNBT(NBTTagCompound nbt) {
	super.writeToNBT(nbt);
	nbt.setString("controllerid", this.controller.getUniqueID().toString());
}

public void onUpdate() {
	System.out.println(this.getClass() + "'s position on side " + (this.worldObj.isRemote ? "client" : "server") + " is [" + this.posX + ", " + this.posY + ", " + this.posZ + "]"  );
	if (controller == null && this.controllerid != "") {
		this.worldObj.getLoadedEntityList();

		for (int i = 0; i < this.worldObj.getLoadedEntityList().size(); ++i) {
			if (this.worldObj.getLoadedEntityList().get(i) instanceof EntityController) {
				EntityController tested = (EntityController)this.worldObj.getLoadedEntityList().get(i);
				if (UUID.fromString(this.controllerid).equals(tested.getUniqueID())) {
					this.controller = (EntityController)this.worldObj.getLoadedEntityList().get(i);
				}
			}
    		}
	}
}

@Override
public AxisAlignedBB getCollisionBox(Entity par1Entity)
{
	return this.boundingBox;
}

/**
 * returns the bounding box for this entity
 */
@Override
public AxisAlignedBB getBoundingBox()
{
	return this.boundingBox;
}

@Override
public boolean canBePushed()
    {
        return false;
    }

@Override
public boolean canBeCollidedWith()
{
	return true;
}

@Override
protected void readEntityFromNBT(NBTTagCompound var1) {
	// TODO Auto-generated method stub

}

@Override
protected void writeEntityToNBT(NBTTagCompound var1) {
	// TODO Auto-generated method stub

}
}

 

Ship Seat (Short wooly one)

package com.deb.debmodularships.entities;

import net.minecraft.world.World;

public class EntityShipSeat extends EntityShipBlock {

public EntityShipSeat(World par1World) {
	super(par1World);
	this.setSize(1f, 0.25f);
	this.boundingBox.offset(0f, -0.5f, 0f);
}

public double getMountedYOffset() {
        return 0.3d;
    }

}

Posted

sorry mate, nothing is coming to mind and I don't see anything obvious in that code (but then - I've never programmed riding entity stuff before either).

 

What I would try next is to put a breakpoint on the client side posY (i.e. to break when it turns to say > 56.5) and see which method is writing the changed value in there.  It will slow your code down a lot but with any luck it should show you exactly what is causing the problem.

 

-TGG

Posted

I definitely did put the super calls in nbt stuff but after changing onUpdate, the same thing happens. New Controller file:

 

package com.deb.debmodularships.entities;

import net.minecraft.entity.Entity;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.util.AxisAlignedBB;
import net.minecraft.world.World;

public class EntityController extends Entity {

public EntityController(World par1World) {
	super(par1World);
	this.setSize(1, 1);
}

@Override
protected void entityInit() {

}

@Override
public void readFromNBT(NBTTagCompound nbt) {
	super.readFromNBT(nbt);
}

@Override
public void writeToNBT(NBTTagCompound nbt) {
	super.writeToNBT(nbt);
}

public void onUpdate() {
	super.onUpdate();
	System.out.println(this.boundingBox);
}

public boolean canBeCollidedWith() {
        return true;
    }

public AxisAlignedBB getCollisionBox(Entity p_70114_1_) {
        return this.boundingBox;
    }

public AxisAlignedBB getBoundingBox()
    {
        return this.boundingBox;
    }

//IGNORE

@Override
protected void readEntityFromNBT(NBTTagCompound var1) {
	// TODO Auto-generated method stub

}

@Override
protected void writeEntityToNBT(NBTTagCompound var1) {
	// TODO Auto-generated method stub

}
}

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

    • I tried do download the essential mod to my mod pack but i didnt work. I paly on 1.21 and it should work. I use neoforge for my modding. The weird things is my friend somehow added the mod to his modpack and many others that I somehow can´t. Is there anything i can do? 
    • Thanks, I've now installed a slightly newer version and the server is at least starting up now.
    • i have the same issue. Found 1 Create mod class dependency(ies) in createdeco-1.3.3-1.19.2.jar, which are missing from the current create-1.19.2-0.5.1.i.jar Found 11 Create mod class dependency(ies) in createaddition-fabric+1.19.2-20230723a.jar, which are missing from the current create-1.19.2-0.5.1.i.jar Detailed walkthrough of mods which rely on missing Create mod classes: Mod: createaddition-fabric+1.19.2-20230723a.jar Missing classes of create: com/simibubi/create/compat/jei/category/sequencedAssembly/JeiSequencedAssemblySubCategory com/simibubi/create/compat/recipeViewerCommon/SequencedAssemblySubCategoryType com/simibubi/create/compat/rei/CreateREI com/simibubi/create/compat/rei/EmptyBackground com/simibubi/create/compat/rei/ItemIcon com/simibubi/create/compat/rei/category/CreateRecipeCategory com/simibubi/create/compat/rei/category/WidgetUtil com/simibubi/create/compat/rei/category/animations/AnimatedBlazeBurner com/simibubi/create/compat/rei/category/animations/AnimatedKinetics com/simibubi/create/compat/rei/category/sequencedAssembly/ReiSequencedAssemblySubCategory com/simibubi/create/compat/rei/display/CreateDisplay Mod: createdeco-1.3.3-1.19.2.jar Missing classes of create: com/simibubi/create/content/kinetics/fan/SplashingRecipe
    • The crash points to moonlight lib - try other builds or make a test without this mod and the mods requiring it
    • Do you have shaders enabled? There is an issue with the mod simpleclouds - remove this mod or disable shaders, if enabled  
  • Topics

×
×
  • Create New...

Important Information

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