1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-21 07:53:53 +00:00

Merge branch 'noskill' into 'master'

Remove Attribute/Skill from tooltips

Closes #7281

See merge request OpenMW/openmw!2845
This commit is contained in:
psi29a 2023-03-22 09:25:26 +00:00
commit 99dac61e49

View file

@ -379,33 +379,68 @@ namespace MWGui::Widgets
assert(magicEffect); assert(magicEffect);
std::string_view pt = MWBase::Environment::get().getWindowManager()->getGameSettingString("spoint", {}); auto windowManager = MWBase::Environment::get().getWindowManager();
std::string_view pts = MWBase::Environment::get().getWindowManager()->getGameSettingString("spoints", {});
std::string_view pct = MWBase::Environment::get().getWindowManager()->getGameSettingString("spercent", {});
std::string_view ft = MWBase::Environment::get().getWindowManager()->getGameSettingString("sfeet", {});
std::string_view lvl = MWBase::Environment::get().getWindowManager()->getGameSettingString("sLevel", {});
std::string_view lvls = MWBase::Environment::get().getWindowManager()->getGameSettingString("sLevels", {});
std::string to
= " " + std::string{ MWBase::Environment::get().getWindowManager()->getGameSettingString("sTo", {}) } + " ";
std::string sec
= " " + std::string{ MWBase::Environment::get().getWindowManager()->getGameSettingString("ssecond", {}) };
std::string secs
= " " + std::string{ MWBase::Environment::get().getWindowManager()->getGameSettingString("sseconds", {}) };
const std::string& effectIDStr = ESM::MagicEffect::effectIdToString(mEffectParams.mEffectID); std::string_view pt = windowManager->getGameSettingString("spoint", {});
std::string spellLine{ MWBase::Environment::get().getWindowManager()->getGameSettingString(effectIDStr, {}) }; std::string_view pts = windowManager->getGameSettingString("spoints", {});
std::string_view pct = windowManager->getGameSettingString("spercent", {});
std::string_view ft = windowManager->getGameSettingString("sfeet", {});
std::string_view lvl = windowManager->getGameSettingString("sLevel", {});
std::string_view lvls = windowManager->getGameSettingString("sLevels", {});
std::string to = " " + std::string{ windowManager->getGameSettingString("sTo", {}) } + " ";
std::string sec = " " + std::string{ windowManager->getGameSettingString("ssecond", {}) };
std::string secs = " " + std::string{ windowManager->getGameSettingString("sseconds", {}) };
if (magicEffect->mData.mFlags & ESM::MagicEffect::TargetSkill && mEffectParams.mSkill != -1) const bool targetsSkill
= magicEffect->mData.mFlags & ESM::MagicEffect::TargetSkill && mEffectParams.mSkill != -1;
const bool targetsAttribute
= magicEffect->mData.mFlags & ESM::MagicEffect::TargetAttribute && mEffectParams.mAttribute != -1;
std::string spellLine;
if (targetsSkill || targetsAttribute)
{ {
spellLine += ' '; switch (magicEffect->mIndex)
spellLine += MWBase::Environment::get().getWindowManager()->getGameSettingString( {
ESM::Skill::sSkillNameIds[mEffectParams.mSkill], {}); case ESM::MagicEffect::AbsorbAttribute:
case ESM::MagicEffect::AbsorbSkill:
spellLine = windowManager->getGameSettingString("sAbsorb", {});
break;
case ESM::MagicEffect::DamageAttribute:
case ESM::MagicEffect::DamageSkill:
spellLine = windowManager->getGameSettingString("sDamage", {});
break;
case ESM::MagicEffect::DrainAttribute:
case ESM::MagicEffect::DrainSkill:
spellLine = windowManager->getGameSettingString("sDrain", {});
break;
case ESM::MagicEffect::FortifyAttribute:
case ESM::MagicEffect::FortifySkill:
spellLine = windowManager->getGameSettingString("sFortify", {});
break;
case ESM::MagicEffect::RestoreAttribute:
case ESM::MagicEffect::RestoreSkill:
spellLine = windowManager->getGameSettingString("sRestore", {});
break;
} }
if (magicEffect->mData.mFlags & ESM::MagicEffect::TargetAttribute && mEffectParams.mAttribute != -1) }
if (spellLine.empty())
{
const std::string& effectIDStr = ESM::MagicEffect::effectIdToString(mEffectParams.mEffectID);
spellLine = windowManager->getGameSettingString(effectIDStr, {});
}
if (targetsSkill)
{ {
spellLine += ' '; spellLine += ' ';
spellLine += MWBase::Environment::get().getWindowManager()->getGameSettingString( spellLine += windowManager->getGameSettingString(ESM::Skill::sSkillNameIds[mEffectParams.mSkill], {});
ESM::Attribute::sGmstAttributeIds[mEffectParams.mAttribute], {}); }
if (targetsAttribute)
{
spellLine += ' ';
spellLine
+= windowManager->getGameSettingString(ESM::Attribute::sGmstAttributeIds[mEffectParams.mAttribute], {});
} }
if (mEffectParams.mMagnMin || mEffectParams.mMagnMax) if (mEffectParams.mMagnMin || mEffectParams.mMagnMax)
@ -413,8 +448,7 @@ namespace MWGui::Widgets
ESM::MagicEffect::MagnitudeDisplayType displayType = magicEffect->getMagnitudeDisplayType(); ESM::MagicEffect::MagnitudeDisplayType displayType = magicEffect->getMagnitudeDisplayType();
if (displayType == ESM::MagicEffect::MDT_TimesInt) if (displayType == ESM::MagicEffect::MDT_TimesInt)
{ {
std::string_view timesInt std::string_view timesInt = windowManager->getGameSettingString("sXTimesINT", {});
= MWBase::Environment::get().getWindowManager()->getGameSettingString("sXTimesINT", {});
std::stringstream formatter; std::stringstream formatter;
formatter << std::fixed << std::setprecision(1) << " " << (mEffectParams.mMagnMin / 10.0f); formatter << std::fixed << std::setprecision(1) << " " << (mEffectParams.mMagnMin / 10.0f);
@ -465,7 +499,7 @@ namespace MWGui::Widgets
if (mEffectParams.mDuration > 0 && !(magicEffect->mData.mFlags & ESM::MagicEffect::NoDuration)) if (mEffectParams.mDuration > 0 && !(magicEffect->mData.mFlags & ESM::MagicEffect::NoDuration))
{ {
spellLine += ' '; spellLine += ' ';
spellLine += MWBase::Environment::get().getWindowManager()->getGameSettingString("sfor", {}); spellLine += windowManager->getGameSettingString("sfor", {});
spellLine += ' ' + MyGUI::utility::toString(mEffectParams.mDuration) spellLine += ' ' + MyGUI::utility::toString(mEffectParams.mDuration)
+ ((mEffectParams.mDuration == 1) ? sec : secs); + ((mEffectParams.mDuration == 1) ? sec : secs);
} }
@ -479,15 +513,14 @@ namespace MWGui::Widgets
if (!mEffectParams.mNoTarget) if (!mEffectParams.mNoTarget)
{ {
spellLine += ' '; spellLine += ' ';
spellLine += MWBase::Environment::get().getWindowManager()->getGameSettingString("sonword", {}); spellLine += windowManager->getGameSettingString("sonword", {});
spellLine += ' '; spellLine += ' ';
if (mEffectParams.mRange == ESM::RT_Self) if (mEffectParams.mRange == ESM::RT_Self)
spellLine += MWBase::Environment::get().getWindowManager()->getGameSettingString("sRangeSelf", {}); spellLine += windowManager->getGameSettingString("sRangeSelf", {});
else if (mEffectParams.mRange == ESM::RT_Touch) else if (mEffectParams.mRange == ESM::RT_Touch)
spellLine += MWBase::Environment::get().getWindowManager()->getGameSettingString("sRangeTouch", {}); spellLine += windowManager->getGameSettingString("sRangeTouch", {});
else if (mEffectParams.mRange == ESM::RT_Target) else if (mEffectParams.mRange == ESM::RT_Target)
spellLine spellLine += windowManager->getGameSettingString("sRangeTarget", {});
+= MWBase::Environment::get().getWindowManager()->getGameSettingString("sRangeTarget", {});
} }
} }