mirror of
https://github.com/minetest/irrlicht.git
synced 2024-11-14 11:43:48 +01:00
8310a3fbad
git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/trunk@6000 dfc29bdd-3216-0410-991c-e03cc46cb475
52 lines
1.9 KiB
C++
52 lines
1.9 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 __I_SCENE_USER_DATA_SERIALIZER_H_INCLUDED__
|
|
#define __I_SCENE_USER_DATA_SERIALIZER_H_INCLUDED__
|
|
|
|
#include "IReferenceCounted.h"
|
|
|
|
namespace irr
|
|
{
|
|
namespace io
|
|
{
|
|
class IAttributes;
|
|
} // end namespace io
|
|
namespace scene
|
|
{
|
|
class ISceneNode;
|
|
|
|
//! Interface to read and write user data to and from .irr files.
|
|
/** This interface is to be implemented by the user, to make it possible to read
|
|
and write user data when reading or writing .irr files via ISceneManager.
|
|
To be used with ISceneManager::loadScene() and ISceneManager::saveScene() */
|
|
class ISceneUserDataSerializer
|
|
{
|
|
public:
|
|
|
|
virtual ~ISceneUserDataSerializer() {}
|
|
|
|
//! Called when the scene manager create a scene node while loading a file.
|
|
virtual void OnCreateNode(ISceneNode* node) = 0;
|
|
|
|
//! Called when the scene manager read a scene node while loading a file.
|
|
/** The userData pointer contains a list of attributes with userData which
|
|
were attached to the scene node in the read scene file.*/
|
|
virtual void OnReadUserData(ISceneNode* forSceneNode, io::IAttributes* userData) = 0;
|
|
|
|
//! Called when the scene manager is writing a scene node to an xml file for example.
|
|
/** Implement this method and return a list of attributes containing the user data
|
|
you want to be saved together with the scene node. Return 0 if no user data should
|
|
be added. Please note that the scene manager will call drop() to the returned pointer
|
|
after it no longer needs it, so if you didn't create a new object for the return value
|
|
and returning a longer existing IAttributes object, simply call grab() before returning it. */
|
|
virtual io::IAttributes* createUserData(ISceneNode* forSceneNode) = 0;
|
|
};
|
|
|
|
} // end namespace scene
|
|
} // end namespace irr
|
|
|
|
#endif
|
|
|