firing event in defined directions
This commit is contained in:
@@ -2,9 +2,18 @@ import org.bukkit as bukkit
|
||||
import org.bukkit.event.block.BlockPlaceEvent as BlockPlaceEvent
|
||||
from helpers import *
|
||||
|
||||
tilehelpers = [ # Front Right Back Left Down Up
|
||||
{"owner": "ae795aa8-6327-408e-92ab-25c8a59f3ba1", "area": [[90, 95], [60, 90], [90, 95]], "world": "b0385345-4803-4522-a06a-75fbd692928d", "directions": [True, True, True, True, False, False]}
|
||||
tilehelpers = [
|
||||
{"owner": "ae795aa8-6327-408e-92ab-25c8a59f3ba1", "area": [[90, 95], [60, 90], [90, 95]], "world": "b0385345-4803-4522-a06a-75fbd692928d", "directions": "neswud"}
|
||||
]
|
||||
dirmap = {
|
||||
# [x, y, z]
|
||||
"n": [0, 0, -1],
|
||||
"e": [1, 0, 0],
|
||||
"s": [0, 0, 1],
|
||||
"w": [-1, 0, 0],
|
||||
"u": [0, 1, 0],
|
||||
"d": [0, -1, 0]
|
||||
}
|
||||
|
||||
@hook.event("block.BlockPlaceEvent", "high")
|
||||
def onPlaceBlock(event):
|
||||
@@ -18,6 +27,13 @@ def onPlaceBlock(event):
|
||||
# stack block in directions
|
||||
msg(player, "&ayus")
|
||||
|
||||
event = BlockPlaceEvent(block, block.getState(), event.getBlockAgainst(), event.getItemInHand(), player, event.canBuild())
|
||||
for direction in th.get("directions"):
|
||||
directions = dirmap[direction]
|
||||
size = [area[0][1] - area[0][0], area[1][1] - area[1][0], area[2][1] - area[2][0]]
|
||||
oldplaced = event.getBlockAgainst()
|
||||
|
||||
# server.getPluginManager().callEvent(event);
|
||||
newblock = block.getWorld().getBlockAt(block.getX() + size[0] * directions[0], block.getY() + size[1] * directions[1], block.getZ() + size[2] * directions[2])
|
||||
newplaced = oldplaced.getWorld().getBlockAt(oldplaced.getX() + size[0] * directions[0], oldplaced.getY() + size[1] * directions[1], oldplaced.getZ() + size[2] * directions[2])
|
||||
|
||||
event = BlockPlaceEvent(newblock, block.getState(), newplaced, event.getItemInHand(), player, event.canBuild())
|
||||
server.getPluginManager().callEvent(event)
|
||||
Reference in New Issue
Block a user