diff options
| author | daoge_cmd <3523206925@qq.com> | 2026-03-01 12:16:08 +0800 |
|---|---|---|
| committer | daoge_cmd <3523206925@qq.com> | 2026-03-01 12:16:08 +0800 |
| commit | b691c43c44ff180d10e7d4a9afc83b98551ff586 (patch) | |
| tree | 3e9849222cbc6ba49f2f1fc6e5fe7179632c7390 /Minecraft.World/BedItem.cpp | |
| parent | def8cb415354ac390b7e89052a50605285f1aca9 (diff) | |
Initial commit
Diffstat (limited to 'Minecraft.World/BedItem.cpp')
| -rw-r--r-- | Minecraft.World/BedItem.cpp | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/Minecraft.World/BedItem.cpp b/Minecraft.World/BedItem.cpp new file mode 100644 index 00000000..1ff50c6c --- /dev/null +++ b/Minecraft.World/BedItem.cpp @@ -0,0 +1,59 @@ +#include "stdafx.h" +#include "net.minecraft.h" +#include "net.minecraft.world.entity.player.h" +#include "net.minecraft.world.level.h" +#include "net.minecraft.world.level.tile.h" +#include "net.minecraft.world.item.h" +#include "Facing.h" +#include "GenericStats.h" +#include "BedItem.h" + +BedItem::BedItem(int id) : Item( id ) +{ +} + +bool BedItem::useOn(shared_ptr<ItemInstance> itemInstance, shared_ptr<Player> player, Level *level, int x, int y, int z, int face, float clickX, float clickY, float clickZ, bool bTestUseOnOnly) +{ + if (face != Facing::UP) + { + return false; + } + + // place on top of tile + y = y + 1; + + BedTile *tile = (BedTile *) Tile::bed; + + int dir = ( Mth::floor(player->yRot * 4 / (360) + 0.5f) ) & 3; + int xra = 0; + int zra = 0; + + if (dir == Direction::SOUTH) zra = 1; + if (dir == Direction::WEST) xra = -1; + if (dir == Direction::NORTH) zra = -1; + if (dir == Direction::EAST) xra = 1; + + if (!player->mayBuild(x, y, z) || !player->mayBuild(x + xra, y, z + zra)) return false; + + if (level->isEmptyTile(x, y, z) && level->isEmptyTile(x + xra, y, z + zra) && level->isTopSolidBlocking(x, y - 1, z) && level->isTopSolidBlocking(x + xra, y - 1, z + zra)) + { + // 4J-PB - Adding a test only version to allow tooltips to be displayed + if(!bTestUseOnOnly) + { + level->setTileAndData(x, y, z, tile->id, dir); + // double-check that the bed was successfully placed + if (level->getTile(x, y, z) == tile->id) + { + // 4J-JEV: Hook for durango 'BlockPlaced' event. + player->awardStat(GenericStats::blocksPlaced(tile->id), GenericStats::param_blocksPlaced(tile->id,itemInstance->getAuxValue(),1)); + + level->setTileAndData(x + xra, y, z + zra, tile->id, dir + BedTile::HEAD_PIECE_DATA); + } + + itemInstance->count--; + } + return true; + } + + return false; +} |
