6a67be2e32
forcing users to use osgDB::readRef*File() methods. The later is preferable as it closes a potential threading bug when using paging databases in conjunction with the osgDB::Registry Object Cache. This threading bug occurs when one thread gets an object from the Cache via an osgDB::read*File() call where only a pointer to the object is passed back, so taking a reference to the object is delayed till it gets reassigned to a ref_ptr<>, but at the same time another thread calls a flush of the Object Cache deleting this object as it's referenceCount is now zero. Using osgDB::readREf*File() makes sure the a ref_ptr<> is passed back and the referenceCount never goes to zero. To ensure the OSG builds when OSG_PROVIDE_READFILE is to OFF the many cases of osgDB::read*File() usage had to be replaced with a ref_ptr<> osgDB::readRef*File() usage. The avoid this change causing lots of other client code to be rewritten to handle the use of ref_ptr<> in place of C pointer I introduced a serious of templte methods in various class to adapt ref_ptr<> to the underly C pointer to be passed to old OSG API's, example of this is found in include/osg/Group: bool addChild(Node* child); // old method which can only be used with a Node* tempalte<class T> bool addChild(const osg::ref_ptr<T>& child) { return addChild(child.get()); } // adapter template method These changes together cover 149 modified files, so it's a large submission. This extent of changes are warrent to make use of the Object Cache and multi-threaded loaded more robust. git-svn-id: http://svn.openscenegraph.org/osg/OpenSceneGraph/branches/OpenSceneGraph-3.4@15165 16af8721-9629-0410-8352-f15c8da7e697
208 lines
7.6 KiB
C++
208 lines
7.6 KiB
C++
/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2006 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.
|
|
*/
|
|
|
|
#ifndef OSG_SHAPEDRAWABLE
|
|
#define OSG_SHAPEDRAWABLE 1
|
|
|
|
#include <osg/Drawable>
|
|
#include <osg/Vec2>
|
|
#include <osg/Vec3>
|
|
#include <osg/Vec4>
|
|
#include <osg/Array>
|
|
#include <osg/PrimitiveSet>
|
|
|
|
namespace osg {
|
|
|
|
/** Describe several hints that can be passed to a Tessellator (like the one used
|
|
* by \c ShapeDrawable) as a mean to try to influence the way it works.
|
|
*/
|
|
class TessellationHints : public Object
|
|
{
|
|
public:
|
|
|
|
TessellationHints():
|
|
_TessellationMode(USE_SHAPE_DEFAULTS),
|
|
_detailRatio(1.0f),
|
|
_targetNumFaces(100),
|
|
_createFrontFace(true),
|
|
_createBackFace(false),
|
|
_createNormals(true),
|
|
_createTextureCoords(false),
|
|
_createTop(true),
|
|
_createBody(true),
|
|
_createBottom(true) {}
|
|
|
|
|
|
TessellationHints(const TessellationHints& tess, const CopyOp& copyop=CopyOp::SHALLOW_COPY):
|
|
Object(tess,copyop),
|
|
_TessellationMode(tess._TessellationMode),
|
|
_detailRatio(tess._detailRatio),
|
|
_targetNumFaces(tess._targetNumFaces),
|
|
_createFrontFace(tess._createFrontFace),
|
|
_createBackFace(tess._createBackFace),
|
|
_createNormals(tess._createNormals),
|
|
_createTextureCoords(tess._createTextureCoords),
|
|
_createTop(tess._createTop),
|
|
_createBody(tess._createBody),
|
|
_createBottom(tess._createBottom) {}
|
|
|
|
META_Object(osg,TessellationHints);
|
|
|
|
|
|
enum TessellationMode
|
|
{
|
|
USE_SHAPE_DEFAULTS,
|
|
USE_TARGET_NUM_FACES
|
|
};
|
|
|
|
inline void setTessellationMode(TessellationMode mode) { _TessellationMode=mode; }
|
|
inline TessellationMode getTessellationMode() const { return _TessellationMode; }
|
|
|
|
inline void setDetailRatio(float ratio) { _detailRatio = ratio; }
|
|
inline float getDetailRatio() const { return _detailRatio; }
|
|
|
|
inline void setTargetNumFaces(unsigned int target) { _targetNumFaces=target; }
|
|
inline unsigned int getTargetNumFaces() const { return _targetNumFaces; }
|
|
|
|
inline void setCreateFrontFace(bool on) { _createFrontFace=on; }
|
|
inline bool getCreateFrontFace() const { return _createFrontFace; }
|
|
|
|
inline void setCreateBackFace(bool on) { _createBackFace=on; }
|
|
inline bool getCreateBackFace() const { return _createBackFace; }
|
|
|
|
inline void setCreateNormals(bool on) { _createNormals=on; }
|
|
inline bool getCreateNormals() const { return _createNormals; }
|
|
|
|
inline void setCreateTextureCoords(bool on) { _createTextureCoords=on; }
|
|
inline bool getCreateTextureCoords() const { return _createTextureCoords; }
|
|
|
|
inline void setCreateTop(bool on) { _createTop=on; }
|
|
inline bool getCreateTop() const { return _createTop; }
|
|
|
|
inline void setCreateBody(bool on) { _createBody=on; }
|
|
inline bool getCreateBody() const { return _createBody; }
|
|
|
|
inline void setCreateBottom(bool on) { _createBottom=on; }
|
|
inline bool getCreateBottom() const { return _createBottom; }
|
|
|
|
protected:
|
|
|
|
~TessellationHints() {}
|
|
|
|
|
|
TessellationMode _TessellationMode;
|
|
|
|
float _detailRatio;
|
|
unsigned int _targetNumFaces;
|
|
|
|
bool _createFrontFace;
|
|
bool _createBackFace;
|
|
bool _createNormals;
|
|
bool _createTextureCoords;
|
|
|
|
bool _createTop;
|
|
bool _createBody;
|
|
bool _createBottom;
|
|
|
|
};
|
|
|
|
|
|
/** Allow the use of <tt>Shape</tt>s as <tt>Drawable</tt>s, so that they can
|
|
* be rendered with reduced effort. The implementation of \c ShapeDrawable is
|
|
* not geared to efficiency; it's better to think of it as a convenience to
|
|
* render <tt>Shape</tt>s easily (perhaps for test or debugging purposes) than
|
|
* as the right way to render basic shapes in some efficiency-critical section
|
|
* of code.
|
|
*/
|
|
class OSG_EXPORT ShapeDrawable : public Drawable
|
|
{
|
|
public:
|
|
|
|
ShapeDrawable();
|
|
|
|
ShapeDrawable(Shape* shape, TessellationHints* hints=0);
|
|
|
|
template<class T> ShapeDrawable(const ref_ptr<T>& shape, TessellationHints* hints=0):
|
|
_color(1.0f,1.0f,1.0f,1.0f),
|
|
_tessellationHints(hints) { setShape(shape.get()); }
|
|
|
|
|
|
|
|
/** Copy constructor using CopyOp to manage deep vs shallow copy.*/
|
|
ShapeDrawable(const ShapeDrawable& pg,const CopyOp& copyop=CopyOp::SHALLOW_COPY);
|
|
|
|
virtual Object* cloneType() const { return new ShapeDrawable(); }
|
|
virtual Object* clone(const CopyOp& copyop) const { return new ShapeDrawable(*this,copyop); }
|
|
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const ShapeDrawable*>(obj)!=NULL; }
|
|
virtual const char* libraryName() const { return "osg"; }
|
|
virtual const char* className() const { return "ShapeDrawable"; }
|
|
|
|
/** Set the color of the shape.*/
|
|
void setColor(const Vec4& color);
|
|
|
|
/** Get the color of the shape.*/
|
|
const Vec4& getColor() const { return _color; }
|
|
|
|
void setTessellationHints(TessellationHints* hints);
|
|
|
|
TessellationHints* getTessellationHints() { return _tessellationHints.get(); }
|
|
const TessellationHints* getTessellationHints() const { return _tessellationHints.get(); }
|
|
|
|
|
|
|
|
/** Draw ShapeDrawable directly ignoring an OpenGL display list which
|
|
* could be attached. This is the internal draw method which does the
|
|
* drawing itself, and is the method to override when deriving from
|
|
* ShapeDrawable for user-drawn objects.
|
|
*/
|
|
virtual void drawImplementation(RenderInfo& renderInfo) const;
|
|
|
|
/* Not all virtual overloads of these methods are overridden in this class, so
|
|
bring the base class implementation in to avoid hiding the non-used ones. */
|
|
using Drawable::supports;
|
|
using Drawable::accept;
|
|
|
|
/** Return false, osg::ShapeDrawable does not support accept(AttributeFunctor&).*/
|
|
virtual bool supports(const AttributeFunctor&) const { return false; }
|
|
|
|
/** Return true, osg::ShapeDrawable does support accept(Drawable::ConstAttributeFunctor&).*/
|
|
virtual bool supports(const Drawable::ConstAttributeFunctor&) const { return true; }
|
|
|
|
/** Accept a Drawable::ConstAttributeFunctor and call its methods to tell it about the internal attributes that this Drawable has.*/
|
|
virtual void accept(Drawable::ConstAttributeFunctor& af) const;
|
|
|
|
/** Return true, osg::ShapeDrawable does support accept(PrimitiveFunctor&) .*/
|
|
virtual bool supports(const PrimitiveFunctor&) const { return true; }
|
|
|
|
/** Accept a PrimitiveFunctor and call its methods to tell it about the internal primitives that this Drawable has.*/
|
|
virtual void accept(PrimitiveFunctor& pf) const;
|
|
|
|
virtual BoundingBox computeBoundingBox() const;
|
|
|
|
protected:
|
|
|
|
ShapeDrawable& operator = (const ShapeDrawable&) { return *this;}
|
|
|
|
virtual ~ShapeDrawable();
|
|
|
|
Vec4 _color;
|
|
|
|
ref_ptr<TessellationHints> _tessellationHints;
|
|
|
|
};
|
|
|
|
|
|
}
|
|
|
|
#endif
|