| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 | //-----------------------------------------------------------------------------// Copyright (c) 2012 GarageGames, LLC//// Permission is hereby granted, free of charge, to any person obtaining a copy// of this software and associated documentation files (the "Software"), to// deal in the Software without restriction, including without limitation the// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or// sell copies of the Software, and to permit persons to whom the Software is// furnished to do so, subject to the following conditions://// The above copyright notice and this permission notice shall be included in// all copies or substantial portions of the Software.//// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS// IN THE SOFTWARE.//-----------------------------------------------------------------------------#include "platform/platform.h"#include "gui/worldEditor/editorIconRegistry.h"#include "console/engineAPI.h"#include "console/simBase.h"#include "gui/core/guiTypes.h"EditorIconRegistry gEditorIcons;ConsoleDoc(   "@class EditorIconRegistry\n"   "@brief This class is used to find the correct icon file path for different SimObject class types.\n\n"   "It is typically used by the editors, not intended for actual game development\n\n"   "@internal");IMPLEMENT_STATIC_CLASS(EditorIconRegistry,, "");EditorIconRegistry::EditorIconRegistry(){}EditorIconRegistry::~EditorIconRegistry(){   clear();}void EditorIconRegistry::loadFromPath( const String &path, bool overwrite ){   AbstractClassRep *classRep = AbstractClassRep::getClassList();   while ( classRep )   {      String iconFile = String::ToString( "%s%s", path.c_str(), classRep->getClassName() );      add( classRep->getClassName(), iconFile.c_str(), overwrite );      classRep = classRep->getNextClass();   }   String defaultIconFile = path + "default";   mDefaultIcon.set( defaultIconFile,                     &GFXDefaultGUIProfile,                     avar("%s() - mIcons[] (line %d)",                      __FUNCTION__, __LINE__) );}void EditorIconRegistry::add( const String &className, const String &imageFile, bool overwrite ){   // First see if we can load the image.   GFXTexHandle icon(   imageFile, &GFXDefaultGUIProfile,                        avar("%s() - mIcons[] (line %d)", __FUNCTION__, __LINE__) );   if ( icon.isNull() )      return;   // Look it up in the map.   StringNoCase key( className );   IconMap::Iterator iter = mIcons.find( key );   if ( iter != mIcons.end() )   {      if ( !overwrite )         return;      iter->value = icon;   }   else      mIcons.insertUnique( key, icon );}GFXTexHandle EditorIconRegistry::findIcon( AbstractClassRep *classRep ){   while ( classRep )   {      StringNoCase key( classRep->getClassName() );      IconMap::Iterator icon = mIcons.find( key );      if ( icon != mIcons.end() && icon->value.isValid() )         return icon->value;      classRep = classRep->getParentClass();   }   return mDefaultIcon;}GFXTexHandle EditorIconRegistry::findIcon( const SimObject *object ){	if( object == NULL )		return mDefaultIcon;   AbstractClassRep *classRep = object->getClassRep();   return findIcon( classRep );}   GFXTexHandle EditorIconRegistry::findIcon( const char *className ){      // On the chance we have this className already in the map,   // check there first because its a lot faster...      StringNoCase key( className );   IconMap::Iterator icon = mIcons.find( key );   if ( icon != mIcons.end() && icon->value.isValid() )      return icon->value;   // Well, we could still have an icon for a parent class,   // so find the AbstractClassRep for the className.   //   // Unfortunately the only way to do this is looping through   // the AbstractClassRep linked list.   bool found = false;   AbstractClassRep* pClassRep = AbstractClassRep::getClassList();      while ( pClassRep )   {      if ( key.equal( pClassRep->getClassName(), String::NoCase ) )      {         found = true;         break;      }      pClassRep = pClassRep->getNextClass();   }   if ( !found )   {      Con::errorf( "EditorIconRegistry::findIcon, passed className %s was not an AbstractClassRep!", key.c_str() );      return mDefaultIcon;   }      // Now do a find by AbstractClassRep recursively up the class tree...   return findIcon( pClassRep );}bool EditorIconRegistry::hasIconNoRecurse( const SimObject *object ){   AbstractClassRep *classRep = object->getClassRep();         StringNoCase key( classRep->getClassName() );   IconMap::Iterator icon = mIcons.find( key );   return icon != mIcons.end();}void EditorIconRegistry::clear(){   mIcons.clear();   mDefaultIcon.free();}DefineEngineStaticMethod( EditorIconRegistry, add, void, (String className, String imageFile, bool overwrite), (true),					"@internal"){   gEditorIcons.add( className, imageFile, overwrite );}DefineEngineStaticMethod( EditorIconRegistry, loadFromPath, void, (String imagePath, bool overwrite), (true),					"@internal"){   gEditorIcons.loadFromPath( imagePath, overwrite );}DefineEngineStaticMethod( EditorIconRegistry, clear, void, (),,					"@internal"){   gEditorIcons.clear();}DefineEngineStaticMethod( EditorIconRegistry, findIconByClassName, const char*, (String className),,   "@brief Returns the file path to the icon file if found."    "@internal"){   GFXTexHandle icon = gEditorIcons.findIcon( className );   if ( icon.isNull() )      return NULL;   return icon->mPath;}DefineEngineStaticMethod( EditorIconRegistry, findIconBySimObject, const char*, (SimObject* obj),,   "Returns the file path to the icon file if found."    "@internal"){   if ( !obj )   {      Con::warnf( "EditorIconRegistry::findIcon, parameter was not a SimObject!");      return NULL;   }   GFXTexHandle icon = gEditorIcons.findIcon( obj );   if ( icon.isNull() )      return NULL;   return icon->mPath;}
 |