| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- // Filename: sheetNode.h
- // Created by: drose (11Oct03)
- //
- ////////////////////////////////////////////////////////////////////
- //
- // PANDA 3D SOFTWARE
- // Copyright (c) 2001 - 2004, Disney Enterprises, Inc. All rights reserved
- //
- // All use of this software is subject to the terms of the Panda 3d
- // Software license. You should have received a copy of this license
- // along with this source code; you will also find a current copy of
- // the license at http://etc.cmu.edu/panda3d/docs/license/ .
- //
- // To contact the maintainers of this program write to
- // [email protected] .
- //
- ////////////////////////////////////////////////////////////////////
- #ifndef SHEETNODE_H
- #define SHEETNODE_H
- #include "pandabase.h"
- #include "nurbsSurfaceEvaluator.h"
- #include "pandaNode.h"
- #include "pStatCollector.h"
- ////////////////////////////////////////////////////////////////////
- // Class : SheetNode
- // Description : This class draws a visible representation of the
- // NURBS surface stored in its NurbsSurfaceEvaluator. It
- // automatically recomputes the surface every frame.
- //
- // This is not related to NurbsSurface, ClassicNurbsSurface,
- // CubicSurfaceseg or any of the ParametricSurface-derived
- // objects in this module. It is a completely parallel
- // implementation of NURBS surfaces, and will probably
- // eventually replace the whole ParametricSurface class
- // hierarchy.
- ////////////////////////////////////////////////////////////////////
- class EXPCL_PANDA SheetNode : public PandaNode {
- PUBLISHED:
- SheetNode(const string &name);
- protected:
- SheetNode(const SheetNode ©);
- public:
- virtual void output(ostream &out) const;
- virtual void write(ostream &out, int indent_level = 0) const;
- virtual PandaNode *make_copy() const;
- virtual bool safe_to_transform() const;
- virtual bool has_cull_callback() const;
- virtual bool cull_callback(CullTraverser *trav, CullTraverserData &data);
- PUBLISHED:
- INLINE void set_surface(NurbsSurfaceEvaluator *surface);
- INLINE NurbsSurfaceEvaluator *get_surface() const;
- INLINE void set_use_vertex_color(bool flag);
- INLINE bool get_use_vertex_color() const;
- INLINE void set_num_u_subdiv(int num_u_subdiv);
- INLINE int get_num_u_subdiv() const;
- INLINE void set_num_v_subdiv(int num_v_subdiv);
- INLINE int get_num_v_subdiv() const;
- void reset_bound(const NodePath &rel_to);
- protected:
- virtual BoundingVolume *recompute_internal_bound();
- private:
- BoundingVolume *do_recompute_bound(const NodePath &rel_to);
- void render_sheet(CullTraverser *trav, CullTraverserData &data,
- NurbsSurfaceResult *result);
- private:
- // This is the data that must be cycled between pipeline stages.
- class EXPCL_PANDA CData : public CycleData {
- public:
- INLINE CData();
- INLINE CData(const CData ©);
- virtual CycleData *make_copy() const;
- virtual void write_datagram(BamWriter *manager, Datagram &dg) const;
- virtual void fillin(DatagramIterator &scan, BamReader *manager);
- virtual TypeHandle get_parent_type() const {
- return SheetNode::get_class_type();
- }
- PT(NurbsSurfaceEvaluator) _surface;
- bool _use_vertex_color;
- int _num_u_subdiv;
- int _num_v_subdiv;
- };
- PipelineCycler<CData> _cycler;
- typedef CycleDataReader<CData> CDReader;
- typedef CycleDataWriter<CData> CDWriter;
- static PStatCollector _sheet_node_pcollector;
- public:
- static void register_with_read_factory();
- virtual void write_datagram(BamWriter *manager, Datagram &dg);
- protected:
- static TypedWritable *make_from_bam(const FactoryParams ¶ms);
- void fillin(DatagramIterator &scan, BamReader *manager);
- public:
- static TypeHandle get_class_type() {
- return _type_handle;
- }
- static void init_type() {
- PandaNode::init_type();
- register_type(_type_handle, "SheetNode",
- PandaNode::get_class_type());
- }
- virtual TypeHandle get_type() const {
- return get_class_type();
- }
- virtual TypeHandle force_init_type() {init_type(); return get_class_type();}
- private:
- static TypeHandle _type_handle;
- };
- #include "sheetNode.I"
- #endif
|