|
Shinya Kitaoka |
810553 |
#pragma once
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#ifndef TRENDERRESOURCEMANAGER_INCLUDED
|
|
Toshihiro Shimizu |
890ddd |
#define TRENDERRESOURCEMANAGER_INCLUDED
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include "trasterfx.h"
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#undef DVAPI
|
|
Toshihiro Shimizu |
890ddd |
#undef DVVAR
|
|
Toshihiro Shimizu |
890ddd |
#ifdef TFX_EXPORTS
|
|
Toshihiro Shimizu |
890ddd |
#define DVAPI DV_EXPORT_API
|
|
Toshihiro Shimizu |
890ddd |
#define DVVAR DV_EXPORT_VAR
|
|
Toshihiro Shimizu |
890ddd |
#else
|
|
Toshihiro Shimizu |
890ddd |
#define DVAPI DV_IMPORT_API
|
|
Toshihiro Shimizu |
890ddd |
#define DVVAR DV_IMPORT_VAR
|
|
Toshihiro Shimizu |
890ddd |
#endif
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//===============================================================================
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
class TRenderer;
|
|
Toshihiro Shimizu |
890ddd |
class TRenderResourceManager;
|
|
Toshihiro Shimizu |
890ddd |
class TRenderResourceManagerGenerator;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//===============================================================================
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//=================================
|
|
Toshihiro Shimizu |
890ddd |
// Render Resource Managers
|
|
Toshihiro Shimizu |
890ddd |
//---------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/*!
|
|
Toshihiro Shimizu |
890ddd |
The TRenderResourceManager is a base class used to develop resource
|
|
Toshihiro Shimizu |
890ddd |
handlers for Toonz rendering contexts.
|
|
Toshihiro Shimizu |
890ddd |
\a Resources are hereby intended as data which possess special scope and
|
|
Toshihiro Shimizu |
890ddd |
duration with respect to one or more rendering processes. A most notable
|
|
Toshihiro Shimizu |
890ddd |
example of this is the internal Fxs cache, which is specialized to
|
|
Toshihiro Shimizu |
890ddd |
maintain a group of intermediate rendered tiles which may be shared in input
|
|
Toshihiro Shimizu |
890ddd |
by multiple fxs.
|
|
Toshihiro Shimizu |
890ddd |
\n \n
|
|
Toshihiro Shimizu |
890ddd |
Creation of a resource manager requires the implementation of both the
|
|
Toshihiro Shimizu |
890ddd |
manager itself, and that of a TRenderResourceManagerGenerator class which
|
|
Toshihiro Shimizu |
890ddd |
is used internally to allocate manager instances at the most appropriate times.
|
|
Toshihiro Shimizu |
890ddd |
The manager's generator needs to be instanced at file scope <\b> to
|
|
Toshihiro Shimizu |
890ddd |
be correctly registered by Toonz.
|
|
Toshihiro Shimizu |
890ddd |
\n \n
|
|
Toshihiro Shimizu |
890ddd |
Observe that the default scope of a resource manager is limited to a TRenderer
|
|
Toshihiro Shimizu |
890ddd |
instance; specifically meaning that the swatch viewer, preview fx command,
|
|
Toshihiro Shimizu |
890ddd |
camstand preview and render/preview commands build different managers.
|
|
Toshihiro Shimizu |
890ddd |
*/
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
class TRenderResourceManager {
|
|
Toshihiro Shimizu |
890ddd |
public:
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManager() {}
|
|
Shinya Kitaoka |
120a6e |
virtual ~TRenderResourceManager() {}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
virtual void onRenderInstanceStart(unsigned long id) {}
|
|
Shinya Kitaoka |
120a6e |
virtual void onRenderInstanceEnd(unsigned long id) {}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
virtual void onRenderFrameStart(double f) {}
|
|
Shinya Kitaoka |
120a6e |
virtual void onRenderFrameEnd(double f) {}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
virtual void onRenderStatusStart(int renderStatus) {}
|
|
Shinya Kitaoka |
120a6e |
virtual void onRenderStatusEnd(int renderStatus) {}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
virtual bool renderHasOwnership() { return true; }
|
|
Toshihiro Shimizu |
890ddd |
};
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//===============================================================================
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//===========================================
|
|
Toshihiro Shimizu |
890ddd |
// Render Resource Manager Generators
|
|
Toshihiro Shimizu |
890ddd |
//-------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/*!
|
|
Toshihiro Shimizu |
890ddd |
The TRenderResourceManagerGenerator class is used to construct resource managers
|
|
Toshihiro Shimizu |
890ddd |
that will be used by TRenderers.
|
|
Toshihiro Shimizu |
890ddd |
Please refer to the TRenderResourceManager documentation for the details.
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
\note Resource managers may be constructed with a render instance <\i> scope
|
|
Shinya Kitaoka |
120a6e |
rather
|
|
Shinya Kitaoka |
120a6e |
than the default render context (ie TRenderer) scope. This can be achieved by
|
|
Shinya Kitaoka |
120a6e |
passing
|
|
Toshihiro Shimizu |
890ddd |
\c true at the generator's constructor, proving especially useful considering
|
|
Shinya Kitaoka |
120a6e |
that the same TRenderer may virtually start multiple render instances at the
|
|
Shinya Kitaoka |
120a6e |
same time.
|
|
Toshihiro Shimizu |
890ddd |
*/
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
class DVAPI TRenderResourceManagerGenerator {
|
|
Shinya Kitaoka |
120a6e |
int m_managerIndex;
|
|
Shinya Kitaoka |
120a6e |
bool m_instanceScope;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
public:
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManagerGenerator(bool renderInstanceScope = false);
|
|
Shinya Kitaoka |
120a6e |
~TRenderResourceManagerGenerator() {}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
int getGeneratorIndex() const { return m_managerIndex; }
|
|
Shinya Kitaoka |
120a6e |
static std::vector<trenderresourcemanagergenerator *=""> &generators();</trenderresourcemanagergenerator>
|
|
Shinya Kitaoka |
120a6e |
static std::vector<trenderresourcemanagergenerator *=""> &generators(</trenderresourcemanagergenerator>
|
|
Shinya Kitaoka |
120a6e |
bool instanceScope);
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
virtual TRenderResourceManager *operator()(void) = 0;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
bool hasInstanceScope() const { return m_instanceScope; }
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManager *getManager(const TRenderer &renderer) const;
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManager *getManager(unsigned long renderId) const;
|
|
Toshihiro Shimizu |
890ddd |
};
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//===============================================================================
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//===========================
|
|
Toshihiro Shimizu |
890ddd |
// Declaration macros
|
|
Toshihiro Shimizu |
890ddd |
//---------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/*! \def MANAGER_DECLARATION(managerClass)
|
|
Toshihiro Shimizu |
890ddd |
Declares a TRenderResourceManager class, it must be used inside the manager
|
|
Toshihiro Shimizu |
890ddd |
definition.
|
|
Toshihiro Shimizu |
890ddd |
For example:
|
|
Toshihiro Shimizu |
890ddd |
\code
|
|
Toshihiro Shimizu |
890ddd |
class MyManager : public TRenderResourceManager
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
T_RENDER_RESOURCE_MANAGER
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
...
|
|
Toshihiro Shimizu |
890ddd |
};
|
|
Toshihiro Shimizu |
890ddd |
\endcode
|
|
Toshihiro Shimizu |
890ddd |
In particular, this macro is used to decorate the manager definition with the
|
|
Toshihiro Shimizu |
890ddd |
static method \c gen(), which can be used to access the manager's generator.
|
|
Toshihiro Shimizu |
890ddd |
The method declaration is:
|
|
Toshihiro Shimizu |
890ddd |
\code
|
|
Toshihiro Shimizu |
890ddd |
static TRenderResourceManagerGenerator* gen();
|
|
Toshihiro Shimizu |
890ddd |
\endcode
|
|
Toshihiro Shimizu |
890ddd |
*/
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
#define T_RENDER_RESOURCE_MANAGER \
|
|
Shinya Kitaoka |
120a6e |
\
|
|
Shinya Kitaoka |
120a6e |
public: \
|
|
Shinya Kitaoka |
120a6e |
static TRenderResourceManagerGenerator *gen(); \
|
|
Shinya Kitaoka |
120a6e |
static TRenderResourceManagerGenerator *deps(); \
|
|
Shinya Kitaoka |
120a6e |
\
|
|
Toshihiro Shimizu |
890ddd |
private:
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//--------------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/*! \def MANAGER_FILESCOPE_DECLARATION(managerClass, generatorClass)
|
|
Toshihiro Shimizu |
890ddd |
This macro must be used at file scope to bind the manager to its generator
|
|
Toshihiro Shimizu |
890ddd |
instance - just place it after the generator definition.
|
|
Toshihiro Shimizu |
890ddd |
\note In case the manager is dependant on some other manager, use the
|
|
Toshihiro Shimizu |
890ddd |
\c MANAGER_FILESCOPE_DECLARATION_DEP macro instead.
|
|
Toshihiro Shimizu |
890ddd |
*/
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
#define MANAGER_FILESCOPE_DECLARATION(managerClass, generatorClass) \
|
|
Shinya Kitaoka |
120a6e |
\
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManagerGenerator *managerClass::gen() { \
|
|
Shinya Kitaoka |
120a6e |
static generatorClass theInstance; \
|
|
Shinya Kitaoka |
120a6e |
return &theInstance; \
|
|
Shinya Kitaoka |
120a6e |
} \
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManagerGenerator *managerClass::deps() { \
|
|
Shinya Kitaoka |
120a6e |
return managerClass::gen(); \
|
|
Shinya Kitaoka |
120a6e |
} \
|
|
Shinya Kitaoka |
120a6e |
\
|
|
Shinya Kitaoka |
120a6e |
namespace { \
|
|
Shinya Kitaoka |
120a6e |
generatorClass *generatorClass##Instance = \
|
|
Shinya Kitaoka |
120a6e |
(generatorClass *)managerClass::deps(); \
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//--------------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
/*! \def MANAGER_FILESCOPE_DECLARATION_DEP(managerClass, generatorClass,
|
|
Shinya Kitaoka |
120a6e |
depsList)
|
|
Shinya Kitaoka |
120a6e |
A variation of the MANAGER_FILESCOPE_DECLARATION macro used to declare
|
|
Shinya Kitaoka |
120a6e |
dependencies between
|
|
Shinya Kitaoka |
120a6e |
resource managers. A manager always receives start notifications \a after those
|
|
Shinya Kitaoka |
120a6e |
from which
|
|
Shinya Kitaoka |
120a6e |
it depends, and viceversa for end notifications. The same applies for
|
|
Shinya Kitaoka |
120a6e |
constructors and destructors.
|
|
Toshihiro Shimizu |
890ddd |
\n \n
|
|
Shinya Kitaoka |
120a6e |
The dependencies declarations list is a sequence of static \c
|
|
Shinya Kitaoka |
120a6e |
<dependencyresourcemanager>::deps()</dependencyresourcemanager>
|
|
Toshihiro Shimizu |
890ddd |
calls separated by a comma.
|
|
Toshihiro Shimizu |
890ddd |
Here is an example:
|
|
Toshihiro Shimizu |
890ddd |
\code
|
|
Toshihiro Shimizu |
890ddd |
MANAGER_FILESCOPE_DECLARATION_DEP(
|
|
Shinya Kitaoka |
120a6e |
MyResourceManager,
|
|
Toshihiro Shimizu |
890ddd |
MyResourceManagerGenerator,
|
|
Toshihiro Shimizu |
890ddd |
TPredictiveCacheManager::deps(); TOfflineGLManager::deps(); \\etc...
|
|
Toshihiro Shimizu |
890ddd |
)
|
|
Toshihiro Shimizu |
890ddd |
\endcode
|
|
Toshihiro Shimizu |
890ddd |
*/
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
#define MANAGER_FILESCOPE_DECLARATION_DEP(managerClass, generatorClass, \
|
|
Shinya Kitaoka |
120a6e |
depsList) \
|
|
Shinya Kitaoka |
120a6e |
\
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManagerGenerator *managerClass::gen() { \
|
|
Shinya Kitaoka |
120a6e |
static generatorClass theInstance; \
|
|
Shinya Kitaoka |
120a6e |
return &theInstance; \
|
|
Shinya Kitaoka |
120a6e |
} \
|
|
Shinya Kitaoka |
120a6e |
TRenderResourceManagerGenerator *managerClass::deps() { \
|
|
Shinya Kitaoka |
120a6e |
depsList; \
|
|
Shinya Kitaoka |
120a6e |
return managerClass::gen(); \
|
|
Shinya Kitaoka |
120a6e |
} \
|
|
Shinya Kitaoka |
120a6e |
\
|
|
Shinya Kitaoka |
120a6e |
namespace { \
|
|
Shinya Kitaoka |
120a6e |
generatorClass *generatorClass##Instance = \
|
|
Shinya Kitaoka |
120a6e |
(generatorClass *)managerClass::deps(); \
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//===============================================================================
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
#endif // TRENDERRESOURCEMANAGER_INCLUDED
|