aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/WeighedTreasure.cpp
diff options
context:
space:
mode:
authordaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
committerdaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
commitb691c43c44ff180d10e7d4a9afc83b98551ff586 (patch)
tree3e9849222cbc6ba49f2f1fc6e5fe7179632c7390 /Minecraft.World/WeighedTreasure.cpp
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.World/WeighedTreasure.cpp')
-rw-r--r--Minecraft.World/WeighedTreasure.cpp86
1 files changed, 86 insertions, 0 deletions
diff --git a/Minecraft.World/WeighedTreasure.cpp b/Minecraft.World/WeighedTreasure.cpp
new file mode 100644
index 00000000..d7044644
--- /dev/null
+++ b/Minecraft.World/WeighedTreasure.cpp
@@ -0,0 +1,86 @@
+#include "stdafx.h"
+#include "net.minecraft.world.level.tile.entity.h"
+#include "net.minecraft.world.item.h"
+#include "WeighedRandom.h"
+#include "WeighedTreasure.h"
+
+WeighedTreasure::WeighedTreasure(int itemId, int auxValue, int minCount, int maxCount, int weight) : WeighedRandomItem(weight)
+{
+ this->item = shared_ptr<ItemInstance>( new ItemInstance(itemId, 1, auxValue) );
+ this->minCount = minCount;
+ this->maxCount = maxCount;
+}
+
+WeighedTreasure::WeighedTreasure(shared_ptr<ItemInstance> item, int minCount, int maxCount, int weight) : WeighedRandomItem(weight)
+{
+ this->item = item;
+ this->minCount = minCount;
+ this->maxCount = maxCount;
+}
+
+void WeighedTreasure::addChestItems(Random *random, WeighedTreasureArray items, shared_ptr<ChestTileEntity> dest, int numRolls)
+{
+ for (int r = 0; r < numRolls; r++)
+ {
+ WeighedTreasure *treasure = (WeighedTreasure *) WeighedRandom::getRandomItem(random, *((WeighedRandomItemArray *)&items));
+
+ int count = treasure->minCount + random->nextInt(treasure->maxCount - treasure->minCount + 1);
+ if (treasure->item->getMaxStackSize() >= count)
+ {
+ shared_ptr<ItemInstance> copy = treasure->item->copy();
+ copy->count = count;
+ dest->setItem(random->nextInt(dest->getContainerSize()), copy);
+ }
+ else
+ {
+ // use multiple slots
+ for (int c = 0; c < count; c++)
+ {
+ shared_ptr<ItemInstance> copy = treasure->item->copy();
+ copy->count = 1;
+ dest->setItem(random->nextInt(dest->getContainerSize()), copy);
+ }
+ }
+ }
+}
+
+void WeighedTreasure::addDispenserItems(Random *random, WeighedTreasureArray items, shared_ptr<DispenserTileEntity> dest, int numRolls)
+{
+ for (int r = 0; r < numRolls; r++)
+ {
+ WeighedTreasure *treasure = (WeighedTreasure *) WeighedRandom::getRandomItem(random, *((WeighedRandomItemArray *)&items));
+
+ int count = treasure->minCount + random->nextInt(treasure->maxCount - treasure->minCount + 1);
+ if (treasure->item->getMaxStackSize() >= count)
+ {
+ shared_ptr<ItemInstance> copy = treasure->item->copy();
+ copy->count = count;
+ dest->setItem(random->nextInt(dest->getContainerSize()), copy);
+ }
+ else
+ {
+ // use multiple slots
+ for (int c = 0; c < count; c++)
+ {
+ shared_ptr<ItemInstance> copy = treasure->item->copy();
+ copy->count = 1;
+ dest->setItem(random->nextInt(dest->getContainerSize()), copy);
+ }
+ }
+ }
+}
+
+WeighedTreasureArray WeighedTreasure::addToTreasure(WeighedTreasureArray items, WeighedTreasure *extra)
+{
+ WeighedTreasureArray result(items.length + 1);
+ int i = 0;
+
+ for (int j = 0; j < items.length; j++)
+ {
+ result[i++] = items[j];
+ }
+
+ result[i++] = extra;
+
+ return result;
+} \ No newline at end of file