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/FurnaceRecipes.cpp | |
| parent | def8cb415354ac390b7e89052a50605285f1aca9 (diff) | |
Initial commit
Diffstat (limited to 'Minecraft.World/FurnaceRecipes.cpp')
| -rw-r--r-- | Minecraft.World/FurnaceRecipes.cpp | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/Minecraft.World/FurnaceRecipes.cpp b/Minecraft.World/FurnaceRecipes.cpp new file mode 100644 index 00000000..49ded1f5 --- /dev/null +++ b/Minecraft.World/FurnaceRecipes.cpp @@ -0,0 +1,82 @@ +#include "stdafx.h" +#include "net.minecraft.world.item.h" +#include "Tile.h" +#include "FurnaceRecipes.h" + +FurnaceRecipes *FurnaceRecipes::instance = NULL; + +void FurnaceRecipes::staticCtor() +{ + FurnaceRecipes::instance = new FurnaceRecipes(); +} + +FurnaceRecipes *FurnaceRecipes::getInstance() +{ + return instance; +} + +FurnaceRecipes::FurnaceRecipes() +{ + addFurnaceRecipy(Tile::ironOre_Id, new ItemInstance(Item::ironIngot), .7f); + addFurnaceRecipy(Tile::goldOre_Id, new ItemInstance(Item::goldIngot), 1); + addFurnaceRecipy(Tile::diamondOre_Id, new ItemInstance(Item::diamond), 1); + addFurnaceRecipy(Tile::sand_Id, new ItemInstance(Tile::glass), .1f); + addFurnaceRecipy(Item::porkChop_raw_Id, new ItemInstance(Item::porkChop_cooked), .35f); + addFurnaceRecipy(Item::beef_raw_Id, new ItemInstance(Item::beef_cooked), .35f); + addFurnaceRecipy(Item::chicken_raw_Id, new ItemInstance(Item::chicken_cooked), .35f); + addFurnaceRecipy(Item::fish_raw_Id, new ItemInstance(Item::fish_cooked), .35f); + addFurnaceRecipy(Tile::stoneBrick_Id, new ItemInstance(Tile::rock), .1f); + addFurnaceRecipy(Item::clay_Id, new ItemInstance(Item::brick), .3f); + addFurnaceRecipy(Tile::cactus_Id, new ItemInstance(Item::dye_powder, 1, DyePowderItem::GREEN), .2f); + addFurnaceRecipy(Tile::treeTrunk_Id, new ItemInstance(Item::coal, 1, CoalItem::CHAR_COAL), .15f); + addFurnaceRecipy(Tile::emeraldOre_Id, new ItemInstance(Item::emerald), 1); + addFurnaceRecipy(Item::potato_Id, new ItemInstance(Item::potatoBaked), .35f); + // 4J - TU9 - add in smelting netherrack + addFurnaceRecipy(Tile::hellRock_Id, new ItemInstance(Item::netherbrick), .1f); + + // special silk touch related recipes: + addFurnaceRecipy(Tile::coalOre_Id, new ItemInstance(Item::coal), .1f); + addFurnaceRecipy(Tile::redStoneOre_Id, new ItemInstance(Item::redStone), .7f); + addFurnaceRecipy(Tile::lapisOre_Id, new ItemInstance(Item::dye_powder, 1, DyePowderItem::BLUE), .2f); + addFurnaceRecipy(Tile::netherQuartz_Id, new ItemInstance(Item::netherQuartz), .2f); + + +} + +void FurnaceRecipes::addFurnaceRecipy(int itemId, ItemInstance *result, float value) +{ + //recipies->put(itemId, result); + recipies[itemId]=result; + recipeValue[result->id] = value; +} + +bool FurnaceRecipes::isFurnaceItem(int itemId) +{ + AUTO_VAR(it, recipies.find(itemId)); + return it != recipies.end(); +} + +ItemInstance *FurnaceRecipes::getResult(int itemId) +{ + AUTO_VAR(it, recipies.find(itemId)); + if(it != recipies.end()) + { + return it->second; + } + return NULL; +} + +unordered_map<int, ItemInstance *> *FurnaceRecipes::getRecipies() +{ + return &recipies; +} + +float FurnaceRecipes::getRecipeValue(int itemId) +{ + AUTO_VAR(it, recipeValue.find(itemId)); + if (it != recipeValue.end()) + { + return it->second; + } + return 0.0f; +}
\ No newline at end of file |
