mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
Broadcast take item packets with collector as source
This fixes players (which can't view the collector) seeing item pickups with themselves as the target.
This commit is contained in:
parent
4866ee899b
commit
b7be7d6807
1 changed files with 12 additions and 3 deletions
|
@ -1413,7 +1413,8 @@
|
||||||
- while (this.yBodyRot - this.yBodyRotO < -180.0F) {
|
- while (this.yBodyRot - this.yBodyRotO < -180.0F) {
|
||||||
- this.yBodyRotO -= 360.0F;
|
- this.yBodyRotO -= 360.0F;
|
||||||
- }
|
- }
|
||||||
-
|
+ this.xRotO += Math.round((this.getXRot() - this.xRotO) / 360.0F) * 360.0F;
|
||||||
|
|
||||||
- while (this.yBodyRot - this.yBodyRotO >= 180.0F) {
|
- while (this.yBodyRot - this.yBodyRotO >= 180.0F) {
|
||||||
- this.yBodyRotO += 360.0F;
|
- this.yBodyRotO += 360.0F;
|
||||||
- }
|
- }
|
||||||
|
@ -1429,8 +1430,7 @@
|
||||||
- while (this.yHeadRot - this.yHeadRotO < -180.0F) {
|
- while (this.yHeadRot - this.yHeadRotO < -180.0F) {
|
||||||
- this.yHeadRotO -= 360.0F;
|
- this.yHeadRotO -= 360.0F;
|
||||||
- }
|
- }
|
||||||
+ this.xRotO += Math.round((this.getXRot() - this.xRotO) / 360.0F) * 360.0F;
|
-
|
||||||
|
|
||||||
- while (this.yHeadRot - this.yHeadRotO >= 180.0F) {
|
- while (this.yHeadRot - this.yHeadRotO >= 180.0F) {
|
||||||
- this.yHeadRotO += 360.0F;
|
- this.yHeadRotO += 360.0F;
|
||||||
- }
|
- }
|
||||||
|
@ -1599,6 +1599,15 @@
|
||||||
|
|
||||||
if (entity instanceof ServerPlayer) {
|
if (entity instanceof ServerPlayer) {
|
||||||
CriteriaTriggers.THROWN_ITEM_PICKED_UP_BY_ENTITY.trigger((ServerPlayer) entity, item.getItem(), this);
|
CriteriaTriggers.THROWN_ITEM_PICKED_UP_BY_ENTITY.trigger((ServerPlayer) entity, item.getItem(), this);
|
||||||
|
@@ -3268,7 +3903,7 @@
|
||||||
|
|
||||||
|
public void take(Entity item, int count) {
|
||||||
|
if (!item.isRemoved() && !this.level().isClientSide && (item instanceof ItemEntity || item instanceof AbstractArrow || item instanceof ExperienceOrb)) {
|
||||||
|
- ((ServerLevel) this.level()).getChunkSource().broadcast(item, new ClientboundTakeItemEntityPacket(item.getId(), this.getId(), count));
|
||||||
|
+ ((ServerLevel) this.level()).getChunkSource().broadcastAndSend(this, new ClientboundTakeItemEntityPacket(item.getId(), this.getId(), count)); // Paper - broadcast with collector as source
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -3284,7 +3919,8 @@
|
@@ -3284,7 +3919,8 @@
|
||||||
Vec3 vec3d = new Vec3(this.getX(), this.getEyeY(), this.getZ());
|
Vec3 vec3d = new Vec3(this.getX(), this.getEyeY(), this.getZ());
|
||||||
Vec3 vec3d1 = new Vec3(entity.getX(), entityY, entity.getZ());
|
Vec3 vec3d1 = new Vec3(entity.getX(), entityY, entity.getZ());
|
||||||
|
|
Loading…
Reference in a new issue