mirror of
https://git.huckle.dev/Huckles-Minecraft-Archive/4jcraft.git
synced 2026-06-13 05:13:51 +00:00
chore: format Minecraft.World
This commit is contained in:
@@ -7,53 +7,49 @@
|
||||
#include "SignItem.h"
|
||||
#include "../Stats/GenericStats.h"
|
||||
|
||||
SignItem::SignItem(int id) : Item(id)
|
||||
{
|
||||
// 4J-PB - Changed for TU9
|
||||
maxStackSize = 16;
|
||||
SignItem::SignItem(int id) : Item(id) {
|
||||
// 4J-PB - Changed for TU9
|
||||
maxStackSize = 16;
|
||||
}
|
||||
|
||||
bool SignItem::useOn(std::shared_ptr<ItemInstance> instance, std::shared_ptr<Player> player, Level *level, int x, int y, int z, int face, float clickX, float clickY, float clickZ, bool bTestUseOnOnly)
|
||||
{
|
||||
// 4J-PB - Adding a test only version to allow tooltips to be displayed
|
||||
if (face == 0) return false;
|
||||
if (!level->getMaterial(x, y, z)->isSolid()) return false;
|
||||
bool SignItem::useOn(std::shared_ptr<ItemInstance> instance,
|
||||
std::shared_ptr<Player> player, Level* level, int x, int y,
|
||||
int z, int face, float clickX, float clickY, float clickZ,
|
||||
bool bTestUseOnOnly) {
|
||||
// 4J-PB - Adding a test only version to allow tooltips to be displayed
|
||||
if (face == 0) return false;
|
||||
if (!level->getMaterial(x, y, z)->isSolid()) return false;
|
||||
|
||||
if (face == 1) y++;
|
||||
if (face == 2) z--;
|
||||
if (face == 3) z++;
|
||||
if (face == 4) x--;
|
||||
if (face == 5) x++;
|
||||
|
||||
if (face == 1) y++;
|
||||
if (face == 2) z--;
|
||||
if (face == 3) z++;
|
||||
if (face == 4) x--;
|
||||
if (face == 5) x++;
|
||||
if (!player->mayBuild(x, y, z)) return false;
|
||||
|
||||
if (!player->mayBuild(x, y, z)) return false;
|
||||
if (!Tile::sign->mayPlace(level, x, y, z)) return false;
|
||||
|
||||
if (!Tile::sign->mayPlace(level, x, y, z)) return false;
|
||||
if (!bTestUseOnOnly) {
|
||||
if (face == 1) {
|
||||
int rot = Mth::floor(((player->yRot + 180) * 16) / 360 + 0.5) & 15;
|
||||
level->setTileAndData(x, y, z, Tile::sign_Id, rot);
|
||||
} else {
|
||||
level->setTileAndData(x, y, z, Tile::wallSign_Id, face);
|
||||
}
|
||||
|
||||
if(!bTestUseOnOnly)
|
||||
{
|
||||
if (face == 1)
|
||||
{
|
||||
int rot = Mth::floor(((player->yRot + 180) * 16) / 360 + 0.5) & 15;
|
||||
level->setTileAndData(x, y, z, Tile::sign_Id, rot);
|
||||
}
|
||||
else
|
||||
{
|
||||
level->setTileAndData(x, y, z, Tile::wallSign_Id, face);
|
||||
}
|
||||
instance->count--;
|
||||
std::shared_ptr<SignTileEntity> ste =
|
||||
std::dynamic_pointer_cast<SignTileEntity>(
|
||||
level->getTileEntity(x, y, z));
|
||||
if (ste != NULL) player->openTextEdit(ste);
|
||||
|
||||
instance->count--;
|
||||
std::shared_ptr<SignTileEntity> ste = std::dynamic_pointer_cast<SignTileEntity>( level->getTileEntity(x, y, z) );
|
||||
if (ste != NULL) player->openTextEdit(ste);
|
||||
|
||||
// 4J-JEV: Hook for durango 'BlockPlaced' event.
|
||||
player->awardStat(
|
||||
GenericStats::blocksPlaced((face==1) ? Tile::sign_Id : Tile::wallSign_Id),
|
||||
GenericStats::param_blocksPlaced(
|
||||
(face==1) ? Tile::sign_Id : Tile::wallSign_Id,
|
||||
instance->getAuxValue(),
|
||||
1)
|
||||
);
|
||||
}
|
||||
return true;
|
||||
// 4J-JEV: Hook for durango 'BlockPlaced' event.
|
||||
player->awardStat(GenericStats::blocksPlaced(
|
||||
(face == 1) ? Tile::sign_Id : Tile::wallSign_Id),
|
||||
GenericStats::param_blocksPlaced(
|
||||
(face == 1) ? Tile::sign_Id : Tile::wallSign_Id,
|
||||
instance->getAuxValue(), 1));
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user