2002-06-21 03:54:08 +08:00
|
|
|
//C++ header - Open Scene Graph - Copyright (C) 1998-2001 Robert Osfield
|
|
|
|
//Distributed under the terms of the GNU Library General Public License (LGPL)
|
|
|
|
//as published by the Free Software Foundation.
|
|
|
|
|
|
|
|
#ifndef OSG_GEOMETRY
|
|
|
|
#define OSG_GEOMETRY 1
|
|
|
|
|
|
|
|
#include <osg/Drawable>
|
|
|
|
#include <osg/Vec2>
|
|
|
|
#include <osg/Vec3>
|
|
|
|
#include <osg/Vec4>
|
2002-06-27 18:50:19 +08:00
|
|
|
#include <osg/Array>
|
|
|
|
#include <osg/Primitive>
|
2002-06-21 03:54:08 +08:00
|
|
|
|
|
|
|
namespace osg {
|
|
|
|
|
2002-06-22 00:45:45 +08:00
|
|
|
|
|
|
|
class SG_EXPORT Geometry : public Drawable
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
Geometry();
|
|
|
|
|
|
|
|
/** Copy constructor using CopyOp to manage deep vs shallow copy.*/
|
|
|
|
Geometry(const Geometry& Geometry,const CopyOp& copyop=CopyOp::SHALLOW_COPY);
|
|
|
|
|
|
|
|
virtual Object* cloneType() const { return osgNew Geometry(); }
|
|
|
|
virtual Object* clone(const CopyOp& copyop) const { return osgNew Geometry(*this,copyop); }
|
|
|
|
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const Geometry*>(obj)!=NULL; }
|
|
|
|
virtual const char* libraryName() const { return "osg"; }
|
|
|
|
virtual const char* className() const { return "Geometry"; }
|
|
|
|
|
|
|
|
enum AttributeBinding
|
|
|
|
{
|
2002-06-24 05:43:46 +08:00
|
|
|
BIND_OFF=0,
|
|
|
|
BIND_OVERALL,
|
|
|
|
BIND_PER_PRIMITIVE,
|
|
|
|
BIND_PER_VERTEX,
|
2002-06-22 00:45:45 +08:00
|
|
|
};
|
|
|
|
|
2002-06-26 04:27:51 +08:00
|
|
|
void setVertexArray(Vec3Array* array) { _vertexArray = array; dirtyDisplayList(); }
|
2002-06-22 00:45:45 +08:00
|
|
|
Vec3Array* getVertexArray() { return _vertexArray.get(); }
|
|
|
|
const Vec3Array* getVertexArray() const { return _vertexArray.get(); }
|
|
|
|
|
|
|
|
|
2002-06-26 04:27:51 +08:00
|
|
|
void setNormalBinding(AttributeBinding ab) { _normalBinding = ab; dirtyDisplayList(); }
|
2002-06-22 00:45:45 +08:00
|
|
|
AttributeBinding getNormalBinding() const { return _normalBinding; }
|
|
|
|
|
2002-06-26 04:27:51 +08:00
|
|
|
void setNormalArray(Vec3Array* array) { _normalArray = array; if (!_normalArray.valid()) _normalBinding=BIND_OFF; dirtyDisplayList(); }
|
2002-06-22 00:45:45 +08:00
|
|
|
Vec3Array* getNormalArray() { return _normalArray.get(); }
|
|
|
|
const Vec3Array* getNormalArray() const { return _normalArray.get(); }
|
|
|
|
|
|
|
|
|
|
|
|
void setColorBinding(AttributeBinding ab) { _colorBinding = ab; }
|
|
|
|
AttributeBinding getColorBinding() const { return _colorBinding; }
|
|
|
|
|
2002-06-26 04:27:51 +08:00
|
|
|
void setColorArray(AttributeArray* array) { _colorArray = array; if (!_colorArray.valid()) _colorBinding=BIND_OFF; dirtyDisplayList(); }
|
2002-06-22 00:45:45 +08:00
|
|
|
AttributeArray* getColorArray() { return _colorArray.get(); }
|
|
|
|
const AttributeArray* getColorArray() const { return _colorArray.get(); }
|
|
|
|
|
|
|
|
|
2002-06-25 05:37:34 +08:00
|
|
|
typedef std::vector< ref_ptr<AttributeArray> > TexCoordArrayList;
|
|
|
|
|
2002-06-22 00:45:45 +08:00
|
|
|
|
|
|
|
void setTexCoordArray(unsigned int unit,AttributeArray*);
|
|
|
|
AttributeArray* getTexCoordArray(unsigned int unit);
|
|
|
|
const AttributeArray* getTexCoordArray(unsigned int unit) const;
|
2002-06-25 05:37:34 +08:00
|
|
|
|
|
|
|
unsigned int getNumTexCoordArrays() const { return _texCoordList.size(); }
|
|
|
|
TexCoordArrayList& getTexCoordArrayList() { return _texCoordList; }
|
|
|
|
const TexCoordArrayList& getTexCoordArrayList() const { return _texCoordList; }
|
2002-06-22 00:45:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
typedef std::vector< ref_ptr<Primitive> > PrimitiveList;
|
|
|
|
|
2002-06-26 04:27:51 +08:00
|
|
|
void setPrimitiveList(const PrimitiveList& primitives) { _primitives = primitives; dirtyDisplayList(); }
|
2002-06-22 00:45:45 +08:00
|
|
|
PrimitiveList& getPrimitiveList() { return _primitives; }
|
|
|
|
const PrimitiveList& getPrimitiveList() const { return _primitives; }
|
|
|
|
|
2002-06-26 04:27:51 +08:00
|
|
|
void addPrimitive(Primitive* primitive) { if (primitive) _primitives.push_back(primitive); dirtyDisplayList(); }
|
2002-06-21 03:54:08 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** draw Geometry 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 Geometry for user-drawn objects.
|
|
|
|
*/
|
|
|
|
virtual void drawImmediateMode(State& state);
|
|
|
|
|
|
|
|
/** Statistics collection for each drawable- 26.09.01
|
|
|
|
*/
|
|
|
|
bool getStats(Statistics &);
|
|
|
|
|
|
|
|
|
|
|
|
/** return the attributes supported by applyAttrbuteUpdate() as an AttributeBitMask.*/
|
|
|
|
virtual AttributeBitMask suppportsAttributeOperation() const;
|
|
|
|
|
|
|
|
/** return the attributes successully applied in applyAttributeUpdate.*/
|
|
|
|
virtual AttributeBitMask applyAttributeOperation(AttributeFunctor& auf);
|
|
|
|
|
2002-06-26 04:27:51 +08:00
|
|
|
virtual void applyPrimitiveOperation(PrimitiveFunctor&);
|
2002-06-21 03:54:08 +08:00
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
Geometry& operator = (const Geometry&) { return *this;}
|
|
|
|
|
|
|
|
virtual ~Geometry();
|
|
|
|
|
|
|
|
virtual const bool computeBound() const;
|
|
|
|
|
|
|
|
|
|
|
|
|
2002-06-22 00:45:45 +08:00
|
|
|
PrimitiveList _primitives;
|
2002-06-21 03:54:08 +08:00
|
|
|
|
2002-06-22 00:45:45 +08:00
|
|
|
ref_ptr<Vec3Array> _vertexArray;
|
|
|
|
|
|
|
|
AttributeBinding _normalBinding;
|
|
|
|
ref_ptr<Vec3Array> _normalArray;
|
2002-06-21 03:54:08 +08:00
|
|
|
|
2002-06-22 00:45:45 +08:00
|
|
|
AttributeBinding _colorBinding;
|
|
|
|
ref_ptr<AttributeArray> _colorArray;
|
2002-06-21 03:54:08 +08:00
|
|
|
|
2002-06-25 05:37:34 +08:00
|
|
|
TexCoordArrayList _texCoordList;
|
2002-06-21 03:54:08 +08:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|