Adding spec private chat + Blocks not breaking and placing

このコミットが含まれているのは:
Ad5001 2016-07-25 15:37:01 +03:00
コミット f6dd631497
2個のファイルの変更16行の追加10行の削除

ファイルの表示

@ -13,6 +13,8 @@ TPCompassName: Find player
BedBackName: Back to lobby
# Name of the lobby world
LobbyWorld:
LobbyWorld: world
# Does the spectators have a private chat (true) or speak to everyone (false)
PrivateSpecChat: true
...

ファイルの表示

@ -21,17 +21,13 @@ class Main extends PluginBase implements Listener{
public function onEnable(){
$this->saveDefaultConfig();
$this->reloadConfig();
$this->getServer()->getPluginManager()->registerEvents($this, $this);
$this->getServer()->getScheduler()->scheduleRepeatingTask(new setGamemodeTask($this), 5);
$this->players = [];
$this->lastPlayer = null;
}
public function onLoad(){
$this->saveDefaultConfig();
}
public function test(Player $p, int $id) {
@ -65,10 +61,10 @@ class Main extends PluginBase implements Listener{
}
}
// }
} elseif($this->isSpectator($event->getPlayer()) and $id == 355) {
} elseif($this->isSpectator($p) and $id == 355) {
// if($event->getPacket() instanceof \pocketmine\network\protocol\UseItemPacket) {
$p->getInventory()->clearAll();
$p->teleport($this->getServer()->getLevelByName($this->getConfig()->get("LobbyWorld"))->getDefaultSpawn());
$p->teleport($this->getServer()->getLevelByName($this->getConfig()->get("LobbyWorld"))->getSpawnLocation());
$p->sendTip(str_ireplace("{lobby}", $this->getConfig()->get("LobbyWorld"), str_ireplace("{player}", $p->getName(), $this->getConfig()->get("LobbyMessage"))));
// }
}
@ -80,10 +76,16 @@ class Main extends PluginBase implements Listener{
public function onBlockPlace(BlockPlaceEvent $event) {
$this->test($event->getPlayer(), $event->getBlock()->getId());
if($this->isSpectator($event->getPlayer())) {
$event->setCancelled();
}
}
public function onBlockBreak(BlockBreakEvent $event) {
$this->test($event->getPlayer(), $event->getPlayer()->getInventory()->getItemInHand()->getId());
if($this->isSpectator($event->getPlayer())) {
$event->setCancelled();
}
}
public function onEntityDamage(EntityDamageEvent $event) {
@ -106,7 +108,7 @@ class Main extends PluginBase implements Listener{
if($this->getConfig()->get("PrivateSpecChat") == "true") {
foreach($event->getPlayer()->getLevel()->getPlayers() as $p) {
if($this->isSpectator($p)) {
$p->sendMessage
$p->sendMessage(\pocketmine\utils\TextFormat::GRAY . "[SPEC] " . $event->getPlayer()->getName() . " > " . $event->getMessage());
}
}
$event->setCancelled();
@ -119,9 +121,11 @@ class Main extends PluginBase implements Listener{
$player = $event->getPlayer();
$this->players[$player->getName()] = [];
$this->lastPlayer = $player;
} elseif($this->lastPlayer !== $player and isset($this->players[$event->getPlayer()->getName()])) {
} elseif($this->lastPlayer !== $event->getPlayer() and isset($this->players[$event->getPlayer()->getName()])) {
unset($this->players[$event->getPlayer()->getName()]);
$event->getPlayer()->setAllowFlight(false);
$event->getPlayer()->getInventory()->clearAll();
$this->lastPlayer = null;
}
}