mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-09-06 09:56:06 +00:00
Fixed crafting
This commit is contained in:
@ -29,134 +29,23 @@ use function max;
|
||||
use function min;
|
||||
use const PHP_INT_MAX;
|
||||
|
||||
class CraftingGrid extends BaseInventory{
|
||||
public const SIZE_SMALL = 2;
|
||||
public const SIZE_BIG = 3;
|
||||
class CraftingGrid extends BaseUIInventory{
|
||||
public const SIZE_SMALL = 4;
|
||||
public const SIZE_BIG = 9;
|
||||
|
||||
/** @var Player */
|
||||
protected $holder;
|
||||
/** @var int */
|
||||
private $gridWidth;
|
||||
|
||||
/** @var int|null */
|
||||
private $startX;
|
||||
/** @var int|null */
|
||||
private $xLen;
|
||||
/** @var int|null */
|
||||
private $startY;
|
||||
/** @var int|null */
|
||||
private $yLen;
|
||||
|
||||
public function __construct(Player $holder, int $gridWidth){
|
||||
$this->holder = $holder;
|
||||
public function __construct(PlayerUIInventory $inventory, int $gridWidth){
|
||||
$this->gridWidth = $gridWidth;
|
||||
parent::__construct();
|
||||
if($gridWidth === self::SIZE_SMALL){
|
||||
parent::__construct($inventory, $gridWidth, 28);
|
||||
}elseif($gridWidth === self::SIZE_BIG){
|
||||
parent::__construct($inventory, $gridWidth, 32);
|
||||
}
|
||||
}
|
||||
|
||||
public function getGridWidth() : int{
|
||||
return $this->gridWidth;
|
||||
}
|
||||
|
||||
public function getDefaultSize() : int{
|
||||
return $this->getGridWidth() ** 2;
|
||||
}
|
||||
|
||||
public function setSize(int $size){
|
||||
throw new \BadMethodCallException("Cannot change the size of a crafting grid");
|
||||
}
|
||||
|
||||
public function getName() : string{
|
||||
return "Crafting";
|
||||
}
|
||||
|
||||
public function setItem(int $index, Item $item, bool $send = true) : bool{
|
||||
if(parent::setItem($index, $item, $send)){
|
||||
$this->seekRecipeBounds();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
public function sendSlot(int $index, $target) : void{
|
||||
//we can't send a slot of a client-sided inventory window
|
||||
}
|
||||
|
||||
public function sendContents($target) : void{
|
||||
//no way to do this
|
||||
}
|
||||
|
||||
/**
|
||||
* @return Player
|
||||
*/
|
||||
public function getHolder(){
|
||||
return $this->holder;
|
||||
}
|
||||
|
||||
private function seekRecipeBounds() : void{
|
||||
$minX = PHP_INT_MAX;
|
||||
$maxX = 0;
|
||||
|
||||
$minY = PHP_INT_MAX;
|
||||
$maxY = 0;
|
||||
|
||||
$empty = true;
|
||||
|
||||
for($y = 0; $y < $this->gridWidth; ++$y){
|
||||
for($x = 0; $x < $this->gridWidth; ++$x){
|
||||
if(!$this->isSlotEmpty($y * $this->gridWidth + $x)){
|
||||
$minX = min($minX, $x);
|
||||
$maxX = max($maxX, $x);
|
||||
|
||||
$minY = min($minY, $y);
|
||||
$maxY = max($maxY, $y);
|
||||
|
||||
$empty = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if(!$empty){
|
||||
$this->startX = $minX;
|
||||
$this->xLen = $maxX - $minX + 1;
|
||||
$this->startY = $minY;
|
||||
$this->yLen = $maxY - $minY + 1;
|
||||
}else{
|
||||
$this->startX = $this->xLen = $this->startY = $this->yLen = null;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the item at offset x,y, offset by where the starts of the recipe rectangle are.
|
||||
*
|
||||
* @param int $x
|
||||
* @param int $y
|
||||
*
|
||||
* @return Item
|
||||
*/
|
||||
public function getIngredient(int $x, int $y) : Item{
|
||||
if($this->startX !== null and $this->startY !== null){
|
||||
return $this->getItem(($y + $this->startY) * $this->gridWidth + ($x + $this->startX));
|
||||
}
|
||||
|
||||
throw new \InvalidStateException("No ingredients found in grid");
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the width of the recipe we're trying to craft, based on items currently in the grid.
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
public function getRecipeWidth() : int{
|
||||
return $this->xLen ?? 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the height of the recipe we're trying to craft, based on items currently in the grid.
|
||||
* @return int
|
||||
*/
|
||||
public function getRecipeHeight() : int{
|
||||
return $this->yLen ?? 0;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user