Jump to content

Recommended Posts

Posted

Hello, I am GhostWolf, one of the coding developers for the Pixelmon mod (essentially Pokemon in Minecraft).

 

We were wondering if it would be possible to add an event into entityLivingBase that would allow us to specify custom behavior for when a player rides an entity underwater. We currently have several mounts that are capable of surfing and diving, and with the code in entityLivingBase lines 281-309 (and 305-309 in particular), as soon as a player goes fully underwater they unmount (whether it is just the natural up and down swimming on the mount or actually diving). Ideally we would be able to just override this or change the event response to this so that the player can remain on the mount.

 

Any help and suggestions you can give on this would be greatly appreciated. We would also be more than happy to take care of the needed coding if you had the way this should be done figured out.

 

 

 

        if (this.isEntityAlive() && this.isInsideOfMaterial(Material.water))

        {

            if (!this.canBreatheUnderwater() && !this.isPotionActive(Potion.waterBreathing.id) && !flag)

            {

                this.setAir(this.decreaseAirSupply(this.getAir()));

 

                if (this.getAir() == -20)

                {

                    this.setAir(0);

 

                    for (int i = 0; i < 8; ++i)

                    {

                        float f = this.rand.nextFloat() - this.rand.nextFloat();

                        float f1 = this.rand.nextFloat() - this.rand.nextFloat();

                        float f2 = this.rand.nextFloat() - this.rand.nextFloat();

                        this.worldObj.spawnParticle("bubble", this.posX + (double)f, this.posY + (double)f1, this.posZ + (double)f2, this.motionX, this.motionY, this.motionZ);

                    }

 

                    this.attackEntityFrom(DamageSource.drown, 2.0F);

                }

            }

 

            this.extinguish();

 

            if (!this.worldObj.isRemote && this.isRiding() && this.ridingEntity instanceof EntityLivingBase)

            {

                this.mountEntity((Entity)null);

            }

        }

 

Posted

Could easily add a boolean Entity.shouldDismountWhenUnderwater(), Should be a Simple PR for someone to make. {I iz busy till the end of next week}

I do Forge for free, however the servers to run it arn't free, so anything is appreciated.
Consider supporting the team on Patreon

Posted

I went ahead and wrote in the needed code. I can't get the patches to update or commit correctly to github, so here is the code for someone who can do that, all written out for you (red text is added, the rest is just to help you locate where to put it).

 

/** Number of ticks since last jump */

    private int jumpTicks;

    private float field_110151_bq;

   

    /** Determines if entity stays on mount when submerged in water. */

    public boolean stayMountedUnderWater = false;

 

    public EntityLivingBase(World par1World)

    {

 

and

 

                    this.attackEntityFrom(DamageSource.drown, 2.0F);

                }

            }

 

            this.extinguish();

 

            if (!this.worldObj.isRemote && this.isRiding() && this.ridingEntity instanceof EntityLivingBase)

            {

            if (!stayMountedUnderWater){

            this.mountEntity((Entity)null);

            }

            }

        }

 

Posted

This is the location in the code that causes the issue with underwater riding. Based on your comment, I looked at putting something inside the mountEntity() function, but that is only called when you change from mounting to unmounting, and that boolean variable if used there could cause other behavioral issues (such as never letting you get off the mount, etc)

 

The line I placed the check at is the only point at which you would want to circumvent the normal unmounting code for this kind of problem, as it is the only point where the unmounting is caused by the rider being located in water. By locating that boolean check there, you only get the bypass behavior under that one condition, and riding should behave entirely normally for all other situations.

 

If you meant a function in the code of the entity being mounted, it likely wouldn't solve the issue we are having, as it is this particular point in the code where it forces the unmounting, and any other function in the mounted entity that would say force re-mounting would be run too frequently while under water to be an elegant solution to the issue.

 

Hopefully that makes sense, feel free to correct me if I am wrong.

Posted

            if (!this.worldObj.isRemote && this.isRiding() && this.ridingEntity instanceof EntityLivingBase)
            {
                  this.mountEntity((Entity)null);
            }

To:

            if (!this.worldObj.isRemote && this.isRiding() && ridingEntity != null && ridingEntity.shouldDismountInWater(this))
            {
                this.mountEntity((Entity)null);
            }

 

and in entity you have:

public boolean shouldDismountInWater(Entity rider)
{
    return this instanceof EntityLivingBase;
}

...

How is that confusing? Give the mounted the choice of kicking the mountee off if it so chooses, Which mimics what this is doing.

I do Forge for free, however the servers to run it arn't free, so anything is appreciated.
Consider supporting the team on Patreon

Posted

That makes a lot of sense.

 

I was thinking you were suggesting only making the dismounting code inside the mount's code, and not doing the check at that line in the entityLivingBase code, since that wouldn't change things.

 

With the way you have it, it would give the ridden entity the control over kicking, which makes it more generally customizable, and it will make the check at the right place in code, so that is the best solution to the issue. Thanks for your help and insight.

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

    • The game crashed whilst unexpected error Error: net.minecraftforge.fml.ModLoadingException: Advanced Mining Dimension (mining_dimension) encountered an error during the done event phase
    • Here is the end of the log. it was way too big to put in pastebin, but I started from when I was online and everything was fine. Error should be in here: https://pastebin.com/Sdhdq593
    • Update: I stand corrected as I was able to dig up a relevant log from my earlier testing which highlights the overall issue but does not explain how to solve it. See, Diagnostic Logs for pack.mcmeta not found: https://pastebin.com/LXS8Rtna
    • Which mod was this? What are all the mods that were in use? It will help if enough information to replicate the problem is available.
    • I have been attempting to create a supplementary resource pack with Patchouli in order to add back the guidebook for Better End but unfortunately in every prototype I have made pack.mcmeta and my resource pack are not recognized. I have tested both zipped and unzipped and either way curseforge does not recognize my resource pack as existing. For testing I stripped my pack down to just the pack.mcmeta file and two empty folders labelled data and assets and I know the data folder is not the problem as firstly my first attempts just had an assets folder following Patchouli instructions and data came later in my flailing attempts to make anything in my pack work. The mcmeta file is not recognized whether or not I use this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } "language": { "en_US": { "name": "English", "region": "United States" } } } ,or this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } } I have made sure to only use lowercase and the pack folder is named better-end-guide. Is this some magic nonsense from me doing this manually instead of using an IDE or similar tool? Could it be because my files are by default in UTF-8 even though ANSI gives the same results? Is there a specific community secret tool I am supposed to use for zipping or specific settings? I am pulling my hair in distress. Unfortunately as there are no errors involved I lack logs to offer, if that disqualifies this thread please do not be harsh and instead if you can then please direct me to a forum with different rules and sufficiently respectful but knowledgeable as to be of assistance. Most of my experience with the programming community has been poor and so naturally I find myself wary.
  • Topics

×
×
  • Create New...

Important Information

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