irrlicht/source/Irrlicht/CMeshCache.cpp

233 lines
4.4 KiB
C++
Raw Normal View History

// Copyright (C) 2002-2007 Nikolaus Gebhardt
// This file is part of the "Irrlicht Engine".
// For conditions of distribution and use, see copyright notice in irrlicht.h
#include "CMeshCache.h"
#include "IAnimatedMesh.h"
#include "IMesh.h"
namespace irr
{
namespace scene
{
CMeshCache::~CMeshCache()
{
clear();
}
//! adds a mesh to the list
void CMeshCache::addMesh(const c8* filename, IAnimatedMesh* mesh)
{
mesh->grab();
MeshEntry e;
e.Mesh = mesh;
e.Name = filename;
e.Name.make_lower();
Meshes.push_back(e);
}
//! Returns amount of loaded meshes
s32 CMeshCache::getMeshCount()
{
return Meshes.size();
}
//! Returns a mesh based on its index number
IAnimatedMesh* CMeshCache::getMeshByIndex(s32 number)
{
if (number < 0 || number >= (s32)Meshes.size())
return 0;
return Meshes[number].Mesh;
}
//! Returns current number of the mesh
s32 CMeshCache::getMeshIndex(IAnimatedMesh* mesh)
{
for (int i=0; i<(int)Meshes.size(); ++i)
if (Meshes[i].Mesh == mesh)
return i;
return -1;
}
//! Returns current index number of the mesh, and -1 if it is not in the cache.
s32 CMeshCache::getMeshIndex(IMesh* mesh)
{
for (s32 i=0; i<(s32)Meshes.size(); ++i)
{
if (Meshes[i].Mesh && Meshes[i].Mesh->getMesh(0) == mesh)
return i;
}
return -1;
}
//! Returns name of a mesh based on its index number
const c8* CMeshCache::getMeshFilename(s32 number)
{
if (number < 0 || number >= (s32)Meshes.size())
return 0;
return Meshes[number].Name.c_str();
}
//! Returns the filename of a loaded mesh, if there is any. Returns 0 if there is none.
const c8* CMeshCache::getMeshFilename(IAnimatedMesh* mesh)
{
for (s32 i=0; i<(s32)Meshes.size(); ++i)
{
if (Meshes[i].Mesh == mesh)
return Meshes[i].Name.c_str();
}
return 0;
}
//! Returns the filename of a loaded mesh, if there is any. Returns 0 if there is none.
const c8* CMeshCache::getMeshFilename(IMesh* mesh)
{
for (s32 i=0; i<(s32)Meshes.size(); ++i)
{
if (Meshes[i].Mesh && Meshes[i].Mesh->getMesh(0) == mesh)
return Meshes[i].Name.c_str();
}
return 0;
}
//! returns if a mesh already was loaded
bool CMeshCache::isMeshLoaded(const c8* filename)
{
core::stringc name = filename;
name.make_lower();
return findMesh(name.c_str()) != 0;
}
//! returns an already loaded mesh
IAnimatedMesh* CMeshCache::findMesh(const c8* lowerMadeFilename)
{
MeshEntry e;
e.Name = lowerMadeFilename;
s32 id = Meshes.binary_search(e);
return (id != -1) ? Meshes[id].Mesh : 0;
}
//! Removes a mesh from the cache.
void CMeshCache::removeMesh(IAnimatedMesh* mesh)
{
if ( mesh )
for (int i=0; i<(int)Meshes.size(); ++i)
{
if (Meshes[i].Mesh == mesh)
{
Meshes[i].Mesh->drop();
Meshes.erase(i);
return;
}
}
}
//! Removes a mesh from the cache.
void CMeshCache::removeMesh(IMesh* mesh)
{
if ( mesh )
for (int i=0; i<(int)Meshes.size(); ++i)
{
if (Meshes[i].Mesh && Meshes[i].Mesh->getMesh(0) == mesh)
{
Meshes[i].Mesh->drop();
Meshes.erase(i);
return;
}
}
}
//! Renames a loaded mesh, if possible.
bool CMeshCache::setMeshFilename(s32 index, const c8* filename)
{
if (index < 0 || index >= (s32)Meshes.size())
return false;
Meshes[index].Name = filename;
Meshes.sort();
return true;
}
//! Renames a loaded mesh, if possible.
bool CMeshCache::setMeshFilename(IAnimatedMesh* mesh, const c8* filename)
{
for (s32 i=0; i<(s32)Meshes.size(); ++i)
{
if (Meshes[i].Mesh == mesh)
{
Meshes[i].Name = filename;
Meshes.sort();
return true;
}
}
return false;
}
//! Renames a loaded mesh, if possible.
bool CMeshCache::setMeshFilename(IMesh* mesh, const c8* filename)
{
for (s32 i=0; i<(s32)Meshes.size(); ++i)
{
if (Meshes[i].Mesh && Meshes[i].Mesh->getMesh(0) == mesh)
{
Meshes[i].Name = filename;
Meshes.sort();
return true;
}
}
return false;
}
//! Clears the whole mesh cache, removing all meshes.
void CMeshCache::clear()
{
for (u32 i=0; i<Meshes.size(); ++i)
Meshes[i].Mesh->drop();
Meshes.clear();
}
//! Returns a mesh based on its file name.
IAnimatedMesh* CMeshCache::getMeshByFilename(const c8* filename)
{
core::stringc str = filename;
str.make_lower();
return findMesh(str.c_str());
}
} // end namespace scene
} // end namespace irr