#include <clipPlaneAttrib.h>
Inheritance diagram for ClipPlaneAttrib:
Public Types | |
enum | Operation { O_set, O_add, O_remove } |
enum | PandaCompareFunc { M_none = 0, M_never, M_less, M_equal, M_less_equal, M_greater, M_not_equal, M_greater_equal, M_always } |
Public Member Functions | |
Operation | get_operation () const |
Returns the basic operation type of the ClipPlaneAttrib. | |
int | get_num_planes () const |
Returns the number of planes listed in the attribute. | |
PlaneNode * | get_plane (int n) const |
Returns the nth planes listed in the attribute. | |
bool | has_plane (PlaneNode *plane) const |
Returns true if the indicated plane is listed in the attrib, false otherwise. | |
ConstPointerTo< RenderAttrib > | add_plane (PlaneNode *plane) const |
ConstPointerTo< RenderAttrib > | remove_plane (PlaneNode *plane) const |
bool | is_identity () const |
Returns true if this is an identity attrib: it does not change the set of planes in use. | |
bool | is_all_off () const |
Returns true if this attrib turns off all planes and turns none on. | |
virtual void | issue (GraphicsStateGuardianBase *gsg) const |
Calls the appropriate method on the indicated GSG to issue the graphics commands appropriate to the given attribute. | |
virtual void | output (ostream &out) const |
virtual void | write_datagram (BamWriter *manager, Datagram &dg) |
Writes the contents of this object to the datagram for shipping out to a Bam file. | |
virtual int | complete_pointers (TypedWritable **plist, BamReader *manager) |
Receives an array of pointers, one for each time manager->read_pointer() was called in fillin(). | |
virtual TypeHandle | get_type () const |
virtual TypeHandle | force_init_type () |
ConstPointerTo< RenderAttrib > | compose (const RenderAttrib *other) const |
ConstPointerTo< RenderAttrib > | invert_compose (const RenderAttrib *other) const |
ConstPointerTo< RenderAttrib > | make_default () const |
int | compare_to (const RenderAttrib &other) const |
Provides an arbitrary ordering among all unique RenderAttribs, so we can store the essentially different ones in a big set and throw away the rest. | |
virtual void | write (ostream &out, int indent_level) const |
virtual void | finalize () |
Method to ensure that any necessary clean up tasks that have to be performed by this object are performed. | |
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 | |
ConstPointerTo< RenderAttrib > | make_all_off () |
Constructs a new ClipPlaneAttrib object that turns off all planes (and hence disables planeing). | |
ConstPointerTo< RenderAttrib > | make (Operation op, PlaneNode *plane) |
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s). | |
ConstPointerTo< RenderAttrib > | make (Operation op, PlaneNode *plane1, PlaneNode *plane2) |
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s). | |
ConstPointerTo< RenderAttrib > | make (Operation op, PlaneNode *plane1, PlaneNode *plane2, PlaneNode *plane3) |
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s). | |
ConstPointerTo< RenderAttrib > | make (Operation op, PlaneNode *plane1, PlaneNode *plane2, PlaneNode *plane3, PlaneNode *plane4) |
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s). | |
void | register_with_read_factory () |
Tells the BamReader how to create objects of type ClipPlaneAttrib. | |
TypeHandle | get_class_type () |
void | init_type () |
TypedWritable * | change_this (TypedWritable *old_ptr, BamReader *manager) |
Called immediately after complete_pointers(), this gives the object a chance to adjust its own pointer if desired. | |
Static Public Attributes | |
TypedWritable *const | Null = (TypedWritable*)0L |
Protected Member Functions | |
virtual int | compare_to_impl (const RenderAttrib *other) const |
Intended to be overridden by derived ClipPlaneAttrib types to return a unique number indicating whether this ClipPlaneAttrib is equivalent to the other one. | |
virtual ConstPointerTo< RenderAttrib > | compose_impl (const RenderAttrib *other) const |
Intended to be overridden by derived RenderAttrib types to specify how two consecutive RenderAttrib objects of the same type interact. | |
virtual ConstPointerTo< RenderAttrib > | invert_compose_impl (const RenderAttrib *other) const |
Intended to be overridden by derived RenderAttrib types to specify how two consecutive RenderAttrib objects of the same type interact. | |
virtual RenderAttrib * | make_default_impl () const |
Intended to be overridden by derived ClipPlaneAttrib types to specify what the default property for a ClipPlaneAttrib of this type should be. | |
void | fillin (DatagramIterator &scan, BamReader *manager) |
This internal function is called by make_from_bam to read in all of the relevant data from the BamFile for the new ClipPlaneAttrib. | |
void | output_comparefunc (ostream &out, PandaCompareFunc fn) const |
Static Protected Member Functions | |
TypedWritable * | make_from_bam (const FactoryParams ¶ms) |
This function is called by the BamReader's factory when a new object of type ClipPlaneAttrib is encountered in the Bam file. | |
ConstPointerTo< RenderAttrib > | return_new (RenderAttrib *attrib) |
This function is used by derived RenderAttrib types to share a common RenderAttrib pointer for all equivalent RenderAttrib objects. | |
TypedWritable * | new_from_bam (RenderAttrib *attrib, BamReader *manager) |
Private Types | |
typedef ov_set< PointerTo< PlaneNode > > | Planes |
Private Member Functions | |
ClipPlaneAttrib () | |
Use ClipPlaneAttrib::make() to construct a new ClipPlaneAttrib object. | |
ConstPointerTo< RenderAttrib > | do_add (const ClipPlaneAttrib *other, Operation op) const |
Returns a new ClipPlaneAttrib that represents all the planes of this attrib, with those of the other one added in. | |
ConstPointerTo< RenderAttrib > | do_remove (const ClipPlaneAttrib *other, Operation op) const |
Returns a new ClipPlaneAttrib that represents all the planes of this attrib, with those of the other one removed. | |
Private Attributes | |
Operation | _operation |
Planes | _planes |
Static Private Attributes | |
TypeHandle | _type_handle |
It indicates the set of clipping planes that modify the geometry at this level and below. A ClipPlaneAttrib can either add planes or remove planes from the total set of clipping planes in effect.
Definition at line 46 of file clipPlaneAttrib.h.
|
Definition at line 97 of file clipPlaneAttrib.h. |
|
Definition at line 51 of file clipPlaneAttrib.h. Referenced by ClipPlaneAttrib(). |
|
Definition at line 107 of file renderAttrib.h. Referenced by AlphaTestAttrib::AlphaTestAttrib(), DepthTestAttrib::DepthTestAttrib(), DXGraphicsStateGuardian8::enable_texturing(), GLGraphicsStateGuardian::issue_tex_matrix(), and GLGraphicsStateGuardian::issue_transform(). |
|
Use ClipPlaneAttrib::make() to construct a new ClipPlaneAttrib object.
Definition at line 34 of file clipPlaneAttrib.I. References _operation, INLINE, and Operation. |
|
|
|
Called immediately after complete_pointers(), this gives the object a chance to adjust its own pointer if desired. Most objects don't change pointers after completion, but some need to. Once this function has been called, the old pointer will no longer be accessed. Definition at line 362 of file renderAttrib.cxx. |
|
Provides an arbitrary ordering among all unique RenderAttribs, so we can store the essentially different ones in a big set and throw away the rest. This method is not needed outside of the RenderAttrib class because all equivalent RenderAttrib objects are guaranteed to share the same pointer; thus, a pointer comparison is always sufficient. Definition at line 125 of file renderAttrib.I. |
|
Intended to be overridden by derived ClipPlaneAttrib types to return a unique number indicating whether this ClipPlaneAttrib is equivalent to the other one. This should return 0 if the two ClipPlaneAttrib objects are equivalent, a number less than zero if this one should be sorted before the other one, and a number greater than zero otherwise. This will only be called with two ClipPlaneAttrib objects whose get_type() functions return the same. Reimplemented from RenderAttrib. Definition at line 234 of file clipPlaneAttrib.cxx. References _operation, DCAST_INTO_R, do_add(), do_remove(), O_remove, and O_set. |
|
Receives an array of pointers, one for each time manager->read_pointer() was called in fillin(). Returns the number of pointers processed. Reimplemented from TypedWritable. Definition at line 542 of file clipPlaneAttrib.cxx. |
|
Referenced by LightAttrib::get_light(), LightAttrib::get_num_lights(), get_num_planes(), and get_plane(). |
|
Intended to be overridden by derived RenderAttrib types to specify how two consecutive RenderAttrib objects of the same type interact. This should return the result of applying the other RenderAttrib to a node in the scene graph below this RenderAttrib, which was already applied. In most cases, the result is the same as the other RenderAttrib (that is, a subsequent RenderAttrib completely replaces the preceding one). On the other hand, some kinds of RenderAttrib (for instance, ColorTransformAttrib) might combine in meaningful ways. Reimplemented from RenderAttrib. Definition at line 300 of file clipPlaneAttrib.cxx. References _operation, and _planes. |
|
Returns a new ClipPlaneAttrib that represents all the planes of this attrib, with those of the other one added in.
Definition at line 391 of file clipPlaneAttrib.cxx. Referenced by compare_to_impl(). |
|
Returns a new ClipPlaneAttrib that represents all the planes of this attrib, with those of the other one removed.
Definition at line 451 of file clipPlaneAttrib.cxx. References fillin(), and parse_params(). Referenced by compare_to_impl(). |
|
This internal function is called by make_from_bam to read in all of the relevant data from the BamFile for the new ClipPlaneAttrib.
Reimplemented from RenderAttrib. Definition at line 594 of file clipPlaneAttrib.cxx. Referenced by do_remove(). |
|
Method to ensure that any necessary clean up tasks that have to be performed by this object are performed.
Reimplemented from TypedWritable. Definition at line 393 of file renderAttrib.cxx. |
|
Reimplemented from RenderAttrib. Definition at line 121 of file clipPlaneAttrib.h. |
|
Reimplemented from RenderAttrib. Definition at line 110 of file clipPlaneAttrib.h. |
|
Returns the number of planes listed in the attribute.
Definition at line 72 of file clipPlaneAttrib.I. References _operation, RenderAttrib::compose(), INLINE, make(), O_add, and O_remove. Referenced by GraphicsStateGuardian::issue_color(). |
|
Returns the basic operation type of the ClipPlaneAttrib. If this is O_set, the planes listed here completely replace any planes that were already on. If this is O_add, the planes here are added to the set of of planes that were already on, and if O_remove, the planes here are removed from the set of planes that were on. Definition at line 59 of file clipPlaneAttrib.I. References _planes, INLINE, nassertr, and NULL. Referenced by GraphicsStateGuardian::issue_color(). |
|
Returns the nth planes listed in the attribute.
Definition at line 85 of file clipPlaneAttrib.I. References _operation, RenderAttrib::compose(), INLINE, make(), O_add, and O_remove. Referenced by GraphicsStateGuardian::issue_color(). |
|
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(). |
|
Reimplemented from RenderAttrib. Definition at line 118 of file clipPlaneAttrib.h. |
|
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. |
|
Returns true if the indicated plane is listed in the attrib, false otherwise.
Definition at line 146 of file clipPlaneAttrib.cxx. Referenced by GraphicsStateGuardian::issue_color(). |
|
Reimplemented from RenderAttrib. Definition at line 113 of file clipPlaneAttrib.h. |
|
|
|
Intended to be overridden by derived RenderAttrib types to specify how two consecutive RenderAttrib objects of the same type interact. See invert_compose() and compose_impl(). Reimplemented from RenderAttrib. Definition at line 346 of file clipPlaneAttrib.cxx. |
|
Returns true if this attrib turns off all planes and turns none on.
Definition at line 156 of file clipPlaneAttrib.I. |
|
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(). |
|
Returns true if this is an identity attrib: it does not change the set of planes in use.
Definition at line 141 of file clipPlaneAttrib.I. |
|
|
Calls the appropriate method on the indicated GSG to issue the graphics commands appropriate to the given attribute. This is normally called (indirectly) only from GraphicsStateGuardian::set_state() or modify_state(). Reimplemented from RenderAttrib. Definition at line 167 of file clipPlaneAttrib.cxx. |
|
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s).
Definition at line 122 of file clipPlaneAttrib.cxx. References GraphicsStateGuardianBase::issue_clip_plane(). |
|
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s).
Definition at line 99 of file clipPlaneAttrib.cxx. References _operation, _planes, RenderAttrib::return_new(), and ov_set< PointerTo< PlaneNode > >::sort(). |
|
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s).
Definition at line 78 of file clipPlaneAttrib.cxx. References _operation, _planes, RenderAttrib::return_new(), and ov_set< PointerTo< PlaneNode > >::sort(). |
|
Constructs a new ClipPlaneAttrib object that turns on (or off, according to op) the indicate plane(s).
Definition at line 60 of file clipPlaneAttrib.cxx. References _operation, _planes, RenderAttrib::return_new(), and ov_set< PointerTo< PlaneNode > >::sort(). Referenced by get_num_planes(), and get_plane(). |
|
Constructs a new ClipPlaneAttrib object that turns off all planes (and hence disables planeing).
Definition at line 43 of file clipPlaneAttrib.cxx. References _operation, _planes, and RenderAttrib::return_new(). |
|
|
|
Intended to be overridden by derived ClipPlaneAttrib types to specify what the default property for a ClipPlaneAttrib of this type should be. This should return a newly-allocated ClipPlaneAttrib of the same type that corresponds to whatever the standard default for this kind of ClipPlaneAttrib is. Implements RenderAttrib. Definition at line 374 of file clipPlaneAttrib.cxx. |
|
This function is called by the BamReader's factory when a new object of type ClipPlaneAttrib is encountered in the Bam file. It should create the ClipPlaneAttrib and extract its information from the file. Definition at line 570 of file clipPlaneAttrib.cxx. |
|
|
|
Reimplemented from RenderAttrib. Definition at line 180 of file clipPlaneAttrib.cxx. References _operation, _planes, and DCAST_INTO_R. |
|
Definition at line 141 of file renderAttrib.cxx. References RenderAttrib::_attribs, RenderAttrib::_saved_entry, nassertr, and NULL. |
|
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(). |
|
Tells the BamReader how to create objects of type ClipPlaneAttrib.
Definition at line 499 of file clipPlaneAttrib.cxx. |
|
|
|
This function is used by derived RenderAttrib types to share a common RenderAttrib pointer for all equivalent RenderAttrib objects. The make() function of the derived type should create a new RenderAttrib and pass it through return_new(), which will either save the pointer and return it unchanged (if this is the first similar such object) or delete it and return an equivalent pointer (if there was already a similar object saved). Definition at line 186 of file renderAttrib.cxx. Referenced by CullFaceAttrib::compare_to_impl(), TextureAttrib::make(), MaterialAttrib::make(), LightAttrib::make(), FogAttrib::make(), CullFaceAttrib::make(), make(), LightAttrib::make_all_off(), make_all_off(), ColorAttrib::make_flat(), and ColorAttrib::make_vertex(). |
|
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(). |
|
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(). |
|
Definition at line 155 of file renderAttrib.cxx. References RenderAttrib::_attribs. |
|
Writes the contents of this object to the datagram for shipping out to a Bam file.
Reimplemented from RenderAttrib. Definition at line 514 of file clipPlaneAttrib.cxx. |
|
Definition at line 96 of file clipPlaneAttrib.h. Referenced by ClipPlaneAttrib(), compare_to_impl(), compose_impl(), get_num_planes(), get_plane(), make(), make_all_off(), and output(). |
|
Definition at line 98 of file clipPlaneAttrib.h. Referenced by compose_impl(), get_operation(), make(), make_all_off(), and output(). |
|
Reimplemented from RenderAttrib. Definition at line 30 of file clipPlaneAttrib.cxx. |
|
Definition at line 25 of file typedWritable.cxx. Referenced by Child::complete_pointers(), Parent::complete_pointers(), Person::complete_pointers(), LoaderFileTypeBam::get_extension(), PartGroup::pick_channel_index(), BamReader::read_pointer(), and AnimGroup::write_datagram(). |