Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members   File Members  

EggPolysetMaker Class Reference

A specialization on EggBinMaker for making polysets that share the same basic rendering characteristic. More...

#include <eggPolysetMaker.h>

Inheritance diagram for EggPolysetMaker:

EggBinMaker EggObject TypedReferenceCount TypedObject ReferenceCount List of all members.

Public Types

enum  BinNumber { BN_none = 0, BN_polyset }
enum  Properties {
  P_has_texture = 0x001, P_texture = 0x002, P_has_material = 0x004, P_material = 0x008,
  P_has_poly_color = 0x010, P_poly_color = 0x020, P_has_poly_normal = 0x040, P_has_vertex_normal = 0x080,
  P_has_vertex_color = 0x100, P_bface = 0x200
}

Public Member Functions

 EggPolysetMaker ()
void set_properties (int properties)
 Sets the set of properties that determines which polygons are allowed to be grouped together into a single polyset.

virtual int get_bin_number (const EggNode *node)
virtual bool sorts_less (int bin_number, const EggNode *a, const EggNode *b)
 May be overridden in derived classes to create additional bins within a particular bin number, based on some arbitrary property of nodes.

int make_bins (EggGroupNode *root_group)
 The main entry point to EggBinMaker.

virtual bool collapse_group (const EggGroup *group, int bin_number)
 May be overridden in derived classes to specify whether a particular group node, apparently redundant, may be safely collapsed out.

virtual string get_bin_name (int bin_number)
 May be overridden in derived classes to define a name for each new bin, based on its bin number.

virtual TypeHandle get_type () const
virtual TypeHandle force_init_type ()
int get_type_index () const
 Returns the internal index number associated with this object's TypeHandle, a unique number for each different type.

bool is_of_type (TypeHandle handle) const
 Returns true if the current object is or derives from the indicated type.

bool is_exact_type (TypeHandle handle) const
 Returns true if the current object is the indicated type exactly.

int get_ref_count () const
 Returns the current reference count.

int ref () const
 Explicitly increments the reference count.

int unref () const
 Explicitly decrements the reference count.

void test_ref_count_integrity () const
 Does some easy checks to make sure that the reference count isn't completely bogus.


Static Public Member Functions

TypeHandle get_class_type ()
void init_type ()

Private Attributes

int _properties

Detailed Description

A specialization on EggBinMaker for making polysets that share the same basic rendering characteristic.

This really just defines the example functions described in the leading comment to EggBinMaker.

It makes some common assumptions about how polysets should be grouped; if these are not sufficient, you can always rederive your own further specialization of this class.

Definition at line 54 of file eggPolysetMaker.h.


Member Enumeration Documentation

enum EggPolysetMaker::BinNumber
 

Enumeration values:
BN_none 
BN_polyset 

Definition at line 58 of file eggPolysetMaker.h.

enum EggPolysetMaker::Properties
 

Enumeration values:
P_has_texture 
P_texture 
P_has_material 
P_material 
P_has_poly_color 
P_poly_color 
P_has_poly_normal 
P_has_vertex_normal 
P_has_vertex_color 
P_bface 

Definition at line 63 of file eggPolysetMaker.h.


Constructor & Destructor Documentation

EggPolysetMaker::EggPolysetMaker  ) 
 

Definition at line 34 of file eggPolysetMaker.cxx.

References _properties.


Member Function Documentation

bool EggBinMaker::collapse_group const EggGroup group,
int  bin_number
[virtual, inherited]
 

May be overridden in derived classes to specify whether a particular group node, apparently redundant, may be safely collapsed out.

Reimplemented in EggBinner.

Definition at line 153 of file eggBinMaker.cxx.

References EggBinMaker::_group_nodes, and EggBinMaker::SortedNodes.

Referenced by EggBinMaker::get_bins_for_group().

virtual TypeHandle EggBinMaker::force_init_type void   )  [inline, virtual, inherited]
 

Reimplemented from EggObject.

Definition at line 320 of file eggBinMaker.h.

string EggBinMaker::get_bin_name int  bin_number  )  [virtual, inherited]
 

May be overridden in derived classes to define a name for each new bin, based on its bin number.

Definition at line 168 of file eggBinMaker.cxx.

int EggPolysetMaker::get_bin_number const EggNode node  )  [virtual]
 

Implements EggBinMaker.

Definition at line 69 of file eggPolysetMaker.cxx.

References _properties, P_has_texture, P_texture, and pb.

TypeHandle EggBinMaker::get_class_type void   )  [inline, static, inherited]
 

Reimplemented from EggObject.

Definition at line 309 of file eggBinMaker.h.

int ReferenceCount::get_ref_count  )  const [inline, inherited]
 

Returns the current reference count.

Definition at line 183 of file referenceCount.I.

Referenced by RenderState::determine_bin_index(), RenderEffects::determine_show_bounds(), FontPool::ns_garbage_collect(), TexturePool::ns_garbage_collect(), MaterialPool::ns_get_material(), and TexturePool::ns_release_texture().

virtual TypeHandle EggBinMaker::get_type void   )  const [inline, virtual, inherited]
 

Reimplemented from EggObject.

Definition at line 317 of file eggBinMaker.h.

