forked from Mirrorlandia_minetest/irrlicht
c58afe8038
- IMeshLoader::setPreferredIndexType and getPreferredIndexType allow setting hints for the loaders if users prefer 16 or 32 bit meshbuffers. Loaders are free to ignore those hints (all but .obj will do that for now). - obj meshloader loads now 32-bit buffers when setPreferredIndexType is set to EIT_32BIT. NOTE: It's 16 bit meshes use now also an IDynamicMeshbuffer instead of an SMeshBuffer. That will break the code of people who accessed meshbuffer before by casting to SMeshBuffer* And might even be somewhat slower (lot's of virtual functions...), but shouldn't really matter and can maybe be a bit improved. Sorry about that, I considered keeping SMeshBuffer for 16-bit (still considering it), but it would add some overhead in code and I don't think it's worth that. If there are any complains I'll maybe consider it again. git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/trunk@6333 dfc29bdd-3216-0410-991c-e03cc46cb475
113 lines
3.5 KiB
C++
113 lines
3.5 KiB
C++
// Copyright (C) 2002-2012 Nikolaus Gebhardt
|
|
// This file is part of the "Irrlicht Engine".
|
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
|
|
|
#ifndef IRR_I_MESH_LOADER_H_INCLUDED
|
|
#define IRR_I_MESH_LOADER_H_INCLUDED
|
|
|
|
#include "IReferenceCounted.h"
|
|
#include "path.h"
|
|
#include "IMeshTextureLoader.h"
|
|
#include "SVertexIndex.h"
|
|
|
|
namespace irr
|
|
{
|
|
namespace io
|
|
{
|
|
class IReadFile;
|
|
} // end namespace io
|
|
namespace scene
|
|
{
|
|
class IAnimatedMesh;
|
|
|
|
//! Class which is able to load an animated mesh from a file.
|
|
/** If you want Irrlicht be able to load meshes of
|
|
currently unsupported file formats (e.g. .cob), then implement
|
|
this and add your new Meshloader with
|
|
ISceneManager::addExternalMeshLoader() to the engine. */
|
|
class IMeshLoader : public virtual IReferenceCounted
|
|
{
|
|
public:
|
|
|
|
//! Constructor
|
|
IMeshLoader() : TextureLoader(0), PreferredIndexType(video::EIT_16BIT) {}
|
|
|
|
//! Destructor
|
|
virtual ~IMeshLoader()
|
|
{
|
|
if ( TextureLoader )
|
|
TextureLoader->drop();
|
|
}
|
|
|
|
//! Returns true if the file might be loaded by this class.
|
|
/** This decision should be based on the file extension (e.g. ".cob")
|
|
only.
|
|
\param filename Name of the file to test.
|
|
\return True if the file might be loaded by this class. */
|
|
virtual bool isALoadableFileExtension(const io::path& filename) const = 0;
|
|
|
|
//! Creates/loads an animated mesh from the file.
|
|
/** \param file File handler to load the file from.
|
|
\return Pointer to the created mesh. Returns 0 if loading failed.
|
|
If you no longer need the mesh, you should call IAnimatedMesh::drop().
|
|
See IReferenceCounted::drop() for more information. */
|
|
virtual IAnimatedMesh* createMesh(io::IReadFile* file) = 0;
|
|
|
|
//! Set a new texture loader which this meshloader can use when searching for textures.
|
|
/** NOTE: Not all meshloaders do support this interface. Meshloaders which
|
|
support it will return a non-null value in getMeshTextureLoader from the start. Setting a
|
|
texture-loader to a meshloader which doesn't support it won't help.
|
|
\param textureLoader The textureloader to use. When set to NULL the mesh will not load any textures.
|
|
*/
|
|
virtual void setMeshTextureLoader(IMeshTextureLoader* textureLoader)
|
|
{
|
|
if ( textureLoader != TextureLoader )
|
|
{
|
|
if ( textureLoader )
|
|
textureLoader->grab();
|
|
if ( TextureLoader )
|
|
TextureLoader->drop();
|
|
TextureLoader = textureLoader;
|
|
}
|
|
}
|
|
|
|
//! Get the texture loader used when this meshloader searches for textures.
|
|
/** NOTE: not all meshloaders support this interface so this can return NULL.
|
|
*/
|
|
virtual IMeshTextureLoader* getMeshTextureLoader() const
|
|
{
|
|
return TextureLoader;
|
|
}
|
|
|
|
//! Give loader a hint if you would prefer 16 or 32 bit meshbuffers.
|
|
/**
|
|
Generally Irrlicht works with 16-bit meshbuffers so far.
|
|
Rendering 32-bit meshbuffers works, other functions like
|
|
mesh-writing and mesh manipulation might not work yet.
|
|
NOTE: Most loaders will ignore this hint so far, but hopefully
|
|
will care about it in the future.
|
|
*/
|
|
void setPreferredIndexType(irr::video::E_INDEX_TYPE typeHint)
|
|
{
|
|
PreferredIndexType = typeHint;
|
|
}
|
|
|
|
//! Return current preference user has for the index-size of meshbuffers
|
|
/** Note that this is _not_ necessarily the type used by the meshloader */
|
|
irr::video::E_INDEX_TYPE getPreferredIndexType() const
|
|
{
|
|
return PreferredIndexType;
|
|
}
|
|
|
|
|
|
protected:
|
|
IMeshTextureLoader* TextureLoader;
|
|
irr::video::E_INDEX_TYPE PreferredIndexType;
|
|
};
|
|
|
|
|
|
} // end namespace scene
|
|
} // end namespace irr
|
|
|
|
#endif
|