Mirror von
https://github.com/IntellectualSites/FastAsyncWorldEdit.git
synchronisiert 2025-01-12 02:20:51 +01:00
Fix block rotations
Dieser Commit ist enthalten in:
Ursprung
6c35d20306
Commit
83d5e2fd22
@ -126,10 +126,8 @@ public final class BlockData {
|
|||||||
case BlockID.CHEST:
|
case BlockID.CHEST:
|
||||||
case BlockID.FURNACE:
|
case BlockID.FURNACE:
|
||||||
case BlockID.BURNING_FURNACE:
|
case BlockID.BURNING_FURNACE:
|
||||||
case BlockID.DISPENSER:
|
|
||||||
case BlockID.ENDER_CHEST:
|
case BlockID.ENDER_CHEST:
|
||||||
case BlockID.TRAPPED_CHEST:
|
case BlockID.TRAPPED_CHEST:
|
||||||
case BlockID.DROPPER:
|
|
||||||
switch (data) {
|
switch (data) {
|
||||||
case 2: return 5;
|
case 2: return 5;
|
||||||
case 3: return 4;
|
case 3: return 4;
|
||||||
@ -138,6 +136,17 @@ public final class BlockData {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case BlockID.DISPENSER:
|
||||||
|
case BlockID.DROPPER:
|
||||||
|
int dispPower = data & 0x8;
|
||||||
|
switch (data & ~0x8) {
|
||||||
|
case 2: return 5 | dispPower;
|
||||||
|
case 3: return 4 | dispPower;
|
||||||
|
case 4: return 2 | dispPower;
|
||||||
|
case 5: return 3 | dispPower;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case BlockID.PUMPKIN:
|
case BlockID.PUMPKIN:
|
||||||
case BlockID.JACKOLANTERN:
|
case BlockID.JACKOLANTERN:
|
||||||
switch (data) {
|
switch (data) {
|
||||||
@ -309,10 +318,8 @@ public final class BlockData {
|
|||||||
case BlockID.CHEST:
|
case BlockID.CHEST:
|
||||||
case BlockID.FURNACE:
|
case BlockID.FURNACE:
|
||||||
case BlockID.BURNING_FURNACE:
|
case BlockID.BURNING_FURNACE:
|
||||||
case BlockID.DISPENSER:
|
|
||||||
case BlockID.ENDER_CHEST:
|
case BlockID.ENDER_CHEST:
|
||||||
case BlockID.TRAPPED_CHEST:
|
case BlockID.TRAPPED_CHEST:
|
||||||
case BlockID.DROPPER:
|
|
||||||
switch (data) {
|
switch (data) {
|
||||||
case 5: return 2;
|
case 5: return 2;
|
||||||
case 4: return 3;
|
case 4: return 3;
|
||||||
@ -321,6 +328,16 @@ public final class BlockData {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case BlockID.DISPENSER:
|
||||||
|
case BlockID.DROPPER:
|
||||||
|
int dispPower = data & 0x8;
|
||||||
|
switch (data & ~0x8) {
|
||||||
|
case 5: return 2 | dispPower;
|
||||||
|
case 4: return 3 | dispPower;
|
||||||
|
case 2: return 4 | dispPower;
|
||||||
|
case 3: return 5 | dispPower;
|
||||||
|
}
|
||||||
|
break;
|
||||||
case BlockID.PUMPKIN:
|
case BlockID.PUMPKIN:
|
||||||
case BlockID.JACKOLANTERN:
|
case BlockID.JACKOLANTERN:
|
||||||
switch (data) {
|
switch (data) {
|
||||||
@ -526,10 +543,8 @@ public final class BlockData {
|
|||||||
case BlockID.CHEST:
|
case BlockID.CHEST:
|
||||||
case BlockID.FURNACE:
|
case BlockID.FURNACE:
|
||||||
case BlockID.BURNING_FURNACE:
|
case BlockID.BURNING_FURNACE:
|
||||||
case BlockID.DISPENSER:
|
|
||||||
case BlockID.ENDER_CHEST:
|
case BlockID.ENDER_CHEST:
|
||||||
case BlockID.TRAPPED_CHEST:
|
case BlockID.TRAPPED_CHEST:
|
||||||
case BlockID.DROPPER:
|
|
||||||
switch (data) {
|
switch (data) {
|
||||||
case 2:
|
case 2:
|
||||||
case 3:
|
case 3:
|
||||||
@ -540,6 +555,22 @@ public final class BlockData {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case BlockID.DROPPER:
|
||||||
|
case BlockID.DISPENSER:
|
||||||
|
int dispPower = data & 0x8;
|
||||||
|
switch (data & ~0x8) {
|
||||||
|
case 2:
|
||||||
|
case 3:
|
||||||
|
return (data ^ flipZ) | dispPower;
|
||||||
|
case 4:
|
||||||
|
case 5:
|
||||||
|
return (data ^ flipX) | dispPower;
|
||||||
|
case 0:
|
||||||
|
case 1:
|
||||||
|
return (data ^ flipY) | dispPower;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case BlockID.PUMPKIN:
|
case BlockID.PUMPKIN:
|
||||||
case BlockID.JACKOLANTERN:
|
case BlockID.JACKOLANTERN:
|
||||||
if (data > 3) break;
|
if (data > 3) break;
|
||||||
@ -768,16 +799,21 @@ public final class BlockData {
|
|||||||
|
|
||||||
case BlockID.FURNACE:
|
case BlockID.FURNACE:
|
||||||
case BlockID.BURNING_FURNACE:
|
case BlockID.BURNING_FURNACE:
|
||||||
case BlockID.DISPENSER:
|
|
||||||
case BlockID.WALL_SIGN:
|
case BlockID.WALL_SIGN:
|
||||||
case BlockID.LADDER:
|
case BlockID.LADDER:
|
||||||
case BlockID.CHEST:
|
case BlockID.CHEST:
|
||||||
case BlockID.ENDER_CHEST:
|
case BlockID.ENDER_CHEST:
|
||||||
case BlockID.TRAPPED_CHEST:
|
case BlockID.TRAPPED_CHEST:
|
||||||
case BlockID.DROPPER:
|
|
||||||
if (data < 2 || data > 5) return -1;
|
if (data < 2 || data > 5) return -1;
|
||||||
return mod((data - 2 + increment), 4) + 2;
|
return mod((data - 2 + increment), 4) + 2;
|
||||||
|
|
||||||
|
case BlockID.DISPENSER:
|
||||||
|
case BlockID.DROPPER:
|
||||||
|
store = data & 0x8;
|
||||||
|
data &= ~0x8;
|
||||||
|
if (data > 5) return -1;
|
||||||
|
return mod((data + increment), 6) | store;
|
||||||
|
|
||||||
case BlockID.REDSTONE_REPEATER_OFF:
|
case BlockID.REDSTONE_REPEATER_OFF:
|
||||||
case BlockID.REDSTONE_REPEATER_ON:
|
case BlockID.REDSTONE_REPEATER_ON:
|
||||||
case BlockID.COMPARATOR_OFF:
|
case BlockID.COMPARATOR_OFF:
|
||||||
|
@ -253,12 +253,14 @@ public class DefaultNmsBlock extends NmsBlock {
|
|||||||
// TileEntity te = craftWorld.getHandle().getTileEntity(x, y, z);
|
// TileEntity te = craftWorld.getHandle().getTileEntity(x, y, z);
|
||||||
// craftWorld.getHandle().tileEntityList.remove(te);
|
// craftWorld.getHandle().tileEntityList.remove(te);
|
||||||
|
|
||||||
boolean changed = craftWorld.getHandle().setTypeIdAndData(x, y, z, block.getId(), block.getData(), 0);
|
boolean changed = craftWorld.getHandle().setTypeIdAndData(x, y, z, block.getId(), 0, 0);
|
||||||
|
|
||||||
if (block instanceof BaseBlock) {
|
if (block instanceof BaseBlock) {
|
||||||
world.copyToWorld(position, (BaseBlock) block);
|
world.copyToWorld(position, (BaseBlock) block);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
changed = craftWorld.getHandle().setData(x, y, z, block.getData(), 0);
|
||||||
|
|
||||||
if (changed) {
|
if (changed) {
|
||||||
if (notifyAdjacent) {
|
if (notifyAdjacent) {
|
||||||
craftWorld.getHandle().update(x, y, z, block.getId());
|
craftWorld.getHandle().update(x, y, z, block.getId());
|
||||||
|
Laden…
x
In neuem Issue referenzieren
Einen Benutzer sperren