checkered_box Class Reference

#include <utils.hpp>

Inheritance diagram for checkered_box:

Inheritance graph
[legend]
Collaboration diagram for checkered_box:

Collaboration graph
[legend]

List of all members.


Detailed Description

Definition at line 136 of file utils.hpp.


Scene Graph Functionality.

void add_child (node *child)
 Add a child node. Also sets the child's parent to this.
bool connect (node *branch)
 If this is called on the root of a scene graph, it will insert the branch node in the appropriate place in the graph, or return false.
void detach ()
 Removes the node from the scene graph (does not delete it!).
gsgl::flags_tget_draw_flags ()
const gsgl::flags_tget_draw_flags () const
gsgl::flags_tget_draw_results ()
const gsgl::flags_tget_draw_results () const
enum  node_draw_flags { NODE_NO_DRAW_FLAGS = 0, NODE_NO_FRUSTUM_CHECK = 1 << 0, NODE_DUMMY_OBJECT = 1 << 2, NODE_DRAW_UNLIT = 1 << 3 }
 Flags that control node drawing. More...
enum  node_draw_results { NODE_NO_DRAW_RESULTS = 0, NODE_OFF_SCREEN = 1 << 0, NODE_DREW_POINT = 1 << 1, NODE_DISTANCE_CULLED = 1 << 2 }
 Flags that indicate what happened when the node was drawn. More...
static void draw_scene (gsgl::scenegraph::context *c, pre_draw_rec &rec)
 Draws a scene. Safe to call while update is also being called in the tree.
static void pre_draw_scene (gsgl::scenegraph::context *c, pre_draw_rec &rec)
 Collect information about the scene to draw. Unsafe to call while update is being called in the tree.

Public Member Functions

 checkered_box (const gsgl::string &name, scenegraph::node *parent, gsgl::real_t radius)
virtual void cleanup (gsgl::scenegraph::context *c)
 Called when the simulation is done.
virtual gsgl::real_t default_view_distance () const
virtual void draw (gsgl::scenegraph::context *c)
 Called to draw the node. The node's modelview matrix is in the correct state for drawing, and already loaded into the OpenGL modelview matrix.
virtual gsgl::real_t get_priority (gsgl::scenegraph::context *)
 Called to determine the draw priority of the node.
gsgl::real_tget_radius ()
virtual const gsgl::stringget_type_name () const
virtual void init (gsgl::scenegraph::context *c)
 Called when the simulation is created. The node's modelview matrix is invalid at this point.
