Home | Download | Screen shots | Discussion | Documentation |
---|
Represents a VRML Script node. More...
#include <openvrml/browser.h>
Inherits openvrml::child_node.
Classes | |
class | eventout |
An event_emitter along with the emitted value. More... | |
Public Types | |
typedef std::map< std::string, boost::shared_ptr< field_value > > | field_value_map_t |
A std::map that keys field values on their field name. More... | |
typedef boost::shared_ptr< eventout > | eventout_ptr |
Reference-counted smart pointer to an eventout . More... | |
typedef std::map< std::string, eventout_ptr > | eventout_map_t |
Map of eventout instances. More... | |
Public Member Functions | |
script_node (script_node_metatype &class_, const boost::shared_ptr< openvrml::scope > &scope, const node_interface_set &interfaces, const initial_value_map &initial_values) throw ( unsupported_interface , std::bad_cast , std::bad_alloc , std::invalid_argument ) | |
Construct. More... | |
virtual | ~script_node () throw () |
Destroy. More... | |
void | update (double current_time) |
Update the script_node for the current time. More... | |
const event_listener_map_t & | event_listener_map () const throw () |
Event listener map accessor. More... | |
const field_value_map_t & | field_value_map () const throw () |
Field value map accessor. More... | |
const eventout_map_t & | eventout_map () const throw () |
eventOut map accessor. More... | |
Private Member Functions | |
virtual void | do_initialize (double timestamp) throw ( std::bad_alloc ) |
Initialize. More... | |
virtual const field_value & | do_field (const std::string &id) const throw ( unsupported_interface ) |
Get the value of a field. More... | |
virtual openvrml::event_listener & | do_event_listener (const std::string &id) throw ( unsupported_interface ) |
Get an event listener. More... | |
virtual openvrml::event_emitter & | do_event_emitter (const std::string &id) throw ( unsupported_interface ) |
Get an event emitter. More... | |
virtual void | do_shutdown (double timestamp) throw () |
Called by node::shutdown . More... | |
virtual void | do_render_child (viewer &v, rendering_context context) |
node::render_child implementation. More... | |
Represents a VRML Script node.
A std::map
that keys field values on their field name.
Reference-counted smart pointer to an eventout
.
Map of eventout
instances.
openvrml::script_node::script_node | ( | script_node_metatype & | class_, |
const boost::shared_ptr< openvrml::scope > & | scope, | ||
const node_interface_set & | interfaces, | ||
const initial_value_map & | initial_values | ||
) | |||
throw | ( | unsupported_interface , | |
std::bad_cast , | |||
std::bad_alloc , | |||
std::invalid_argument | |||
) |
Construct.
Unlike other concrete node types, which are always instantiated via node_type::create_node
, the script_node
constructor is called directly when creating a new script_node
from scratch. However, a script_node
can be duplicated (or “cloned”) by calling node_type::create_node
on #type
of a script_node
instance. This provides a consistent interface for cloning any node, regardless of its type. OpenVRML uses this internally when instantiating PROTOs
.
[in] | class_ | the script_node_metatype . Typically there is one script_node_metatype per browser instance. |
[in] | scope | the scope to which the node should belong. |
[in] | interfaces | a node_interface_set containing specifications of user-defined fields , eventIns , and eventOuts particular to the script_node instance. |
[in] | initial_values | a map of initial values for fields of the script_node . |
unsupported_interface | if initial_values specifies a field that is not supported by the script_node . |
std::bad_cast | if initial_values includes a field value that is the wrong type for the specified field. |
std::bad_alloc | if memory allocation fails. |
std::invalid_argument | if:
|
|
virtual |
Destroy.
void openvrml::script_node::update | ( | double | current_time | ) |
Update the script_node for the current time.
[in] | current_time | the current time. |
const openvrml::script_node::event_listener_map_t & openvrml::script_node::event_listener_map | ( | ) | const | |
throw | ( | |||
) |
Event listener map accessor.
const openvrml::script_node::field_value_map_t & openvrml::script_node::field_value_map | ( | ) | const | |
throw | ( | |||
) |
Field value map accessor.
field value map.
const openvrml::script_node::eventout_map_t & openvrml::script_node::eventout_map | ( | ) | const | |
throw | ( | |||
) |
eventOut
map accessor.
eventOut
map.
eventOut
map.
|
privatevirtual |
Initialize.
[in] | timestamp | the current time. |
std::bad_alloc | if memory allocation fails. |
|
privatevirtual |
Get the value of a field.
[in] | id | the name of the field to get. |
id
.unsupported_interface | if the node has no field id . |
|
privatevirtual |
Get an event listener.
This method is called by node::event_listener
. Subclasses must implement this method.
[in] | id | eventIn identifier. |
unsupported_interface | if the node has no eventIn id . |
|
privatevirtual |
Get an event emitter.
This method is called by node::event_emitter
.
[in] | id | eventOut identifier. |
unsupported_interface | if the node has no eventOut id . |
|
privatevirtual |
Called by node::shutdown
.
[in] | timestamp | the current time. |
|
privatevirtual |
node::render_child
implementation.
[in,out] | v | viewer implementation responsible for actually doing the drawing. |
[in] | context | generic context argument; holds things like the accumulated modelview transform. |