Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement Trident #4547

Open
wants to merge 10 commits into
base: minor-next
Choose a base branch
from
Open

Implement Trident #4547

wants to merge 10 commits into from

Conversation

IvanCraft623
Copy link
Member

@IvanCraft623 IvanCraft623 commented Nov 5, 2021

Introduction

Implements item and trident projectile.

Changes

API changes

Projectile::onHit() now returns Vector3 representing the new projectile motion.

Behavioural changes

Projectile::onHitEntity() no longer flags the projectile for despawn, child classes decide whether the entity should be despawned.

Follow-up

Implement enchantments
Implement custom death attack message for thrown tridents

Requires translations:

TODO

Name Value in eng.ini
death.attack.thrownTrident {%0} was impaled to death by {%1}

Tests

https://youtu.be/y__tfdHA3FE

@ghost
Copy link

ghost commented Nov 6, 2021

Trident enchantments?

@ghost
Copy link

ghost commented Dec 3, 2021

@dktapps When you merged it? It's really good implementation.

I thought that it must be in PocketMine-MP

@dktapps dktapps changed the base branch from master to next-major December 29, 2021 21:56
@IvanCraft623
Copy link
Member Author

oh no!

@dktapps
Copy link
Member

dktapps commented Jan 3, 2022

That's a github bug, don't worry about it.

@dktapps dktapps added Category: Gameplay Related to Minecraft gameplay experience Type: Contribution labels Jan 18, 2022
@IvanCraft623
Copy link
Member Author

I will take up this PR when I have time.

@IvanCraft623 IvanCraft623 reopened this Oct 29, 2022
@IvanCraft623 IvanCraft623 changed the base branch from next-major to next-minor October 29, 2022 18:11
@IvanCraft623 IvanCraft623 changed the base branch from next-minor to next-major October 29, 2022 20:06
@IvanCraft623
Copy link
Member Author

Trident enchantments?

Enchantments will be implemented in a separate PR:

@dktapps dktapps added Type: Enhancement Contributes features or other improvements to PocketMine-MP and removed Type: Contribution labels Nov 26, 2022
@IvanCraft623 IvanCraft623 changed the title Trident implementation Implement Trident Dec 18, 2022
NhanAZ
NhanAZ previously approved these changes Mar 17, 2023
@dktapps
Copy link
Member

dktapps commented Feb 20, 2024

I don't love that we're breaking BC to implement this. Is there a way to do it while retaining BC?

@Gewinum

This comment was marked as off-topic.

@Gewinum

This comment was marked as off-topic.

@IvanCraft623

This comment was marked as off-topic.

@IvanCraft623
Copy link
Member Author

I don't love that we're breaking BC to implement this. Is there a way to do it while retaining BC?

The BC Break is to be able to modify the motion that the projectile will have when impacting a target, previously it was simply set to zero, but the trident has the fature of "bouncing" when hitting an entity. I thought of an alternative of something like getMotionOnHit(ProjectileHitEvent), but I disliked it and we already had onHit which does not have a return value.

@IvanCraft623
Copy link
Member Author

In its beginnings this PR did not contain BCBreak, this was done by creating a new trident inside onHitEntity() with the desired motion. But I discarded that because it felt hacky.

@dktapps
Copy link
Member

dktapps commented Feb 22, 2024

Seems to me like we should enable the use of setMotion in onHit, as that's the conventional way to set motion.

There's also a behavioural BC break wrt. the despawn behaviour when hitting objects. I'm not sure how we could make that non-BC-breaking.

@dktapps
Copy link
Member

dktapps commented Nov 14, 2024

I think we can avoid BC breaks:

  • For the post-hit velocity, either add a getPostHitVelocity(ProjectileHitEvent) : ?Vector3, or permit the use of setMotion() inside the onHit* handlers
  • For post-hit despawning, add despawnsOnHit() : bool or perhaps an onPostHit() : void that can be overridden by subclasses.

However, the branch will need to be rebased if we retarget this back to minor-next, since there's been stuff merged into it from major-next.

@IvanCraft623 IvanCraft623 changed the base branch from major-next to minor-next December 1, 2024 19:56
@IvanCraft623 IvanCraft623 requested a review from a team as a code owner December 1, 2024 19:56
pmmp-admin-bot[bot]
pmmp-admin-bot bot previously approved these changes Dec 2, 2024
}

$item = Item::nbtDeserialize($itemTag);
if($item->isNull() || !$item instanceof TridentItem){
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a reason to require this to be a TridentItem? It doesn't look like it needs any specific methods.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consistency, if I do TridentEntity->getItem() I would expect a TridentItem.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It just seems like an unnecessary constraint to me, considering there's no special methods on TridentItem.

src/entity/projectile/Projectile.php Outdated Show resolved Hide resolved
src/entity/projectile/Projectile.php Outdated Show resolved Hide resolved
src/item/Trident.php Outdated Show resolved Hide resolved
src/world/sound/TridentHitSound.php Outdated Show resolved Hide resolved
pmmp-admin-bot[bot]
pmmp-admin-bot bot previously approved these changes Dec 4, 2024
pmmp-admin-bot[bot]
pmmp-admin-bot bot previously approved these changes Dec 4, 2024
src/item/Trident.php Outdated Show resolved Hide resolved
pmmp-admin-bot[bot]
pmmp-admin-bot bot previously approved these changes Dec 5, 2024
}
if($this->spawnedInCreative){
$ev->cancel();
$shouldDespawn = true;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is going to despawn tridents thrown by creative players if a survival player tries to pick them up, even though no item will be received. Doesn't seem right to me.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's the expected behavior

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Expected by who?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm pretty sure this is a bug in Bedrock. No other items behave like this.
Arrows fired in creative aren't expected to despawn when a survival player steps on them.

Also, from the wiki:

Only the owner of a trident thrown in Creative mode or enchanted with Loyalty can pick it up; other players in Creative and players in Survival mode including its own owner can't pick up the trident thrown in Creative.

I would expect this to work the same way arrows do, with modes NONE/ANY/CREATIVE pickup modes.

@dktapps
Copy link
Member

dktapps commented Dec 18, 2024

This PR seems mostly done, just a couple things left to deal with.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Category: Gameplay Related to Minecraft gameplay experience Status: Waiting on Author Type: Enhancement Contributes features or other improvements to PocketMine-MP
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants