mirror of
https://git.krews.org/morningstar/Arcturus-Community.git
synced 2025-01-18 23:46:28 +01:00
Plugin events to make everything stackable if needed (in case of :buildheight)
This commit is contained in:
parent
cfcc2d0f7c
commit
47865f0ec5
@ -3560,7 +3560,13 @@ public class Room implements Comparable<Room>, ISerialize, Runnable {
|
||||
}
|
||||
}
|
||||
|
||||
if (!stackHelper) {
|
||||
boolean pluginHelper = false;
|
||||
if (Emulator.getPluginManager().isRegistered(FurnitureStackHeightEvent.class, true)) {
|
||||
FurnitureStackHeightEvent event = Emulator.getPluginManager().fireEvent(new FurnitureStackHeightEvent(x, y, this));
|
||||
stackHelper = event.hasPluginHelper();
|
||||
}
|
||||
|
||||
if (!stackHelper && !pluginHelper) {
|
||||
HabboItem item = this.getTopItemAt(x, y, exclude);
|
||||
if (item != null) {
|
||||
canStack = item.getBaseItem().allowStack();
|
||||
@ -4443,19 +4449,22 @@ public class Room implements Comparable<Room>, ISerialize, Runnable {
|
||||
}
|
||||
|
||||
public FurnitureMovementError placeFloorFurniAt(HabboItem item, RoomTile tile, int rotation, Habbo owner) throws Exception {
|
||||
boolean pluginHelper = false;
|
||||
if (Emulator.getPluginManager().isRegistered(FurniturePlacedEvent.class, true)) {
|
||||
Event furniturePlacedEvent = new FurniturePlacedEvent(item, owner, tile);
|
||||
Emulator.getPluginManager().fireEvent(furniturePlacedEvent);
|
||||
FurniturePlacedEvent event = Emulator.getPluginManager().fireEvent(new FurniturePlacedEvent(item, owner, tile));
|
||||
|
||||
if (furniturePlacedEvent.isCancelled())
|
||||
if (event.isCancelled()) {
|
||||
return FurnitureMovementError.CANCEL_PLUGIN_PLACE;
|
||||
}
|
||||
|
||||
pluginHelper = event.hasPluginHelper();
|
||||
}
|
||||
|
||||
THashSet<RoomTile> occupiedTiles = this.layout.getTilesAt(tile, item.getBaseItem().getWidth(), item.getBaseItem().getLength(), rotation);
|
||||
|
||||
FurnitureMovementError fits = furnitureFitsAt(tile, item, rotation);
|
||||
|
||||
if (!fits.equals(FurnitureMovementError.NONE)) {
|
||||
if (!fits.equals(FurnitureMovementError.NONE) && !pluginHelper) {
|
||||
return fits;
|
||||
}
|
||||
|
||||
@ -4520,9 +4529,14 @@ public class Room implements Comparable<Room>, ISerialize, Runnable {
|
||||
|
||||
public FurnitureMovementError moveFurniTo(HabboItem item, RoomTile tile, int rotation, Habbo actor) {
|
||||
RoomTile oldLocation = this.layout.getTile(item.getX(), item.getY());
|
||||
|
||||
boolean pluginHelper = false;
|
||||
if (Emulator.getPluginManager().isRegistered(FurnitureMovedEvent.class, true)) {
|
||||
if (Emulator.getPluginManager().fireEvent(new FurnitureMovedEvent(item, actor, oldLocation, tile)).isCancelled())
|
||||
FurnitureMovedEvent event = Emulator.getPluginManager().fireEvent(new FurnitureMovedEvent(item, actor, oldLocation, tile));
|
||||
if(event.isCancelled()) {
|
||||
return FurnitureMovementError.CANCEL_PLUGIN_MOVE;
|
||||
}
|
||||
pluginHelper = event.hasPluginHelper();
|
||||
}
|
||||
|
||||
HabboItem topItem = this.getTopItemAt(tile.x, tile.y);
|
||||
@ -4534,7 +4548,7 @@ public class Room implements Comparable<Room>, ISerialize, Runnable {
|
||||
//Check if can be placed at new position
|
||||
THashSet<RoomTile> occupiedTiles = this.layout.getTilesAt(tile, item.getBaseItem().getWidth(), item.getBaseItem().getLength(), rotation);
|
||||
|
||||
if (!stackHelper.isPresent()) {
|
||||
if (!stackHelper.isPresent() && !pluginHelper) {
|
||||
if (topItem != item) {
|
||||
for (RoomTile t : occupiedTiles) {
|
||||
HabboItem tileTopItem = this.getTopItemAt(t.x, t.y);
|
||||
|
@ -7,9 +7,8 @@ import com.eu.habbo.habbohotel.users.HabboItem;
|
||||
public class FurnitureMovedEvent extends FurnitureUserEvent {
|
||||
|
||||
public final RoomTile oldPosition;
|
||||
|
||||
|
||||
public final RoomTile newPosition;
|
||||
private boolean pluginHelper;
|
||||
|
||||
|
||||
public FurnitureMovedEvent(HabboItem furniture, Habbo habbo, RoomTile oldPosition, RoomTile newPosition) {
|
||||
@ -17,5 +16,14 @@ public class FurnitureMovedEvent extends FurnitureUserEvent {
|
||||
|
||||
this.oldPosition = oldPosition;
|
||||
this.newPosition = newPosition;
|
||||
this.pluginHelper = false;
|
||||
}
|
||||
|
||||
public void setPluginHelper(boolean helper) {
|
||||
this.pluginHelper = helper;
|
||||
}
|
||||
|
||||
public boolean hasPluginHelper() {
|
||||
return this.pluginHelper;
|
||||
}
|
||||
}
|
||||
|
@ -7,11 +7,20 @@ import com.eu.habbo.habbohotel.users.HabboItem;
|
||||
public class FurniturePlacedEvent extends FurnitureUserEvent {
|
||||
|
||||
public final RoomTile location;
|
||||
|
||||
private boolean pluginHelper;
|
||||
|
||||
public FurniturePlacedEvent(HabboItem furniture, Habbo habbo, RoomTile location) {
|
||||
super(furniture, habbo);
|
||||
|
||||
this.location = location;
|
||||
this.pluginHelper = false;
|
||||
}
|
||||
|
||||
public void setPluginHelper(boolean helper) {
|
||||
this.pluginHelper = helper;
|
||||
}
|
||||
|
||||
public boolean hasPluginHelper() {
|
||||
return this.pluginHelper;
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,27 @@
|
||||
package com.eu.habbo.plugin.events.furniture;
|
||||
|
||||
import com.eu.habbo.habbohotel.rooms.Room;
|
||||
import com.eu.habbo.plugin.Event;
|
||||
|
||||
public class FurnitureStackHeightEvent extends Event {
|
||||
|
||||
public final short x;
|
||||
public final short y;
|
||||
public final Room room;
|
||||
private boolean pluginHelper;
|
||||
|
||||
public FurnitureStackHeightEvent(short x, short y, Room room) {
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
this.room = room;
|
||||
this.pluginHelper = false;
|
||||
}
|
||||
|
||||
public void setPluginHelper(boolean helper) {
|
||||
this.pluginHelper = helper;
|
||||
}
|
||||
|
||||
public boolean hasPluginHelper() {
|
||||
return this.pluginHelper;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user