OpenSceneGraph
3.5.1
|
This is the base class for effect techniques. More...
Public Member Functions | |
Technique () | |
virtual const char * | techniqueName () |
get the name of this Technique More... | |
virtual const char * | techniqueDescription () |
get a brief description of this Technique More... | |
virtual void | getRequiredExtensions (std::vector< std::string > &) const |
collect the GL extension strings which are required for this technique to work properly. More... | |
virtual bool | validate (osg::State &) const |
tests whether this technique is valid for the current rendering context. More... | |
int | getNumPasses () const |
get the number of rendering passes defined in this Technique More... | |
osg::StateSet * | getPassStateSet (int i) |
get the StateSet object associated to the i-th pass More... | |
const osg::StateSet * | getPassStateSet (int i) const |
get the const StateSet object associated to the i-th pass More... | |
virtual void | traverse (osg::NodeVisitor &nv, Effect *fx) |
traverse children with multipass if necessary. More... | |
Public Member Functions inherited from osg::Referenced | |
Referenced () | |
Referenced (bool threadSafeRefUnref) | |
Referenced (const Referenced &) | |
Referenced & | operator= (const Referenced &) |
virtual void | setThreadSafeRefUnref (bool threadSafe) |
Set whether to use a mutex to ensure ref() and unref() are thread safe. More... | |
bool | getThreadSafeRefUnref () const |
Get whether a mutex is used to ensure ref() and unref() are thread safe. More... | |
OpenThreads::Mutex * | getRefMutex () const |
Get the mutex used to ensure thread safety of ref()/unref(). More... | |
int | ref () const |
Increment the reference count by one, indicating that this object has another pointer which is referencing it. More... | |
int | unref () const |
Decrement the reference count by one, indicating that a pointer to this object is no longer referencing it. More... | |
int | unref_nodelete () const |
Decrement the reference count by one, indicating that a pointer to this object is no longer referencing it. More... | |
int | referenceCount () const |
Return the number of pointers currently referencing this object. More... | |
ObserverSet * | getObserverSet () const |
Get the ObserverSet if one is attached, otherwise return NULL. More... | |
ObserverSet * | getOrCreateObserverSet () const |
Get the ObserverSet if one is attached, otherwise create an ObserverSet, attach it, then return this newly created ObserverSet. More... | |
void | addObserver (Observer *observer) const |
Add a Observer that is observing this object, notify the Observer when this object gets deleted. More... | |
void | removeObserver (Observer *observer) const |
Remove Observer that is observing this object. More... | |
Protected Member Functions | |
Technique (const Technique &) | |
virtual | ~Technique () |
Technique & | operator= (const Technique &) |
void | dirtyPasses () |
force rebuilding of pass nodes on next traversal More... | |
void | addPass (osg::StateSet *ss=0) |
create a new pass node, add it to the technique and associate a StateSet More... | |
virtual osg::Node * | getOverrideChild (int) |
optional: return a node that overrides the child node on a specified pass More... | |
virtual void | define_passes ()=0 |
define the rendering passes that make up this technique. More... | |
void | traverse_implementation (osg::NodeVisitor &nv, Effect *fx) |
traverse children with multipass if necessary. More... | |
Protected Member Functions inherited from osg::Referenced | |
virtual | ~Referenced () |
void | signalObserversAndDelete (bool signalDelete, bool doDelete) const |
void | deleteUsingDeleteHandler () const |
Additional Inherited Members | |
Static Public Member Functions inherited from osg::Referenced | |
static OpenThreads::Mutex * | getGlobalReferencedMutex () |
Get the optional global Referenced mutex, this can be shared between all osg::Referenced. More... | |
static void | setThreadSafeReferenceCounting (bool enableThreadSafeReferenceCounting) |
Set whether reference counting should use a mutex for thread safe reference counting. More... | |
static bool | getThreadSafeReferenceCounting () |
Get whether reference counting is active. More... | |
static void | setDeleteHandler (DeleteHandler *handler) |
Set a DeleteHandler to which deletion of all referenced counted objects will be delegated. More... | |
static DeleteHandler * | getDeleteHandler () |
Get a DeleteHandler. More... | |
Protected Attributes inherited from osg::Referenced | |
OpenThreads::AtomicPtr | _observerSet |
OpenThreads::Atomic | _refCount |
This is the base class for effect techniques.
A technique represents one of the possible ways to implement a special effect. This base class is abstract, you will have to subclass your own techniques for your custom effects. Derived classes will have to implement the define_passes() method to configure the rendering pass(es) that make up the technique. Usually you will create one StateSet object for each rendering pass and then you'll call addPass(stateset). The validate() method should return true if the technique is valid within the current rendering context, false otherwise. The default implementation of validate() calls getRequiredExtensions() and tests whether all required extensions are supported or not, returning false if at least one extension is not supported.
osgFX::Technique::Technique | ( | ) |
|
inlineprotected |
|
inlineprotectedvirtual |
|
protected |
create a new pass node, add it to the technique and associate a StateSet
|
protectedpure virtual |
define the rendering passes that make up this technique.
You must implement this method in derived classes to add the required passes.
|
inlineprotected |
force rebuilding of pass nodes on next traversal
|
inline |
get the number of rendering passes defined in this Technique
|
inlineprotectedvirtual |
optional: return a node that overrides the child node on a specified pass
|
inline |
get the StateSet object associated to the i-th pass
|
inline |
get the const StateSet object associated to the i-th pass
|
inlinevirtual |
collect the GL extension strings which are required for this technique to work properly.
This method is called from the default implementation of validate().
|
inlinevirtual |
get a brief description of this Technique
|
inlinevirtual |
get the name of this Technique
|
inlinevirtual |
traverse children with multipass if necessary.
By default this method simply calls the protected method traverse_implementation(); you can override it to change the default behavior. Don't call this method directly as it is called by osgFX::Effect
|
protected |
traverse children with multipass if necessary.
Don't call this method directly unless you are in a customized version of traverse().
|
virtual |
tests whether this technique is valid for the current rendering context.
The default behavior is to call getRequiredExtensions() and check for extension availability.
Generated at Wed Nov 11 2015 22:14:57 for the OpenSceneGraph by doxygen 1.8.10. |