mirror of
https://github.com/OpenMW/openmw.git
synced 2025-02-06 08:15:34 +00:00
Handle non-string RefIds when displaying a class image
This commit is contained in:
parent
25c1e6abee
commit
6e39c0336c
1 changed files with 13 additions and 6 deletions
|
@ -889,14 +889,21 @@ namespace MWGui
|
|||
|
||||
void setClassImage(MyGUI::ImageBox* imageBox, const ESM::RefId& classId)
|
||||
{
|
||||
const VFS::Manager* const vfs = MWBase::Environment::get().getResourceSystem()->getVFS();
|
||||
std::string classImage
|
||||
= Misc::ResourceHelpers::correctTexturePath("textures\\levelup\\" + classId.getRefIdString() + ".dds", vfs);
|
||||
if (!vfs->exists(classImage))
|
||||
std::string_view fallback = "textures\\levelup\\warrior.dds";
|
||||
std::string classImage;
|
||||
if (const auto* id = classId.getIf<ESM::StringRefId>())
|
||||
{
|
||||
Log(Debug::Warning) << "No class image for " << classId << ", falling back to default";
|
||||
classImage = "textures\\levelup\\warrior.dds";
|
||||
const VFS::Manager* const vfs = MWBase::Environment::get().getResourceSystem()->getVFS();
|
||||
classImage
|
||||
= Misc::ResourceHelpers::correctTexturePath("textures\\levelup\\" + id->getValue() + ".dds", vfs);
|
||||
if (!vfs->exists(classImage))
|
||||
{
|
||||
Log(Debug::Warning) << "No class image for " << classId << ", falling back to default";
|
||||
classImage = fallback;
|
||||
}
|
||||
}
|
||||
else
|
||||
classImage = fallback;
|
||||
imageBox->setImageTexture(classImage);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue