Some tile improvements and added ItemFrame tile

This commit is contained in:
Dylan K. Taylor 2016-11-27 14:05:42 +00:00
parent 50d59619a6
commit 90957cd908
7 changed files with 137 additions and 33 deletions

View File

@ -107,6 +107,7 @@ use pocketmine\tile\Chest;
use pocketmine\tile\EnchantTable;
use pocketmine\tile\FlowerPot;
use pocketmine\tile\Furnace;
use pocketmine\tile\ItemFrame;
use pocketmine\tile\Sign;
use pocketmine\tile\Skull;
use pocketmine\tile\Tile;
@ -2452,6 +2453,7 @@ class Server{
Tile::registerTile(EnchantTable::class);
Tile::registerTile(FlowerPot::class);
Tile::registerTile(Furnace::class);
Tile::registerTile(ItemFrame::class);
Tile::registerTile(Sign::class);
Tile::registerTile(Skull::class);
}

View File

@ -31,10 +31,10 @@ use pocketmine\nbt\tag\StringTag;
class FlowerPot extends Spawnable{
public function __construct(Chunk $chunk, CompoundTag $nbt){
if(!isset($nbt->Item)){
if(!isset($nbt->item)){
$nbt->item = new ShortTag("item", 0);
}
if(!isset($nbt->Data)){
if(!isset($nbt->mData)){
$nbt->mData = new IntTag("mData", 0);
}
parent::__construct($chunk, $nbt);
@ -69,12 +69,7 @@ class FlowerPot extends Spawnable{
public function setItem(Item $item){
$this->namedtag["item"] = $item->getId();
$this->namedtag["mData"] = $item->getDamage();
$this->spawnToAll();
if($this->chunk){
$this->chunk->setChanged();
$this->level->clearChunkCache($this->chunk->getX(), $this->chunk->getZ());
}
$this->onChanged();
}
public function removeItem(){
@ -91,8 +86,8 @@ class FlowerPot extends Spawnable{
new IntTag("x", (int) $this->x),
new IntTag("y", (int) $this->y),
new IntTag("z", (int) $this->z),
new ShortTag("item", (int) $this->namedtag["item"]),
new IntTag("mData", (int) $this->namedtag["mData"])
$this->namedtag->item,
$this->namedtag->mData
]);
}
}

View File

@ -0,0 +1,106 @@
<?php
/*
*
* ____ _ _ __ __ _ __ __ ____
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* @author PocketMine Team
* @link http://www.pocketmine.net/
*
*
*/
namespace pocketmine\tile;
use pocketmine\item\Item;
use pocketmine\level\format\FullChunk;
use pocketmine\nbt\tag\ByteTag;
use pocketmine\nbt\tag\CompoundTag;
use pocketmine\nbt\tag\FloatTag;
use pocketmine\nbt\tag\IntTag;
use pocketmine\nbt\tag\StringTag;
class ItemFrame extends Spawnable{
public function __construct(FullChunk $chunk, CompoundTag $nbt){
if(!isset($nbt->ItemRotation)){
$nbt->ItemRotation = new ByteTag("ItemRotation", 0);
}
if(!isset($nbt->ItemDropChance)){
$nbt->ItemDropChance = new FloatTag("ItemDropChance", 1.0);
}
parent::__construct($chunk, $nbt);
}
public function dropItem(){
if(lcg_value() < $this->getDropChance() and $this->hasItem()){
$this->level->dropItem($this, $this->getItem());
}
$this->setItem(null);
}
public function hasItem() : bool{
return $this->getItem()->getId() !== Item::AIR;
}
public function getItem() : Item{
if(isset($this->namedtag->Item)){
return Item::nbtDeserialize($this->namedtag->Item);
}else{
return Item::get(Item::AIR);
}
}
public function setItem(Item $item = null){
if($item !== null and $item->getId() !== Item::AIR){
$this->namedtag->Item = $item->nbtSerialize(-1, "Item");
}else{
unset($this->namedtag->Item);
}
$this->onChanged();
}
public function getItemRotation() : int{
return $this->namedtag->ItemRotation->getValue();
}
public function setItemRotation(int $rotation){
$this->namedtag->ItemRotation = new ByteTag("ItemRotation", $rotation);
$this->onChanged();
}
public function getItemDropChance() : float{
return $this->namedtag->ItemDropChance->getValue();
}
public function setItemDropChance(float $chance){
$this->namedtag->ItemDropChance = new FloatTag("ItemDropChance", $chance);
$this->onChanged();
}
public function getSpawnCompound(){
$tag = new CompoundTag("", [
new StringTag("id", Tile::ITEM_FRAME),
new IntTag("x", (int) $this->x),
new IntTag("y", (int) $this->y),
new IntTag("z", (int) $this->z),
$this->namedtag->ItemDropChance,
$this->namedtag->ItemRotation,
]);
if($this->hasItem()){
$tag->Item = $this->namedtag->Item;
}
return $tag;
}
}

View File

@ -55,12 +55,7 @@ class Sign extends Spawnable{
$this->namedtag->Text2 = new StringTag("Text2", $line2);
$this->namedtag->Text3 = new StringTag("Text3", $line3);
$this->namedtag->Text4 = new StringTag("Text4", $line4);
$this->spawnToAll();
if($this->chunk){
$this->chunk->setChanged();
$this->level->clearChunkCache($this->chunk->getX(), $this->chunk->getZ());
}
$this->onChanged();
return true;
}

View File

@ -47,12 +47,7 @@ class Skull extends Spawnable{
public function setType($type){
if($type >= 0 && $type <= 4){
$this->namedtag->SkullType = new ByteTag("SkullType", $type);
$this->spawnToAll();
if($this->chunk){
$this->chunk->setChanged();
$this->level->clearChunkCache($this->chunk->getX(), $this->chunk->getZ());
}
$this->onChanged();
return true;
}
return false;

View File

@ -67,4 +67,13 @@ abstract class Spawnable extends Tile{
}
}
}
protected function onChanged(){
$this->spawnToAll();
if($this->chunk !== null){
$this->chunk->setChanged();
$this->level->clearChunkCache($this->chunk->getX(), $this->chunk->getZ());
}
}
}

View File

@ -33,14 +33,16 @@ use pocketmine\nbt\tag\IntTag;
use pocketmine\nbt\tag\StringTag;
abstract class Tile extends Position{
const SIGN = "Sign";
const CHEST = "Chest";
const FURNACE = "Furnace";
const FLOWER_POT = "FlowerPot";
const MOB_SPAWNER = "MobSpawner";
const SKULL = "Skull";
const BREWING_STAND = "BrewingStand";
const CHEST = "Chest";
const ENCHANT_TABLE = "EnchantTable";
const FLOWER_POT = "FlowerPot";
const FURNACE = "Furnace";
const ITEM_FRAME = "ItemFrame";
const MOB_SPAWNER = "MobSpawner";
const SIGN = "Sign";
const SKULL = "Skull";
public static $tileCount = 1;