virtual gsgl::real_t max_extent () const
 Should return the maximum extent of the object (in the node's coordinates, i.e. not scaled to meters).
virtual gsgl::real_t minimum_view_distance () const
virtual void update (gsgl::scenegraph::context *c)
 Called from the root of the world-tree up to update the node's state. The node's modelview matrix is that of the previously-drawn frame.
virtual ~checkered_box ()
Accessors.
data::simple_array< node * > & get_children ()
math::transformget_modelview ()
stringget_name ()
const stringget_name () const
math::transformget_orientation ()
node *& get_parent ()
const nodeget_parent () const
stringget_parent_name ()
gsgl::real_tget_scale ()
math::vectorget_translation ()
Node Life Cycle.
virtual bool handle_event (gsgl::scenegraph::context *c, sg_event &e)
 Called with events.
virtual data::config_recordsave () const
 Called to save the node to a config_record structure.

Static Public Attributes

Drawing Information Functions.
static const gsgl::real_t NODE_DRAW_FIRST = FLT_MAX
static const gsgl::real_t NODE_DRAW_IGNORE = 0.000f
static const gsgl::real_t NODE_DRAW_SOLID = 0.001f
static const gsgl::real_t NODE_DRAW_TRANSLUCENT = 0.002f

Private Attributes

platform::vertex_buffer normals
gsgl::real_t radius
platform::vertex_buffer vertices

Member Enumeration Documentation

enum node_draw_flags [inherited]

Flags that control node drawing.

Enumerator:
NODE_NO_DRAW_FLAGS 
NODE_NO_FRUSTUM_CHECK  Don't perform a frustum check when drawing this node.
NODE_DUMMY_OBJECT  This node should never be drawn.
NODE_DRAW_UNLIT  This node should not be lit.

Definition at line 141 of file node.hpp.

enum node_draw_results [inherited]

Flags that indicate what happened when the node was drawn.

Enumerator:
NODE_NO_DRAW_RESULTS 
NODE_OFF_SCREEN  The node was not drawn because it was out-of-frame.
NODE_DREW_POINT  The node was drawn as a point.
NODE_DISTANCE_CULLED  The node was not drawn due to distance.

Definition at line 157 of file node.hpp.


Constructor & Destructor Documentation

checkered_box ( const gsgl::string name,
scenegraph::node parent,
gsgl::real_t  radius 
)

Definition at line 455 of file utils.cpp.

~checkered_box (  )  [virtual]

Definition at line 461 of file utils.cpp.


Member Function Documentation

void add_child ( node child  )  [inherited]

Add a child node. Also sets the child's parent to this.

Definition at line 267 of file node.cpp.

References assert, node::children, and node::parent.

Referenced by node::connect(), application::load_objects(), application::load_scenery(), model::model(), node::node(), vehicle::vehicle(), and vehicle_module::vehicle_module().

void cleanup ( gsgl::scenegraph::context c  )  [virtual]

Called when the simulation is done.

Reimplemented from node.

Definition at line 563 of file utils.cpp.

References node::cleanup(), checkered_box::normals, vbuffer_base::unload(), and checkered_box::vertices.

bool connect ( node branch  )  [inherited]

If this is called on the root of a scene graph, it will insert the branch node in the appropriate place in the graph, or return false.

Definition at line 289 of file node.cpp.

References node::add_child(), node::children, node::name, and node::parent_name.

Referenced by simulation::simulation().

gsgl::real_t default_view_distance (  )  const [virtual]

Reimplemented from node.

Definition at line 583 of file utils.cpp.

void detach (  )  [inherited]

Removes the node from the scene graph (does not delete it!).

Definition at line 276 of file node.cpp.

References node::children, and node::parent.

void draw ( gsgl::scenegraph::context c  )  [virtual]

Called to draw the node. The node's modelview matrix is in the correct state for drawing, and already loaded into the OpenGL modelview matrix.

Reimplemented from node.

Definition at line 523 of file utils.cpp.

References vbuffer_base::bind(), color::BLACK, CHECK_GL_ERRORS, color::get_val(), checkered_box::normals, vbuffer_mixin::size(), and checkered_box::vertices.

void draw_scene ( gsgl::scenegraph::context c,
pre_draw_rec rec 
) [static, inherited]

data::simple_array< node * > & get_children (  )  [inherited]

gsgl::flags_t& get_draw_flags (  )  [inline, inherited]

Returns:
The node's draw flags (a bitset using node_draw_flags).

Definition at line 153 of file node.hpp.

const gsgl::flags_t& get_draw_flags (  )  const [inline, inherited]

gsgl::flags_t& get_draw_results (  )  [inline, inherited]

Returns:
The node's draw results (a bitset using node_draw_results).

Definition at line 169 of file node.hpp.

const gsgl::flags_t& get_draw_results (  )  const [inline, inherited]

Returns:
The node's draw results (a bitset using node_draw_results).

Definition at line 166 of file node.hpp.

Referenced by large_rocky_body::draw(), celestial_body::draw(), and large_lithosphere::update().

math::transform & get_modelview (  )  [inherited]

string & get_name (  )  [inherited]

Definition at line 205 of file node.cpp.

References node::name.

const string & get_name (  )  const [inherited]

math::transform & get_orientation (  )  [inherited]

node *& get_parent (  )  [inherited]

Definition at line 168 of file node.cpp.

References node::parent.

const node * get_parent (  )  const [inherited]

string & get_parent_name (  )  [inherited]

Definition at line 210 of file node.cpp.

References node::parent_name.

gsgl::real_t get_priority ( gsgl::scenegraph::context  )  [virtual]

Called to determine the draw priority of the node.

A value of NODE_DRAW_IGNORE means don't draw (invisible nodes or nodes that are drawn by their parents -- the modelview matrix is still built). A value of NODE_DRAW_SOLID means the object is solid and should be drawn after the painter's algorithm. A value of NODE_DRAW_TRANSLUCENT means the object is translucent and should be drawn after solid objects. A value > NODE_DRAW_TRANSLUCENT is interpreted as the distance to the object. Objects that return > 2.0 are drawn with a painter's algorithm.

Reimplemented from node.

Definition at line 572 of file utils.cpp.

References node::NODE_DRAW_TRANSLUCENT.

gsgl::real_t& get_radius (  )  [inline]

Definition at line 146 of file utils.hpp.

gsgl::real_t & get_scale (  )  [inherited]

Definition at line 215 of file node.cpp.

References node::scale.

Referenced by stellar_db::draw(), gsgl::scenegraph::utils::greatest_extent(), and stellar_db::init().

math::vector & get_translation (  )  [inherited]

const gsgl::string & get_type_name (  )  const [virtual, inherited]

Definition at line 54 of file broker.cpp.

References countable::is_empty(), and brokered_object::type_name.

Referenced by node::draw_scene(), and simulation::update_node().

bool handle_event ( gsgl::scenegraph::context c,
sg_event e 
) [virtual, inherited]

Called with events.

Reimplemented in freeview.

Definition at line 323 of file node.cpp.

Referenced by simulation::handle_event().

void init ( gsgl::scenegraph::context c  )  [virtual]

Called when the simulation is created. The node's modelview matrix is invalid at this point.

Reimplemented from node.

Definition at line 483 of file utils.cpp.

References checkered_box::normals, and checkered_box::vertices.

gsgl::real_t max_extent (  )  const [virtual]

Should return the maximum extent of the object (in the node's coordinates, i.e. not scaled to meters).

Reimplemented from node.

Definition at line 578 of file utils.cpp.

gsgl::real_t minimum_view_distance (  )  const [virtual]

Reimplemented from node.

Definition at line 588 of file utils.cpp.

void pre_draw_scene ( gsgl::scenegraph::context c,
pre_draw_rec rec 
) [static, inherited]

Collect information about the scene to draw. Unsafe to call while update is being called in the tree.

Definition at line 380 of file node.cpp.

References node::build_draw_list(), context::cam, transform::IDENTITY, node::pre_draw_rec::light_queue, node::pre_draw_rec::paint_queue, node::pre_draw_rec::solids, and node::pre_draw_rec::translucents.

Referenced by simulation::pre_draw().

data::config_record * save (  )  const [virtual, inherited]

Called to save the node to a config_record structure.

Definition at line 328 of file node.cpp.

void update ( gsgl::scenegraph::context c  )  [virtual]

Called from the root of the world-tree up to update the node's state. The node's modelview matrix is that of the previously-drawn frame.

Reimplemented from node.

Definition at line 557 of file utils.cpp.

References node::update().


Member Data Documentation

const gsgl::real_t NODE_DRAW_FIRST = FLT_MAX [static, inherited]

const gsgl::real_t NODE_DRAW_IGNORE = 0.000f [static, inherited]

const gsgl::real_t NODE_DRAW_SOLID = 0.001f [static, inherited]

Definition at line 216 of file node.hpp.

Referenced by node::build_draw_list(), and submesh_node::get_priority().

const gsgl::real_t NODE_DRAW_TRANSLUCENT = 0.002f [static, inherited]

Definition at line 140 of file utils.hpp.

Referenced by checkered_box::cleanup(), checkered_box::draw(), and checkered_box::init().

gsgl::real_t radius [private]

Definition at line 139 of file utils.hpp.

Definition at line 140 of file utils.hpp.

Referenced by checkered_box::cleanup(), checkered_box::draw(), and checkered_box::init().


The documentation for this class was generated from the following files:

Generated on Sat Mar 1 13:50:07 2008 for Periapsis Project by  doxygen 1.5.5