Panda3D
|
Public Member Functions | |
XFileToEggConverter (const XFileToEggConverter ©) | |
void | clear_egg_data () |
Sets the EggData to NULL and makes the converter invalid. | |
void | clear_end_frame () |
Removes the value previously set by set_end_frame(). | |
void | clear_error () |
Resets the error flag to the no-error state. | |
void | clear_frame_inc () |
Removes the value previously set by set_frame_inc(). | |
void | clear_input_frame_rate () |
Removes the value previously set by set_input_frame_rate(). | |
void | clear_neutral_frame () |
Removes the value previously set by set_neutral_frame(). | |
void | clear_output_frame_rate () |
Removes the value previously set by set_output_frame_rate(). | |
void | clear_start_frame () |
Removes the value previously set by set_start_frame(). | |
void | close () |
Finalizes and closes the file previously opened via convert_file(). | |
virtual bool | convert_file (const Filename &filename) |
Handles the reading of the input file and converting it to egg. | |
Filename | convert_model_path (const Filename &orig_filename) |
Converts the indicated model filename to a relative or absolute or whatever filename, according to _path_replace. | |
EggMaterial * | create_unique_material (const EggMaterial ©) |
Returns an EggMaterial pointer whose properties match that of the the given EggMaterial, except for the mref name. | |
EggTexture * | create_unique_texture (const EggTexture ©) |
Returns an EggTexture pointer whose properties match that of the the given EggTexture, except for the tref name. | |
EggGroup * | find_joint (const string &joint_name) |
This is called by set_animation_frame, for the purposes of building the frame data for the animation--it needs to know the original rest frame transform. | |
virtual string | get_additional_extensions () const |
Returns a space-separated list of extension, in addition to the one returned by get_extension(), that are recognized by this converter. | |
AnimationConvert | get_animation_convert () const |
Returns how source animation will be converted into egg structures. | |
const string & | get_character_name () const |
Returns the name of the character generated. | |
EggGroup * | get_dart_node () const |
Returns the root of the joint hierarchy, if _make_char is true, or NULL otherwise. | |
EggData * | get_egg_data () |
Returns the EggData structure. | |
double | get_end_frame () const |
Returns the value set by a previous call to set_end_frame(). | |
virtual string | get_extension () const |
Returns the common extension of the file type this converter supports. | |
double | get_frame_inc () const |
Returns the value set by a previous call to set_frame_inc(). | |
double | get_input_frame_rate () const |
Returns the value set by a previous call to set_input_frame_rate(). | |
virtual DistanceUnit | get_input_units () |
This may be called after convert_file() has been called and returned true, indicating a successful conversion. | |
bool | get_merge_externals () const |
Returns the current state of the merge_externals flag. | |
virtual string | get_name () const |
Returns the English name of the file type this converter supports. | |
double | get_neutral_frame () const |
Returns the value set by a previous call to set_neutral_frame(). | |
double | get_output_frame_rate () const |
Returns the value set by a previous call to set_output_frame_rate(). | |
PathReplace * | get_path_replace () |
Returns a pointer to the PathReplace object associated with this converter. | |
const PathReplace * | get_path_replace () const |
Returns a pointer to the PathReplace object associated with this converter. | |
double | get_start_frame () const |
Returns the value set by a previous call to set_start_frame(). | |
bool | had_error () const |
Returns true if an error was detected during the conversion process (unless _allow_errors is true), false otherwise. | |
bool | handle_external_reference (EggGroupNode *egg_parent, const Filename &ref_filename) |
Handles an external reference in the source file. | |
bool | has_end_frame () const |
Returns true if the ending frame has been explicitly specified via set_end_frame(), or false if the ending frame should be implicit based on the source. | |
bool | has_frame_inc () const |
Returns true if the frame increment has been explicitly specified via set_frame_inc(), or false if the ending frame should be implicit based on the source. | |
bool | has_input_frame_rate () const |
Returns true if the frame rate has been explicitly specified via set_input_frame_rate(), or false otherwise. | |
bool | has_neutral_frame () const |
Returns true if the neutral frame has been explicitly specified via set_neutral_frame(), or false otherwise. | |
bool | has_output_frame_rate () const |
Returns true if the frame rate has been explicitly specified via set_output_frame_rate(), or false otherwise. | |
bool | has_start_frame () const |
Returns true if the starting frame has been explicitly specified via set_start_frame(), or false if the starting frame should be implicit based on the source. | |
virtual SomethingToEggConverter * | make_copy () |
Allocates and returns a new copy of the converter. | |
void | set_animation_convert (AnimationConvert animation_convert) |
Specifies how source animation will be converted into egg structures. | |
void | set_character_name (const string &character_name) |
Specifies the name of the character generated. | |
void | set_egg_data (EggData *egg_data) |
Sets the egg data that will be filled in when convert_file() is called. | |
void | set_end_frame (double end_frame) |
Specifies the ending frame of the animation to convert, in the units specified by set_input_frame_rate(). | |
void | set_frame_inc (double frame_inc) |
Specifies the increment between frames to extract. | |
void | set_input_frame_rate (double input_frame_rate) |
Specifies the number of frames per second that is represented by the "frame" unit in the animation package. | |
void | set_merge_externals (bool merge_externals) |
Sets the merge_externals flag. | |
void | set_neutral_frame (double neutral_frame) |
Specifies the frame of animation to represent the neutral pose of the model. | |
void | set_output_frame_rate (double output_frame_rate) |
Specifies the number of frames per second that the resulting animation should be played at. | |
void | set_path_replace (PathReplace *path_replace) |
Replaces the PathReplace object (which specifies how to mangle paths from the source to the destination egg file) with a new one. | |
void | set_start_frame (double start_frame) |
Specifies the starting frame of the animation to convert, in the units specified by set_input_frame_rate(). | |
void | strip_nodes (TypeHandle t) |
Removes all groups of the given type. | |
virtual bool | supports_compressed () const |
Returns true if this file type can transparently load compressed files (with a .pz extension), false otherwise. | |
Static Public Member Functions | |
static double | get_default_frame_rate () |
Returns the default frame rate if nothing is specified for input_frame_rate or output_frame_rate, and the animation package does not have an implicit frame rate. | |
Public Attributes | |
bool | _allow_errors |
string | _char_name |
double | _frame_rate |
bool | _keep_animation |
bool | _keep_model |
bool | _make_char |
Protected Types | |
enum | ControlFlags { CF_start_frame = 0x0001, CF_end_frame = 0x0002, CF_frame_inc = 0x0004, CF_neutral_frame = 0x0008, CF_input_frame_rate = 0x0010, CF_output_frame_rate = 0x0020 } |
Protected Member Functions | |
PT (PathReplace) _path_replace | |
PT (EggData) _egg_data | |
Protected Attributes | |
AnimationConvert | _animation_convert |
string | _character_name |
int | _control_flags |
double | _end_frame |
bool | _error |
double | _frame_inc |
double | _input_frame_rate |
bool | _merge_externals |
double | _neutral_frame |
double | _output_frame_rate |
double | _start_frame |
Definition at line 42 of file xFileToEggConverter.h.
void SomethingToEggConverter::clear_egg_data | ( | ) | [inline, inherited] |
Sets the EggData to NULL and makes the converter invalid.
Definition at line 485 of file somethingToEggConverter.I.
References SomethingToEggConverter::set_egg_data().
void SomethingToEggConverter::clear_end_frame | ( | ) | [inline, inherited] |
Removes the value previously set by set_end_frame().
Definition at line 227 of file somethingToEggConverter.I.
void SomethingToEggConverter::clear_error | ( | ) | [inline, inherited] |
Resets the error flag to the no-error state.
had_error() will return false until a new error is generated.
Definition at line 24 of file somethingToEggConverter.I.
Referenced by convert_file(), VRMLToEggConverter::convert_file(), DXFToEggConverter::convert_file(), DAEToEggConverter::convert_file(), FltToEggConverter::convert_flt(), and MayaToEggConverter::convert_maya().
void SomethingToEggConverter::clear_frame_inc | ( | ) | [inline, inherited] |
Removes the value previously set by set_frame_inc().
Definition at line 282 of file somethingToEggConverter.I.
void SomethingToEggConverter::clear_input_frame_rate | ( | ) | [inline, inherited] |
Removes the value previously set by set_input_frame_rate().
Definition at line 385 of file somethingToEggConverter.I.
void SomethingToEggConverter::clear_neutral_frame | ( | ) | [inline, inherited] |
Removes the value previously set by set_neutral_frame().
Definition at line 331 of file somethingToEggConverter.I.
void SomethingToEggConverter::clear_output_frame_rate | ( | ) | [inline, inherited] |
Removes the value previously set by set_output_frame_rate().
Definition at line 436 of file somethingToEggConverter.I.
void SomethingToEggConverter::clear_start_frame | ( | ) | [inline, inherited] |
Removes the value previously set by set_start_frame().
Definition at line 174 of file somethingToEggConverter.I.
void XFileToEggConverter::close | ( | ) |
Finalizes and closes the file previously opened via convert_file().
Definition at line 178 of file xFileToEggConverter.cxx.
Referenced by convert_file().
bool XFileToEggConverter::convert_file | ( | const Filename & | filename | ) | [virtual] |
Handles the reading of the input file and converting it to egg.
Returns true if successful, false otherwise.
This is designed to be as generic as possible, generally in support of run-time loading. Command-line converters may choose to use convert_flt() instead, as it provides more control.
Implements SomethingToEggConverter.
Definition at line 125 of file xFileToEggConverter.cxx.
References SomethingToEggConverter::clear_error(), close(), Filename::get_basename_wo_extension(), SomethingToEggConverter::had_error(), strip_nodes(), and EggNameUniquifier::uniquify().
Filename SomethingToEggConverter::convert_model_path | ( | const Filename & | orig_filename | ) | [inline, inherited] |
Converts the indicated model filename to a relative or absolute or whatever filename, according to _path_replace.
Definition at line 507 of file somethingToEggConverter.I.
Referenced by XFileMaterial::apply_to_egg(), and CLwoSurface::check_texture().
EggMaterial * XFileToEggConverter::create_unique_material | ( | const EggMaterial & | copy | ) |
Returns an EggMaterial pointer whose properties match that of the the given EggMaterial, except for the mref name.
Definition at line 249 of file xFileToEggConverter.cxx.
References EggMaterialCollection::create_unique_material().
Referenced by XFileMaterial::apply_to_egg().
EggTexture * XFileToEggConverter::create_unique_texture | ( | const EggTexture & | copy | ) |
Returns an EggTexture pointer whose properties match that of the the given EggTexture, except for the tref name.
Definition at line 237 of file xFileToEggConverter.cxx.
References EggTextureCollection::create_unique_texture().
Referenced by XFileMaterial::apply_to_egg().
EggGroup * XFileToEggConverter::find_joint | ( | const string & | joint_name | ) |
This is called by set_animation_frame, for the purposes of building the frame data for the animation--it needs to know the original rest frame transform.
Definition at line 262 of file xFileToEggConverter.cxx.
Referenced by XFileMesh::create_polygons().
string SomethingToEggConverter::get_additional_extensions | ( | ) | const [virtual, inherited] |
Returns a space-separated list of extension, in addition to the one returned by get_extension(), that are recognized by this converter.
Reimplemented in MayaToEggConverter.
Definition at line 88 of file somethingToEggConverter.cxx.
Referenced by LoaderFileTypePandatool::get_additional_extensions().
AnimationConvert SomethingToEggConverter::get_animation_convert | ( | ) | const [inline, inherited] |
Returns how source animation will be converted into egg structures.
Definition at line 98 of file somethingToEggConverter.I.
Referenced by MayaToEggConverter::convert_maya(), and MayaNodeTree::get_egg_group().
const string & SomethingToEggConverter::get_character_name | ( | ) | const [inline, inherited] |
Returns the name of the character generated.
See set_character_name().
Definition at line 122 of file somethingToEggConverter.I.
EggGroup * XFileToEggConverter::get_dart_node | ( | ) | const |
Returns the root of the joint hierarchy, if _make_char is true, or NULL otherwise.
Definition at line 225 of file xFileToEggConverter.cxx.
Referenced by XFileAnimationSet::create_hierarchy().
double SomethingToEggConverter::get_default_frame_rate | ( | ) | [inline, static, inherited] |
Returns the default frame rate if nothing is specified for input_frame_rate or output_frame_rate, and the animation package does not have an implicit frame rate.
Definition at line 450 of file somethingToEggConverter.I.
EggData * SomethingToEggConverter::get_egg_data | ( | ) | [inline, inherited] |
Returns the EggData structure.
Definition at line 495 of file somethingToEggConverter.I.
Referenced by CLwoLayer::connect_egg(), VRMLToEggConverter::convert_file(), MayaToEggConverter::convert_maya(), SoftToEggConverter::convert_soft(), XFileAnimationSet::create_hierarchy(), and SomethingToEggConverter::handle_external_reference().
double SomethingToEggConverter::get_end_frame | ( | ) | const [inline, inherited] |
Returns the value set by a previous call to set_end_frame().
It is an error to call this if has_end_frame() returns false.
Definition at line 215 of file somethingToEggConverter.I.
References SomethingToEggConverter::has_end_frame().
Referenced by MayaToEggConverter::convert_maya().
string XFileToEggConverter::get_extension | ( | ) | const [virtual] |
Returns the common extension of the file type this converter supports.
Implements SomethingToEggConverter.
Definition at line 96 of file xFileToEggConverter.cxx.
double SomethingToEggConverter::get_frame_inc | ( | ) | const [inline, inherited] |
Returns the value set by a previous call to set_frame_inc().
It is an error to call this if has_frame_inc() returns false.
Definition at line 270 of file somethingToEggConverter.I.
References SomethingToEggConverter::has_frame_inc().
Referenced by MayaToEggConverter::convert_maya().
double SomethingToEggConverter::get_input_frame_rate | ( | ) | const [inline, inherited] |
Returns the value set by a previous call to set_input_frame_rate().
It is an error to call this if has_input_frame_rate() returns false.
Definition at line 373 of file somethingToEggConverter.I.
References SomethingToEggConverter::has_input_frame_rate().
Referenced by MayaToEggConverter::convert_maya().
DistanceUnit SomethingToEggConverter::get_input_units | ( | ) | [virtual, inherited] |
This may be called after convert_file() has been called and returned true, indicating a successful conversion.
It will return the distance units represented by the converted egg file, if known, or DU_invalid if not known.
Reimplemented in FltToEggConverter, and MayaToEggConverter.
Definition at line 114 of file somethingToEggConverter.cxx.
bool SomethingToEggConverter::get_merge_externals | ( | ) | const [inline, inherited] |
Returns the current state of the merge_externals flag.
Definition at line 474 of file somethingToEggConverter.I.
string XFileToEggConverter::get_name | ( | ) | const [virtual] |
Returns the English name of the file type this converter supports.
Implements SomethingToEggConverter.
Definition at line 85 of file xFileToEggConverter.cxx.
double SomethingToEggConverter::get_neutral_frame | ( | ) | const [inline, inherited] |
Returns the value set by a previous call to set_neutral_frame().
It is an error to call this if has_neutral_frame() returns false.
Definition at line 319 of file somethingToEggConverter.I.
References SomethingToEggConverter::has_neutral_frame().
double SomethingToEggConverter::get_output_frame_rate | ( | ) | const [inline, inherited] |
Returns the value set by a previous call to set_output_frame_rate().
It is an error to call this if has_output_frame_rate() returns false.
Definition at line 424 of file somethingToEggConverter.I.
References SomethingToEggConverter::has_output_frame_rate().
Referenced by MayaToEggConverter::convert_maya().
const PathReplace * SomethingToEggConverter::get_path_replace | ( | ) | const [inline, inherited] |
Returns a pointer to the PathReplace object associated with this converter.
If the converter is non-const, this returns a non-const pointer, which can be adjusted.
Definition at line 74 of file somethingToEggConverter.I.
PathReplace * SomethingToEggConverter::get_path_replace | ( | ) | [inline, inherited] |
Returns a pointer to the PathReplace object associated with this converter.
If the converter is non-const, this returns a non-const pointer, which can be adjusted.
Definition at line 61 of file somethingToEggConverter.I.
double SomethingToEggConverter::get_start_frame | ( | ) | const [inline, inherited] |
Returns the value set by a previous call to set_start_frame().
It is an error to call this if has_start_frame() returns false.
Definition at line 162 of file somethingToEggConverter.I.
References SomethingToEggConverter::has_start_frame().
Referenced by MayaToEggConverter::convert_maya().
bool SomethingToEggConverter::had_error | ( | ) | const [inline, inherited] |
Returns true if an error was detected during the conversion process (unless _allow_errors is true), false otherwise.
Definition at line 36 of file somethingToEggConverter.I.
Referenced by convert_file(), VRMLToEggConverter::convert_file(), DXFToEggConverter::convert_file(), FltToEggConverter::convert_flt(), LwoToEggConverter::convert_lwo(), and MayaToEggConverter::convert_maya().
bool SomethingToEggConverter::handle_external_reference | ( | EggGroupNode * | egg_parent, |
const Filename & | ref_filename | ||
) | [inherited] |
Handles an external reference in the source file.
If the merge_externals flag is true (see set_merge_externals()), this causes the named file to be read in and converted, and the converted egg geometry is parented to egg_parent. Otherwise, only a reference to a similarly named egg file is parented to egg_parent.
The parameters orig_filename and searchpath are as those passed to convert_model_path().
Returns true on success, false on failure.
Definition at line 135 of file somethingToEggConverter.cxx.
References EggGroupNode::add_child(), SomethingToEggConverter::get_egg_data(), EggData::set_coordinate_system(), SomethingToEggConverter::set_egg_data(), and EggGroupNode::steal_children().
bool SomethingToEggConverter::has_end_frame | ( | ) | const [inline, inherited] |
Returns true if the ending frame has been explicitly specified via set_end_frame(), or false if the ending frame should be implicit based on the source.
Definition at line 203 of file somethingToEggConverter.I.
Referenced by MayaToEggConverter::convert_maya(), and SomethingToEggConverter::get_end_frame().
bool SomethingToEggConverter::has_frame_inc | ( | ) | const [inline, inherited] |
Returns true if the frame increment has been explicitly specified via set_frame_inc(), or false if the ending frame should be implicit based on the source.
Definition at line 258 of file somethingToEggConverter.I.
Referenced by MayaToEggConverter::convert_maya(), and SomethingToEggConverter::get_frame_inc().
bool SomethingToEggConverter::has_input_frame_rate | ( | ) | const [inline, inherited] |
Returns true if the frame rate has been explicitly specified via set_input_frame_rate(), or false otherwise.
Definition at line 361 of file somethingToEggConverter.I.
Referenced by MayaToEggConverter::convert_maya(), and SomethingToEggConverter::get_input_frame_rate().
bool SomethingToEggConverter::has_neutral_frame | ( | ) | const [inline, inherited] |
Returns true if the neutral frame has been explicitly specified via set_neutral_frame(), or false otherwise.
Definition at line 307 of file somethingToEggConverter.I.
Referenced by SomethingToEggConverter::get_neutral_frame().
bool SomethingToEggConverter::has_output_frame_rate | ( | ) | const [inline, inherited] |
Returns true if the frame rate has been explicitly specified via set_output_frame_rate(), or false otherwise.
Definition at line 412 of file somethingToEggConverter.I.
Referenced by MayaToEggConverter::convert_maya(), and SomethingToEggConverter::get_output_frame_rate().
bool SomethingToEggConverter::has_start_frame | ( | ) | const [inline, inherited] |
Returns true if the starting frame has been explicitly specified via set_start_frame(), or false if the starting frame should be implicit based on the source.
Definition at line 150 of file somethingToEggConverter.I.
Referenced by MayaToEggConverter::convert_maya(), and SomethingToEggConverter::get_start_frame().
SomethingToEggConverter * XFileToEggConverter::make_copy | ( | ) | [virtual] |
Allocates and returns a new copy of the converter.
Implements SomethingToEggConverter.
Definition at line 73 of file xFileToEggConverter.cxx.
void SomethingToEggConverter::set_animation_convert | ( | AnimationConvert | animation_convert | ) | [inline, inherited] |
Specifies how source animation will be converted into egg structures.
The default is AC_none, which means animation tables will be ignored. This is only meaningful for converters that understand animation.
Definition at line 87 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_character_name | ( | const string & | character_name | ) | [inline, inherited] |
Specifies the name of the character generated.
This name should match between all the model and channel egg files for a particular character and its associated animations.
Definition at line 111 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_egg_data | ( | EggData * | egg_data | ) | [inherited] |
Sets the egg data that will be filled in when convert_file() is called.
This must be called before convert_file().
Definition at line 76 of file somethingToEggConverter.cxx.
Referenced by SomethingToEggConverter::clear_egg_data(), SoftToEggConverter::convert_soft(), and SomethingToEggConverter::handle_external_reference().
void SomethingToEggConverter::set_end_frame | ( | double | end_frame | ) | [inline, inherited] |
Specifies the ending frame of the animation to convert, in the units specified by set_input_frame_rate().
If this is unspecified, the ending frame is taken from the source, for instance from the last frame of the animation slider.
Definition at line 189 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_frame_inc | ( | double | frame_inc | ) | [inline, inherited] |
Specifies the increment between frames to extract.
This is the amount to increment the time slider (in units of internal_frame_rate) between extracting each frame. If this is not specified, the default is taken from the animation package, or 1.0 if the animation package does not specified a frame increment.
Definition at line 244 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_input_frame_rate | ( | double | input_frame_rate | ) | [inline, inherited] |
Specifies the number of frames per second that is represented by the "frame" unit in the animation package.
If this is omitted, it is taken from whatever the file header indicates. Some animation packages do not encode a frame rate, in which case the default if this is omitted is the same as the output frame rate.
Definition at line 348 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_merge_externals | ( | bool | merge_externals | ) | [inline, inherited] |
Sets the merge_externals flag.
When this is true, external references within the source file are read in and merged directly; otherwise, only a reference to a similarly-named egg file is inserted.
Definition at line 463 of file somethingToEggConverter.I.
void SomethingToEggConverter::set_neutral_frame | ( | double | neutral_frame | ) | [inline, inherited] |
Specifies the frame of animation to represent the neutral pose of the model.
Definition at line 294 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_output_frame_rate | ( | double | output_frame_rate | ) | [inline, inherited] |
Specifies the number of frames per second that the resulting animation should be played at.
If this is omitted, it is taken to be the same as the input frame rate.
Definition at line 399 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_path_replace | ( | PathReplace * | path_replace | ) | [inline, inherited] |
Replaces the PathReplace object (which specifies how to mangle paths from the source to the destination egg file) with a new one.
Definition at line 48 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void SomethingToEggConverter::set_start_frame | ( | double | start_frame | ) | [inline, inherited] |
Specifies the starting frame of the animation to convert, in the units specified by set_input_frame_rate().
If this is unspecified, the starting frame is taken from the source, for instance from the first frame of the animation slider.
Definition at line 136 of file somethingToEggConverter.I.
Referenced by SomethingToEgg::apply_parameters().
void XFileToEggConverter::strip_nodes | ( | TypeHandle | t | ) |
Removes all groups of the given type.
This is used to implement the -anim and -model options.
Definition at line 204 of file xFileToEggConverter.cxx.
References TypedObject::is_of_type().
Referenced by convert_file().
bool XFileToEggConverter::supports_compressed | ( | ) | const [virtual] |
Returns true if this file type can transparently load compressed files (with a .pz extension), false otherwise.
Reimplemented from SomethingToEggConverter.
Definition at line 108 of file xFileToEggConverter.cxx.