mirror of
https://github.com/smartcmd/MinecraftConsoles.git
synced 2026-03-23 02:58:12 +05:00
* Fixed boats falling and a TP glitch #266 * Replaced every C-style cast with C++ ones * Replaced every C-style cast with C++ ones * Fixed boats falling and a TP glitch #266 * Updated NULL to nullptr and fixing some type issues * Modernized and fixed a few bugs - Replaced most instances of `NULL` with `nullptr`. - Replaced most `shared_ptr(new ...)` with `make_shared`. - Removed the `nullptr` macro as it was interfering with the actual nullptr keyword in some instances. * Fixing more conflicts * Replace int loops with size_t and start work on overrides * Add safety checks and fix a issue with vector going OOR
46 lines
1.2 KiB
C++
46 lines
1.2 KiB
C++
#include "stdafx.h"
|
|
#include "net.minecraft.world.entity.item.h"
|
|
#include "net.minecraft.world.level.h"
|
|
#include "net.minecraft.world.level.redstone.h"
|
|
#include "net.minecraft.world.item.h"
|
|
#include "Entity.h"
|
|
#include "WeightedPressurePlateTile.h"
|
|
|
|
WeightedPressurePlateTile::WeightedPressurePlateTile(int id, const wstring &tex, Material *material, int maxWeight) : BasePressurePlateTile(id, tex, material)
|
|
{
|
|
this->maxWeight = maxWeight;
|
|
|
|
// 4J Stu - Move this from base class to use virtual function
|
|
updateShape(getDataForSignal(Redstone::SIGNAL_MAX));
|
|
}
|
|
|
|
int WeightedPressurePlateTile::getSignalStrength(Level *level, int x, int y, int z)
|
|
{
|
|
int weightOfEntities = level->getEntitiesOfClass(typeid(Entity), getSensitiveAABB(x, y, z))->size();
|
|
int count = min(weightOfEntities, maxWeight);
|
|
|
|
if (count <= 0)
|
|
{
|
|
return 0;
|
|
}
|
|
else
|
|
{
|
|
float pct = min(maxWeight, count) / static_cast<float>(maxWeight);
|
|
return Mth::ceil(pct * Redstone::SIGNAL_MAX);
|
|
}
|
|
}
|
|
|
|
int WeightedPressurePlateTile::getSignalForData(int data)
|
|
{
|
|
return data;
|
|
}
|
|
|
|
int WeightedPressurePlateTile::getDataForSignal(int signal)
|
|
{
|
|
return signal;
|
|
}
|
|
|
|
int WeightedPressurePlateTile::getTickDelay(Level *level)
|
|
{
|
|
return SharedConstants::TICKS_PER_SECOND / 2;
|
|
} |