|
|
@ -31,6 +31,7 @@ namespace MWGui
|
|
|
|
{
|
|
|
|
{
|
|
|
|
AlchemyWindow::AlchemyWindow()
|
|
|
|
AlchemyWindow::AlchemyWindow()
|
|
|
|
: WindowBase("openmw_alchemy_window.layout")
|
|
|
|
: WindowBase("openmw_alchemy_window.layout")
|
|
|
|
|
|
|
|
, mCurrentFilter(FilterType::ByName)
|
|
|
|
, mModel(nullptr)
|
|
|
|
, mModel(nullptr)
|
|
|
|
, mSortModel(nullptr)
|
|
|
|
, mSortModel(nullptr)
|
|
|
|
, mAlchemy(new MWMechanics::Alchemy())
|
|
|
|
, mAlchemy(new MWMechanics::Alchemy())
|
|
|
@ -192,16 +193,16 @@ namespace MWGui
|
|
|
|
std::set<std::string> itemNames, itemEffects;
|
|
|
|
std::set<std::string> itemNames, itemEffects;
|
|
|
|
for (size_t i = 0; i < mModel->getItemCount(); ++i)
|
|
|
|
for (size_t i = 0; i < mModel->getItemCount(); ++i)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
auto const& base = mModel->getItem(i).mBase;
|
|
|
|
MWWorld::Ptr item = mModel->getItem(i).mBase;
|
|
|
|
if (base.getTypeName() != typeid(ESM::Ingredient).name())
|
|
|
|
if (item.getTypeName() != typeid(ESM::Ingredient).name())
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
itemNames.insert(base.getClass().getName(base));
|
|
|
|
itemNames.insert(item.getClass().getName(item));
|
|
|
|
|
|
|
|
|
|
|
|
MWWorld::Ptr player = MWBase::Environment::get().getWorld ()->getPlayerPtr();
|
|
|
|
MWWorld::Ptr player = MWBase::Environment::get().getWorld ()->getPlayerPtr();
|
|
|
|
auto const alchemySkill = player.getClass().getSkill(player, ESM::Skill::Alchemy);
|
|
|
|
auto const alchemySkill = player.getClass().getSkill(player, ESM::Skill::Alchemy);
|
|
|
|
|
|
|
|
|
|
|
|
auto const effects = MWMechanics::Alchemy::effectsDescription(base, alchemySkill);
|
|
|
|
auto const effects = MWMechanics::Alchemy::effectsDescription(item, alchemySkill);
|
|
|
|
itemEffects.insert(effects.begin(), effects.end());
|
|
|
|
itemEffects.insert(effects.begin(), effects.end());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|