Mirror von
https://github.com/ViaVersion/ViaVersion.git
synchronisiert 2024-12-26 00:00:28 +01:00
Merge pull request #1187 from creeper123123321/snowygrass
Connect grass block to snow
Dieser Commit ist enthalten in:
Commit
cd009388a4
@ -168,8 +168,8 @@ public class ConnectionData {
|
|||||||
BasicFenceConnectionHandler.init();
|
BasicFenceConnectionHandler.init();
|
||||||
NetherFenceConnectionHandler.init();
|
NetherFenceConnectionHandler.init();
|
||||||
WallConnectionHandler.init();
|
WallConnectionHandler.init();
|
||||||
MelonConnectionHandler.init();
|
|
||||||
GlassConnectionHandler.init();
|
GlassConnectionHandler.init();
|
||||||
|
SnowyGrassConnectionHandler.init();
|
||||||
ChestConnectionHandler.init();
|
ChestConnectionHandler.init();
|
||||||
DoorConnectionHandler.init();
|
DoorConnectionHandler.init();
|
||||||
RedstoneConnectionHandler.init();
|
RedstoneConnectionHandler.init();
|
||||||
|
@ -0,0 +1,49 @@
|
|||||||
|
package us.myles.ViaVersion.protocols.protocol1_13to1_12_2.blockconnections;
|
||||||
|
|
||||||
|
import us.myles.ViaVersion.api.Pair;
|
||||||
|
import us.myles.ViaVersion.api.data.UserConnection;
|
||||||
|
import us.myles.ViaVersion.api.minecraft.BlockFace;
|
||||||
|
import us.myles.ViaVersion.api.minecraft.Position;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
public class SnowyGrassConnectionHandler extends ConnectionHandler {
|
||||||
|
private static Map<Pair<Integer, Boolean>, Integer> grassBlocks = new HashMap<>();
|
||||||
|
private static Set<Integer> snows = new HashSet<>();
|
||||||
|
|
||||||
|
static void init() {
|
||||||
|
Set<String> snowyGrassBlocks = new HashSet<>();
|
||||||
|
snowyGrassBlocks.add("minecraft:grass_block");
|
||||||
|
snowyGrassBlocks.add("minecraft:podzol");
|
||||||
|
snowyGrassBlocks.add("minecraft:mycelium");
|
||||||
|
|
||||||
|
SnowyGrassConnectionHandler handler = new SnowyGrassConnectionHandler();
|
||||||
|
for (Map.Entry<String, Integer> blockState : ConnectionData.keyToId.entrySet()) {
|
||||||
|
WrappedBlockData data = WrappedBlockData.fromString(blockState.getKey());
|
||||||
|
if (snowyGrassBlocks.contains(data.getMinecraftKey())) {
|
||||||
|
ConnectionData.connectionHandlerMap.put(blockState.getValue(), handler);
|
||||||
|
data.set("snowy", "true");
|
||||||
|
grassBlocks.put(new Pair<>(blockState.getValue(), true), data.getBlockStateId());
|
||||||
|
data.set("snowy", "false");
|
||||||
|
grassBlocks.put(new Pair<>(blockState.getValue(), false), data.getBlockStateId());
|
||||||
|
}
|
||||||
|
if (data.getMinecraftKey().equals("minecraft:snow") || data.getMinecraftKey().equals("minecraft:snow_block")) {
|
||||||
|
ConnectionData.connectionHandlerMap.put(blockState.getValue(), handler);
|
||||||
|
snows.add(blockState.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int connect(UserConnection user, Position position, int blockState) {
|
||||||
|
int blockUpId = getBlockData(user, position.getRelative(BlockFace.TOP));
|
||||||
|
Integer newId = grassBlocks.get(new Pair<>(blockState, snows.contains(blockUpId)));
|
||||||
|
if (newId != null) {
|
||||||
|
return newId;
|
||||||
|
}
|
||||||
|
return blockState;
|
||||||
|
}
|
||||||
|
}
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren