Changed: Look into predefined pathes for Ryzom icons

This commit is contained in:
kervala 2015-11-29 14:43:08 +01:00
parent 0ad9f15831
commit cbe7528130

View file

@ -1060,26 +1060,42 @@ void prelogInit()
#if defined(NL_OS_UNIX) && !defined(NL_OS_MAC) #if defined(NL_OS_UNIX) && !defined(NL_OS_MAC)
// add all existing icons // add all existing icons
vector<string> filenames; vector<string> directories;
filenames.push_back("/usr/share/icons/hicolor/128x128/apps/ryzom.png");
filenames.push_back("/usr/share/icons/hicolor/48x48/apps/ryzom.png"); // system directories
filenames.push_back("/usr/share/icons/hicolor/32x32/apps/ryzom.png"); directories.push_back("/usr/share/icons/hicolor/256x256/apps");
filenames.push_back("/usr/share/icons/hicolor/24x24/apps/ryzom.png"); directories.push_back("/usr/share/icons/hicolor/128x128/apps");
filenames.push_back("/usr/share/icons/hicolor/22x22/apps/ryzom.png"); directories.push_back("/usr/share/icons/hicolor/96x96/apps");
filenames.push_back("/usr/share/icons/hicolor/16x16/apps/ryzom.png"); directories.push_back("/usr/share/icons/hicolor/48x48/apps");
filenames.push_back("/usr/share/pixmaps/ryzom.png"); directories.push_back("/usr/share/icons/hicolor/32x32/apps");
directories.push_back("/usr/share/icons/hicolor/24x24/apps");
directories.push_back("/usr/share/icons/hicolor/22x22/apps");
directories.push_back("/usr/share/icons/hicolor/16x16/apps");
directories.push_back("/usr/share/pixmaps");
// local directories
directories.push_back("~/.local/share/icons/hicolor/256x256/apps");
directories.push_back("~/.local/share/icons/hicolor/128x128/apps");
directories.push_back("~/.local/share/icons/hicolor/96x96/apps");
directories.push_back("~/.local/share/icons/hicolor/48x48/apps");
directories.push_back("~/.local/share/icons/hicolor/32x32/apps");
directories.push_back("~/.local/share/icons/hicolor/24x24/apps");
directories.push_back("~/.local/share/icons/hicolor/22x22/apps");
directories.push_back("~/.local/share/icons/hicolor/16x16/apps");
directories.push_back("~/.local/share/pixmaps");
// check if an icon is present in registered paths // check if an icon is present in registered paths
if(CPath::exists("ryzom.png")) directories.push_back(".");
filenames.push_back(CPath::lookup("ryzom.png"));
vector<CBitmap> bitmaps; vector<CBitmap> bitmaps;
for(size_t i = 0; i < filenames.size(); ++i) for(size_t i = 0; i < directories.size(); ++i)
{ {
std::string filename = NLMISC::toString("%s/%s.png", directories[i].c_str(), RYZOM_CLIENT_ICON);
CIFile file; CIFile file;
if (CFile::fileExists(filenames[i]) && file.open(filenames[i])) if (CFile::fileExists(filename) && file.open(filename))
{ {
CBitmap bitmap; CBitmap bitmap;
if (bitmap.load(file)) if (bitmap.load(file))
@ -1184,7 +1200,7 @@ void prelogInit()
// resetTextContext ("bremenb.ttf", false); // resetTextContext ("bremenb.ttf", false);
resetTextContext ("ryzom.ttf", false); resetTextContext ("ryzom.ttf", false);
CInterfaceManager::getInstance(); CInterfaceManager::getInstance();
// Yoyo: initialize NOW the InputHandler for Event filtering. // Yoyo: initialize NOW the InputHandler for Event filtering.
@ -1233,7 +1249,7 @@ void prelogInit()
// init bloom effect // init bloom effect
CBloomEffect::getInstance().init(); CBloomEffect::getInstance().init();
if (StereoDisplay) // VR_CONFIG if (StereoDisplay) // VR_CONFIG
{ {
// Init stereo display resources // Init stereo display resources