OpenSceneGraph/include/osg/Stencil

155 lines
5.0 KiB
Plaintext
Raw Normal View History

/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2003 Robert Osfield
*
* This library is open source and may be redistributed and/or modified under
* the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
* (at your option) any later version. The full license is in LICENSE file
* included with this distribution, and on the openscenegraph.org website.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* OpenSceneGraph Public License for more details.
*/
2001-09-20 05:19:47 +08:00
#ifndef OSG_STENCIL
#define OSG_STENCIL 1
#include <osg/StateAttribute>
namespace osg {
/** Encapsulate OpenGL glStencilFunc/Op/Mask functions.
2001-09-20 05:19:47 +08:00
*/
class SG_EXPORT Stencil : public StateAttribute
{
public :
Stencil();
2001-09-22 10:42:08 +08:00
/** Copy constructor using CopyOp to manage deep vs shallow copy.*/
Stencil(const Stencil& stencil,const CopyOp& copyop=CopyOp::SHALLOW_COPY):
StateAttribute(stencil,copyop),
_func(stencil._func),
_funcRef(stencil._funcRef),
_funcMask(stencil._funcMask),
_sfail(stencil._sfail),
_zfail(stencil._zfail),
_zpass(stencil._zpass),
_writeMask(stencil._writeMask) {}
META_StateAttribute(osg, Stencil, STENCIL);
2001-09-20 05:19:47 +08:00
2001-09-22 10:42:08 +08:00
/** return -1 if *this < *rhs, 0 if *this==*rhs, 1 if *this>*rhs.*/
virtual int compare(const StateAttribute& sa) const
{
// check the types are equal and then create the rhs variable
// used by the COMPARE_StateAttribute_Paramter macro's below.
COMPARE_StateAttribute_Types(Stencil,sa)
// compare each paramter in turn against the rhs.
COMPARE_StateAttribute_Parameter(_func)
COMPARE_StateAttribute_Parameter(_funcRef)
COMPARE_StateAttribute_Parameter(_funcMask)
COMPARE_StateAttribute_Parameter(_sfail)
COMPARE_StateAttribute_Parameter(_zfail)
COMPARE_StateAttribute_Parameter(_zpass)
COMPARE_StateAttribute_Parameter(_writeMask)
return 0; // passed all the above comparison macro's, must be equal.
}
virtual bool getModeUsage(ModeUsage& usage) const
2001-09-20 05:19:47 +08:00
{
usage.usesMode(GL_STENCIL_TEST);
return true;
2001-09-20 05:19:47 +08:00
}
enum Function
{
NEVER = GL_NEVER,
LESS = GL_LESS,
EQUAL = GL_EQUAL,
LEQUAL = GL_LEQUAL,
GREATER = GL_GREATER,
NOTEQUAL = GL_NOTEQUAL,
GEQUAL = GL_GEQUAL,
ALWAYS = GL_ALWAYS
};
2003-02-14 19:41:52 +08:00
inline void setFunction(Function func,int ref,unsigned int mask)
2001-09-20 05:19:47 +08:00
{
_func = func;
_funcRef = ref;
_funcMask = mask;
}
2002-11-11 16:04:40 +08:00
inline Function getFunction() const { return _func; }
2001-09-20 05:19:47 +08:00
inline int getFunctionRef() const { return _funcRef; }
2001-09-20 05:19:47 +08:00
2003-02-14 19:41:52 +08:00
inline unsigned int getFunctionMask() const { return _funcMask; }
2001-09-20 05:19:47 +08:00
enum Operation
{
KEEP = GL_KEEP,
ZERO = GL_ZERO,
REPLACE = GL_REPLACE,
INCR = GL_INCR,
DECR = GL_DECR,
INVERT = GL_INVERT
};
/** set the operations to apply when the various stencil and depth
* tests fail or pass. First parameter is to control the operation
* when the stencil test fails. The second parameter is to control the
* operation when the stencil test passes, but depth test fails. The
2001-09-20 05:19:47 +08:00
* third parameter controls the operation when both the stencil test
* and depth pass. Ordering of parameter is the same as if using
* glStencilOp(,,).*/
2002-11-11 16:04:40 +08:00
inline void setOperation(Operation sfail, Operation zfail, Operation zpass)
2001-09-20 05:19:47 +08:00
{
_sfail = sfail;
_zfail = zfail;
_zpass = zpass;
}
/** get the operation when the stencil test fails.*/
2002-11-11 16:04:40 +08:00
inline Operation getStencilFailOperation() const { return _sfail; }
2001-09-20 05:19:47 +08:00
/** get the operation when the stencil test passes but the depth test fails*/
2002-11-11 16:04:40 +08:00
inline Operation getStencilPassAndDepthFailOperation() const { return _zfail; }
2001-09-20 05:19:47 +08:00
/** get the operation when both the stencil test and the depth test pass*/
2002-11-11 16:04:40 +08:00
inline Operation getStencilPassAndDepthPassOperation() const { return _zpass; }
2001-09-20 05:19:47 +08:00
2003-02-14 19:41:52 +08:00
inline void setWriteMask(unsigned int mask) { _writeMask = mask; }
2001-09-20 05:19:47 +08:00
2003-02-14 19:41:52 +08:00
inline unsigned int getWriteMask() const { return _writeMask; }
2001-09-20 05:19:47 +08:00
virtual void apply(State& state) const;
protected:
virtual ~Stencil();
Function _func;
int _funcRef;
2003-02-14 19:41:52 +08:00
unsigned int _funcMask;
2001-09-20 05:19:47 +08:00
Operation _sfail;
Operation _zfail;
Operation _zpass;
2003-02-14 19:41:52 +08:00
unsigned int _writeMask;
2001-09-20 05:19:47 +08:00
};
}
2001-09-20 05:19:47 +08:00
#endif