int TypedObject::get_type_index  )  const [inline, inherited]
 

Returns the internal index number associated with this object's TypeHandle, a unique number for each different type.

This is equivalent to get_type().get_index().

Definition at line 71 of file typedObject.I.

References TypeHandle::get_name(), TypedObject::get_type(), and INLINE.

void EggBinMaker::init_type void   )  [inline, static, inherited]
 

Reimplemented from EggObject.

Definition at line 312 of file eggBinMaker.h.

bool TypedObject::is_exact_type TypeHandle  handle  )  const [inline, inherited]
 

Returns true if the current object is the indicated type exactly.

Definition at line 101 of file typedObject.I.

Referenced by PT(), and CollisionNode::xform().

bool TypedObject::is_of_type TypeHandle  handle  )  const [inline, inherited]
 

Returns true if the current object is or derives from the indicated type.

Definition at line 86 of file typedObject.I.

Referenced by EggMaterialCollection::collapse_equivalent_materials(), EggTextureCollection::collapse_equivalent_textures(), DeferredNodeProperty::compose(), AnimBundleMaker::create_s_channel(), CharacterMaker::create_slider(), ProjectionScreen::cull_callback(), DataNode::define_output(), EggNode::determine_draw_order(), CharacterMaker::egg_to_index(), EggGroupUniquifier::EggGroupUniquifier(), EggPoolUniquifier::EggPoolUniquifier(), EggGroupNode::find_textures(), StaticTextFont::get_glyph(), EggMaterialCollection::insert_materials(), EggTextureCollection::insert_textures(), CharacterJoint::make_copy(), PT(), EggGroupNode::r_flatten_transforms(), EggGroupNode::r_transform_vertices(), EggGroupNode::recompute_polygon_normals(), CollisionLevelState::reserve(), PandaFramework::reset_frame_rate(), PandaFramework::set_texture(), EggGroupNode::steal_children(), and DataGraphTraverser::traverse().

int EggBinMaker::make_bins EggGroupNode root_group  )  [inherited]
 

The main entry point to EggBinMaker.

Walks the egg scene graph beginning at the indicated root node, and moves all binnable nodes into EggBin objects. Returns the number of EggBins created.

Definition at line 101 of file eggBinMaker.cxx.

Referenced by EggLoader::EggLoader().

int ReferenceCount::ref  )  const [inline, inherited]
 

Explicitly increments the reference count.

User code should avoid using ref() and unref() directly, which can result in missed reference counts. Instead, let a PointerTo object manage the reference counting automatically.

This function is const, even though it changes the object, because generally fiddling with an object's reference count isn't considered part of fiddling with the object. An object might be const in other ways, but we still need to accurately count the number of references to it.

The return value is the new reference count.

Definition at line 225 of file referenceCount.I.

Referenced by ClientDevice::ClientDevice(), EggGroupNode::find_textures(), EggGroupNode::r_apply_texmats(), EggGroupNode::r_flatten_transforms(), and EggGroupNode::reverse_vertex_ordering().

void EggPolysetMaker::set_properties int  properties  ) 
 

Sets the set of properties that determines which polygons are allowed to be grouped together into a single polyset.

This is the bitwise 'or' of all the properties that matter. If this is 0, all polygons (within a given group) will be lumped into a common polyset regardless of their properties.

Definition at line 57 of file eggPolysetMaker.cxx.

References BN_none.

bool EggPolysetMaker::sorts_less int  bin_number,
const EggNode a,
const EggNode b
[virtual]
 

May be overridden in derived classes to create additional bins within a particular bin number, based on some arbitrary property of nodes.

This function establishes an arbitrary but fixed ordering between nodes; if two nodes do not sort to the same position, different bins are created for each one (with the same bin number on each bin).

Reimplemented from EggBinMaker.

Definition at line 86 of file eggPolysetMaker.cxx.

References pb.

void ReferenceCount::test_ref_count_integrity  )  const [inline, inherited]
 

Does some easy checks to make sure that the reference count isn't completely bogus.

Definition at line 328 of file referenceCount.I.

References INLINE.

Referenced by EggNode::determine_bin(), and ReferenceCount::~ReferenceCount().

int ReferenceCount::unref  )  const [inline, inherited]
 

Explicitly decrements the reference count.

Note that the object will not be implicitly deleted by unref() simply because the reference count drops to zero. (Having a member function delete itself is problematic; plus, we don't have a virtual destructor anyway.) However, see the helper function unref_delete().

User code should avoid using ref() and unref() directly, which can result in missed reference counts. Instead, let a PointerTo object manage the reference counting automatically.

This function is const, even though it changes the object, because generally fiddling with an object's reference count isn't considered part of fiddling with the object. An object might be const in other ways, but we still need to accurately count the number of references to it.

The return value is the new reference count.

Definition at line 293 of file referenceCount.I.

References INLINE.

Referenced by RenderState::determine_bin_index(), and RenderEffects::determine_show_bounds().


Member Data Documentation

int EggPolysetMaker::_properties [private]
 

Definition at line 87 of file eggPolysetMaker.h.

Referenced by EggPolysetMaker(), and get_bin_number().


The documentation for this class was generated from the following files:
Generated on Fri May 2 00:50:18 2003 for Panda by doxygen1.3