Implemented split between consumable crafting initialization and equipment enhancement initialization.
parent
b02936fcb5
commit
4e3c9877e7
@ -0,0 +1,185 @@ |
|||||||
|
#pragma region License |
||||||
|
/*
|
||||||
|
License (OLC-3) |
||||||
|
~~~~~~~~~~~~~~~ |
||||||
|
|
||||||
|
Copyright 2018 - 2022 OneLoneCoder.com |
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without modification, |
||||||
|
are permitted provided that the following conditions are met: |
||||||
|
|
||||||
|
1. Redistributions or derivations of source code must retain the above copyright |
||||||
|
notice, this list of conditions and the following disclaimer. |
||||||
|
|
||||||
|
2. Redistributions or derivative works in binary form must reproduce the above |
||||||
|
copyright notice. This list of conditions and the following disclaimer must be |
||||||
|
reproduced in the documentation and/or other materials provided with the distribution. |
||||||
|
|
||||||
|
3. Neither the name of the copyright holder nor the names of its contributors may |
||||||
|
be used to endorse or promote products derived from this software without specific |
||||||
|
prior written permission. |
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY |
||||||
|
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES |
||||||
|
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT |
||||||
|
SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, |
||||||
|
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED |
||||||
|
TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR |
||||||
|
BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
||||||
|
ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
||||||
|
SUCH DAMAGE. |
||||||
|
|
||||||
|
Portions of this software are copyright © 2023 The FreeType |
||||||
|
Project (www.freetype.org). Please see LICENSE_FT.txt for more information. |
||||||
|
All rights reserved. |
||||||
|
*/ |
||||||
|
#pragma endregion |
||||||
|
|
||||||
|
#include "Menu.h" |
||||||
|
#include "Crawler.h" |
||||||
|
#include "MenuItemItemButton.h" |
||||||
|
#include "PlayerMoneyLabel.h" |
||||||
|
#include "RowInventoryScrollableWindowComponent.h" |
||||||
|
#include "EnhancementStatsLabel.h" |
||||||
|
#include "RequiredMaterialsList.h" |
||||||
|
|
||||||
|
INCLUDE_game |
||||||
|
INCLUDE_ITEM_CATEGORIES |
||||||
|
INCLUDE_DATA |
||||||
|
INCLUDE_GFX |
||||||
|
|
||||||
|
void Menu::InitializeConsumableCraftingWindow(){ |
||||||
|
Menu*consumableCraftingWindow=CreateMenu(CRAFT_CONSUMABLE,CENTERED,game->GetScreenSize()-vi2d{52,52}); |
||||||
|
|
||||||
|
std::vector<std::pair<std::string,int>>categories; |
||||||
|
std::vector<std::weak_ptr<Item>>weaponInventory; |
||||||
|
std::vector<std::weak_ptr<Item>>armorInventory; |
||||||
|
|
||||||
|
#pragma region Build Equipment Lists |
||||||
|
std::for_each(Inventory::get("Equipment").begin(),Inventory::get("Equipment").end(),[&](const std::shared_ptr<Item> item){ |
||||||
|
switch(item.get()->GetEquipSlot()){ |
||||||
|
case EquipSlot::WEAPON:{ |
||||||
|
weaponInventory.push_back(item); |
||||||
|
}break; |
||||||
|
case EquipSlot::NONE: |
||||||
|
case EquipSlot::RING1: |
||||||
|
case EquipSlot::RING2:break;//No-op
|
||||||
|
default:{ //We assume everything else is armor.
|
||||||
|
armorInventory.push_back(item); |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
#pragma endregion |
||||||
|
|
||||||
|
auto weaponTab=consumableCraftingWindow->ADD("Weapon Tab",MenuComponent)({{2,0},{consumableCraftingWindow->size.x/2-4,24}},"Weapon",[](MenuFuncData data){ |
||||||
|
Component<MenuComponent>(CRAFT_CONSUMABLE,"Armor Tab")->selected=false; |
||||||
|
Component<RowInventoryScrollableWindowComponent>(CRAFT_CONSUMABLE,"Weapon Inventory Display")->Enable(true); |
||||||
|
Component<RowInventoryScrollableWindowComponent>(CRAFT_CONSUMABLE,"Armor Inventory Display")->Enable(false); |
||||||
|
data.component->selected=true; |
||||||
|
return true; |
||||||
|
})END; |
||||||
|
weaponTab->selected=true; |
||||||
|
weaponTab->selectionType=SelectionType::HIGHLIGHT; |
||||||
|
auto armorTab=consumableCraftingWindow->ADD("Armor Tab",MenuComponent)({{consumableCraftingWindow->size.x/2+2,0},{consumableCraftingWindow->size.x/2-4,24}},"Armor",[](MenuFuncData data){ |
||||||
|
Component<MenuComponent>(CRAFT_CONSUMABLE,"Weapon Tab")->selected=false; |
||||||
|
Component<RowInventoryScrollableWindowComponent>(CRAFT_CONSUMABLE,"Weapon Inventory Display")->Enable(false); |
||||||
|
Component<RowInventoryScrollableWindowComponent>(CRAFT_CONSUMABLE,"Armor Inventory Display")->Enable(true); |
||||||
|
data.component->selected=true; |
||||||
|
return true; |
||||||
|
})END; |
||||||
|
armorTab->selectionType=SelectionType::HIGHLIGHT; |
||||||
|
|
||||||
|
#pragma region Weapon Inventory Display |
||||||
|
auto weaponsDisplay=consumableCraftingWindow->ADD("Weapon Inventory Display",RowInventoryScrollableWindowComponent)({{2,28},{220,consumableCraftingWindow->size.y-44}},"Item Name Label","Item Description Label", |
||||||
|
[](MenuFuncData data){ |
||||||
|
RowItemDisplay*comp=DYNAMIC_CAST<RowItemDisplay*>(data.component); |
||||||
|
const std::weak_ptr<Item>item=comp->GetItem(); |
||||||
|
|
||||||
|
std::string label=""; |
||||||
|
if(item.lock()->EnhancementIsPossible()&&item.lock()->GetEnhancementInfo().size()>item.lock()->EnhancementLevel()+1){ |
||||||
|
label=std::format("Level {} ->#00AA00 {}",item.lock()->EnhancementLevel(),item.lock()->EnhancementLevel()+1); |
||||||
|
} |
||||||
|
Component<MenuLabel>(CRAFT_ITEM,"Enhancement Level Header")->SetLabel(label); |
||||||
|
Component<MenuLabel>(CRAFT_ITEM,"Item Name Header")->SetLabel(std::format("Crafting {}",item.lock()->DisplayName())); |
||||||
|
Component<EnhancementStatsLabel>(CRAFT_ITEM,"Enhancement Stats Label")->SetItem(item); |
||||||
|
Component<RequiredMaterialsList>(CRAFT_ITEM,"Required Materials List")->SetItem(item); |
||||||
|
Component<MenuComponent>(CRAFT_ITEM,"Craft Button")->SetGrayedOut(!item.lock()->CanEnhanceItem()); |
||||||
|
Menu::OpenMenu(CRAFT_ITEM); |
||||||
|
return true; |
||||||
|
}, |
||||||
|
[](MenuFuncData data){ |
||||||
|
RowItemDisplay*rowItem=DYNAMIC_CAST<RowItemDisplay*>(data.component); |
||||||
|
Component<MenuItemItemButton>(CRAFT_CONSUMABLE,"Item Icon")->SetItem(rowItem->GetItem()); |
||||||
|
return true; |
||||||
|
}, |
||||||
|
[](MenuFuncData data){ |
||||||
|
Component<MenuItemItemButton>(CRAFT_CONSUMABLE,"Item Icon")->SetItem(Item::BLANK); |
||||||
|
return true; |
||||||
|
}, |
||||||
|
InventoryCreator::RowPlayerWeapons_InventoryUpdate, |
||||||
|
{.padding=1,.size={207,28}} |
||||||
|
)END; |
||||||
|
AddInventoryListener(weaponsDisplay,"Equipment"); |
||||||
|
weaponsDisplay->SetCompactDescriptions(CRAFTING_INFO); |
||||||
|
#pragma endregion |
||||||
|
|
||||||
|
#pragma region Armor Inventory Display |
||||||
|
auto armorDisplay=consumableCraftingWindow->ADD("Armor Inventory Display",RowInventoryScrollableWindowComponent)({{2,28},{220,consumableCraftingWindow->size.y-44}},"Item Name Label","Item Description Label", |
||||||
|
[](MenuFuncData data){ |
||||||
|
Menu::OpenMenu(CRAFT_ITEM); |
||||||
|
RowItemDisplay*comp=DYNAMIC_CAST<RowItemDisplay*>(data.component); |
||||||
|
const std::weak_ptr<Item>item=comp->GetItem(); |
||||||
|
|
||||||
|
std::string label=""; |
||||||
|
if(item.lock()->EnhancementIsPossible()&&item.lock()->GetEnhancementInfo().size()>item.lock()->EnhancementLevel()+1){ |
||||||
|
label=std::format("Level {} ->#00AA00 {}",item.lock()->EnhancementLevel(),item.lock()->EnhancementLevel()+1); |
||||||
|
} |
||||||
|
Component<MenuLabel>(CRAFT_ITEM,"Enhancement Level Header")->SetLabel(label); |
||||||
|
Component<MenuLabel>(CRAFT_ITEM,"Item Name Header")->SetLabel(std::format("Crafting {}",item.lock()->DisplayName())); |
||||||
|
Component<EnhancementStatsLabel>(CRAFT_ITEM,"Enhancement Stats Label")->SetItem(item); |
||||||
|
Component<RequiredMaterialsList>(CRAFT_ITEM,"Required Materials List")->SetItem(item); |
||||||
|
Component<MenuComponent>(CRAFT_ITEM,"Craft Button")->SetGrayedOut(!item.lock()->CanEnhanceItem()); |
||||||
|
return true; |
||||||
|
}, |
||||||
|
[](MenuFuncData data){ |
||||||
|
RowItemDisplay*rowItem=DYNAMIC_CAST<RowItemDisplay*>(data.component); |
||||||
|
Component<MenuItemItemButton>(CRAFT_CONSUMABLE,"Item Icon")->SetItem(rowItem->GetItem()); |
||||||
|
return true; |
||||||
|
}, |
||||||
|
[](MenuFuncData data){ |
||||||
|
Component<MenuItemItemButton>(CRAFT_CONSUMABLE,"Item Icon")->SetItem(Item::BLANK); |
||||||
|
return true; |
||||||
|
}, |
||||||
|
InventoryCreator::RowPlayerArmor_InventoryUpdate, |
||||||
|
{.padding=1,.size={207,28}} |
||||||
|
)END; |
||||||
|
AddInventoryListener(armorDisplay,"Equipment"); |
||||||
|
armorDisplay->Enable(false); |
||||||
|
armorDisplay->SetCompactDescriptions(CRAFTING_INFO); |
||||||
|
#pragma endregion |
||||||
|
|
||||||
|
#pragma region Inventory Description |
||||||
|
float inventoryDescriptionWidth=consumableCraftingWindow->pos.x+consumableCraftingWindow->size.x-26-224; |
||||||
|
consumableCraftingWindow->ADD("Item Description Outline",MenuLabel)({{224,28},{inventoryDescriptionWidth,consumableCraftingWindow->size.y-44}},"",1,ComponentAttr::LEFT_ALIGN|ComponentAttr::OUTLINE|ComponentAttr::BACKGROUND)END; |
||||||
|
consumableCraftingWindow->ADD("Item Icon",MenuItemItemButton)({{226+inventoryDescriptionWidth/2-24,30},{48,48}},Item::BLANK,MenuType::ENUM_END,DO_NOTHING,"","",IconButtonAttr::NOT_SELECTABLE)END; |
||||||
|
consumableCraftingWindow->ADD("Item Name Label",MenuLabel)({{226,84},{inventoryDescriptionWidth-6,12}},"",0.75f,ComponentAttr::LEFT_ALIGN|ComponentAttr::SHADOW)END; |
||||||
|
consumableCraftingWindow->ADD("Item Description Label",MenuLabel)({{226,94},{inventoryDescriptionWidth-6,consumableCraftingWindow->size.y-44-66}},"",0.5f,ComponentAttr::LEFT_ALIGN|ComponentAttr::SHADOW)END; |
||||||
|
#pragma endregion |
||||||
|
|
||||||
|
#pragma region Money Display |
||||||
|
vf2d moneyIconPos={224+inventoryDescriptionWidth-24,28+consumableCraftingWindow->size.y-44+6}; |
||||||
|
auto moneyIcon=consumableCraftingWindow->ADD("Money Icon",MenuIconButton)({moneyIconPos,{24,24}},GFX["money.png"].Decal(),DO_NOTHING,IconButtonAttr::NOT_SELECTABLE|IconButtonAttr::NO_OUTLINE|IconButtonAttr::NO_BACKGROUND)END; |
||||||
|
std::string moneyText=std::to_string(game->GetPlayer()->GetMoney()); |
||||||
|
vf2d moneyTextSize=game->GetTextSizeProp(moneyText)*2; |
||||||
|
auto moneyDisplay=consumableCraftingWindow->ADD("Money Label",PlayerMoneyLabel)({moneyIconPos-vf2d{2+moneyTextSize.x,-2},moneyTextSize},2,ComponentAttr::SHADOW|ComponentAttr::LEFT_ALIGN)END; |
||||||
|
moneyDisplay->SetRightAlignment(true); |
||||||
|
Player::AddMoneyListener(moneyDisplay); |
||||||
|
#pragma endregion |
||||||
|
|
||||||
|
consumableCraftingWindow->ADD("Leave Button",MenuComponent)({{consumableCraftingWindow->size.x/2-48,28+consumableCraftingWindow->size.y-44+6},{96,24}},"Leave",MenuType::ENUM_END, |
||||||
|
[](MenuFuncData data){ |
||||||
|
Menu::CloseMenu(); |
||||||
|
return true; |
||||||
|
},{2,2})END; |
||||||
|
} |
@ -0,0 +1,12 @@ |
|||||||
|
Merchants items |
||||||
|
Minor Health Potion (s: 16g b: 23g) // Buyable or crafted with 3x Green Slime Remains + 1 Blue Slime Remains |
||||||
|
Minor Mana Potion (s: 21g b: 30g) // Buyable or crafted with 1 Red Slime Remains + 1 Yellow Slime Remains |
||||||
|
Bandages (s: 7g b: 10g) // Buyable |
||||||
|
|
||||||
|
other Consumables |
||||||
|
Berries (s: 8g) // 5% dropp from every Flower or Slime |
||||||
|
Elixir of Bear Strength (s: 30g) // crafted with 1 Bear Claw + 1 Bear Blood |
||||||
|
Minor Recovery Potion (s: 15g) // crafted with 1 Blue Slime Remains, 1 Red Slime Remains and 1 Flower Petal" |
||||||
|
|
||||||
|
Only for 4 potions to craft in chapter 1. |
||||||
|
But guess if every chapter has 4-5 potions that should be enough |
Loading…
Reference in new issue