mirror of
https://github.com/ViaVersion/ViaVersion.git
synced 2025-01-25 00:41:23 +01:00
Eat remaining particle data in spawn particle
This commit is contained in:
parent
c75b4d8ef5
commit
1be0605f51
@ -35,6 +35,7 @@ public class ParticleMappings extends FullMappingsBase {
|
|||||||
addBlockParticle("block");
|
addBlockParticle("block");
|
||||||
addBlockParticle("falling_dust");
|
addBlockParticle("falling_dust");
|
||||||
addBlockParticle("block_marker");
|
addBlockParticle("block_marker");
|
||||||
|
addBlockParticle("dust_pillar");
|
||||||
addItemParticle("item");
|
addItemParticle("item");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -210,28 +210,45 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
|
|
||||||
// Read data and add it to Particle
|
// Read data and add it to Particle
|
||||||
final ParticleMappings mappings = protocol.getMappingData().getParticleMappings();
|
final ParticleMappings mappings = protocol.getMappingData().getParticleMappings();
|
||||||
final Particle particle = new Particle(mappings.getNewId(particleId));
|
final int mappedId = mappings.getNewId(particleId);
|
||||||
if (particle.id() == protocol.getMappingData().getParticleMappings().mappedId("entity_effect")) {
|
final Particle particle = new Particle(mappedId);
|
||||||
|
if (mappedId == mappings.mappedId("entity_effect")) {
|
||||||
particle.add(Type.INT, data != 0 ? ThreadLocalRandom.current().nextInt() : 0); // rgb
|
particle.add(Type.INT, data != 0 ? ThreadLocalRandom.current().nextInt() : 0); // rgb
|
||||||
}
|
} else if (particleId == mappings.id("dust_color_transition")) {
|
||||||
if (particle.id() == protocol.getMappingData().getParticleMappings().mappedId("dust_color_transition")) {
|
|
||||||
for (int i = 0; i < 7; i++) {
|
for (int i = 0; i < 7; i++) {
|
||||||
particle.add(Type.FLOAT, wrapper.read(Type.FLOAT));
|
particle.add(Type.FLOAT, wrapper.read(Type.FLOAT));
|
||||||
}
|
}
|
||||||
// fromColor, scale, toColor -> fromColor, toColor, scale
|
// fromColor, scale, toColor -> fromColor, toColor, scale
|
||||||
particle.add(Type.FLOAT, particle.<Float> removeArgument(3).getValue());
|
particle.add(Type.FLOAT, particle.<Float>removeArgument(3).getValue());
|
||||||
}
|
} else if (mappings.isBlockParticle(particleId)) {
|
||||||
|
|
||||||
if (mappings.isBlockParticle(particleId)) {
|
|
||||||
final int blockStateId = wrapper.read(Type.VAR_INT);
|
final int blockStateId = wrapper.read(Type.VAR_INT);
|
||||||
particle.add(Type.VAR_INT, protocol.getMappingData().getNewBlockStateId(blockStateId));
|
particle.add(Type.VAR_INT, protocol.getMappingData().getNewBlockStateId(blockStateId));
|
||||||
} else if (mappings.isItemParticle(particleId)) {
|
} else if (mappings.isItemParticle(particleId)) {
|
||||||
final Item item = handleNonNullItemToClient(wrapper.read(Type.ITEM1_20_2));
|
final Item item = handleNonNullItemToClient(wrapper.read(Type.ITEM1_20_2));
|
||||||
particle.add(Types1_20_5.ITEM, item);
|
particle.add(Types1_20_5.ITEM, item);
|
||||||
|
} else if (particleId == mappings.id("dust")) {
|
||||||
|
// R, g, b, scale
|
||||||
|
for (int i = 0; i < 4; i++) {
|
||||||
|
particle.add(Type.FLOAT, wrapper.read(Type.FLOAT));
|
||||||
|
}
|
||||||
|
} else if (particleId == mappings.id("vibration")) {
|
||||||
|
final int sourceTypeId = wrapper.read(Type.VAR_INT);
|
||||||
|
particle.add(Type.VAR_INT, sourceTypeId);
|
||||||
|
if (sourceTypeId == 0) { // Block
|
||||||
|
particle.add(Type.POSITION1_14, wrapper.read(Type.POSITION1_14)); // Target block pos
|
||||||
|
} else if (sourceTypeId == 1) { // Entity
|
||||||
|
particle.add(Type.VAR_INT, wrapper.read(Type.VAR_INT)); // Target entity
|
||||||
|
particle.add(Type.FLOAT, wrapper.read(Type.FLOAT)); // Y offset
|
||||||
|
} else {
|
||||||
|
Via.getPlatform().getLogger().warning("Unknown vibration path position source type: " + sourceTypeId);
|
||||||
|
}
|
||||||
|
particle.add(Type.VAR_INT, wrapper.read(Type.VAR_INT)); // Arrival in ticks
|
||||||
|
} else if (particleId == mappings.id("sculk_charge")) {
|
||||||
|
particle.add(Type.FLOAT, wrapper.read(Type.FLOAT)); // Roll
|
||||||
|
} else if (particleId == mappings.id("shriek")) {
|
||||||
|
particle.add(Type.VAR_INT, wrapper.read(Type.VAR_INT)); // Delay
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: We should read the particle data of every particle.
|
|
||||||
// Otherwise reading the particle type in future versions will be broken.
|
|
||||||
wrapper.write(Types1_20_5.PARTICLE, particle);
|
wrapper.write(Types1_20_5.PARTICLE, particle);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user