use of thpmc.vanilla_source.util.BlockPosition3i in project VanillaSource by TheHollowPlanetMC.
the class ParallelStructure method setStructureData.
/**
* この構造物を指定された構造物データを適応して特定のプレイヤーへ見せる
* @param EnginePlayer 構造物を変化させて見せるプレイヤー
* @param implStructureData 構造物データ
*/
public void setStructureData(EnginePlayer EnginePlayer, ImplStructureData implStructureData, @Nullable UpdatePacketType type) {
clearStructureData(EnginePlayer, false);
ParallelUniverse universe = EnginePlayer.getUniverse();
if (universe == null)
return;
ParallelWorld parallelWorld = universe.getWorld(Objects.requireNonNull(baseLocation.getWorld()).getName());
Set<Block> blocks = new HashSet<>();
Set<BlockPosition3i> updateBlocks = new HashSet<>();
for (Map.Entry<BlockPosition3i, BlockData> entry : implStructureData.getBlockDataMap().entrySet()) {
BlockPosition3i relative = entry.getKey();
Block block = getBaseLocation().add(relative.getX(), relative.getY(), relative.getZ()).getBlock();
parallelWorld.setBlockData(block.getX(), block.getY(), block.getZ(), entry.getValue());
blocks.add(block);
updateBlocks.add(new BlockPosition3i(block.getX(), block.getY(), block.getZ()));
}
for (Map.Entry<BlockPosition3i, Integer> entry : implStructureData.getBlockLightLevelMap().entrySet()) {
BlockPosition3i relative = entry.getKey();
Block block = getBaseLocation().add(relative.getX(), relative.getY(), relative.getZ()).getBlock();
parallelWorld.setBlockLightLevel(block.getX(), block.getY(), block.getZ(), entry.getValue());
blocks.add(block);
updateBlocks.add(new BlockPosition3i(block.getX(), block.getY(), block.getZ()));
}
dataMap.put(universe.getName(), blocks);
parallelWorld.sendMultiBlockUpdate(updateBlocks);
}
use of thpmc.vanilla_source.util.BlockPosition3i in project VanillaSource by TheHollowPlanetMC.
the class PacketManager method createMultiBlockChangePacket.
public static Set<Object> createMultiBlockChangePacket(ParallelWorld parallelWorld, Set<BlockPosition3i> blocks) {
Map<BlockPosition3i, Set<BlockPosition3i>> chunkMap = new HashMap<>();
for (BlockPosition3i bp : blocks) {
chunkMap.computeIfAbsent(new BlockPosition3i(bp.getX() >> 4, bp.getY() >> 4, bp.getZ() >> 4), cp -> new HashSet<>()).add(bp);
}
Set<Object> packets = new HashSet<>();
for (Map.Entry<BlockPosition3i, Set<BlockPosition3i>> entry : chunkMap.entrySet()) {
BlockPosition3i sectionPosition = entry.getKey();
Set<BlockPosition3i> bps = entry.getValue();
ParallelChunk parallelChunk = parallelWorld.getChunk(sectionPosition.getX(), sectionPosition.getZ());
if (parallelChunk == null)
continue;
SectionTypeArray sectionTypeArray = parallelChunk.getSectionTypeArray(sectionPosition.getY());
if (sectionTypeArray == null)
continue;
List<Short> coordList = new ArrayList<>();
List<IBlockData> dataList = new ArrayList<>();
for (BlockPosition3i bp : bps) {
IBlockData iBlockData = (IBlockData) sectionTypeArray.getType(bp.getX() & 0xF, bp.getY() & 0xF, bp.getZ() & 0xF);
if (iBlockData == null)
continue;
coordList.add((short) ((bp.getX() & 0xF) << 8 | (bp.getZ() & 0xF) << 4 | bp.getY() & 0xF));
dataList.add(iBlockData);
}
short[] coordArray = new short[coordList.size()];
IBlockData[] dataArray = new IBlockData[dataList.size()];
for (int i = 0; i < coordList.size(); i++) {
coordArray[i] = coordList.get(i);
dataArray[i] = dataList.get(i);
}
try {
PacketPlayOutMultiBlockChange packet = new PacketPlayOutMultiBlockChange();
MultiBlockChangePacketHandler.a.set(packet, SectionPosition.a(sectionPosition.getX(), sectionPosition.getY(), sectionPosition.getZ()));
MultiBlockChangePacketHandler.b.set(packet, coordArray);
MultiBlockChangePacketHandler.c.set(packet, dataArray);
MultiBlockChangePacketHandler.d.setBoolean(packet, true);
packets.add(packet);
} catch (Exception e) {
e.printStackTrace();
}
}
return packets;
}
Aggregations