Summary
OGRE (Object-Oriented Graphics Rendering Engine) is a
scene-oriented, flexible 3D engine written in C++ designed to make it
easier and more intuitive for developers to produce games and demos
utilising 3D hardware. The class library abstracts all the details of
using the underlying system libraries like Direct3D and OpenGL and
provides an interface based on world objects and other intuitive
classes.
This distribution contains the files required to export OGRE
.mesh, .skeleton and .material files from SoftImage|XSI. Currently supported XSI versions are 6.5 up to Softimage 2011
IMPORTANT: This exporter
only works with a full version
of XSI (Foundation or better). It will not work with the trial version.
How To Install
Features
How To Use
Using the Export Command
Tips
Change Log
How to Install
If you are using the installer, you don't need to do anything except
to run it and point it at your XSI folder. If you're installing from
source, you need to do the following:
- If 'OgreMain.dll' is included, copy it (and OgreMain_d.dll if you wish to use the
debug version anytime) into $(XSI_ROOT)\Application\bin
- copy OgreXSIExporter.dll into $(XSI_ROOT)\Application\plugins
Back To Top
Features
The following features are supported:
- Exporting selected PolygonMesh objects direct to the OGRE binary
.mesh format
- Exports vertex position, normals, multiple UV sets and vertex
colours
- Polygon clusters used to change materials in a single PolygonMesh
are exported as separate SubMeshes
- By default, separate PolygonMesh objects which use the same
material are merged for efficiency
- Mesh vertices are index-organised for efficiency
- Exporting of up to 4 weighted bone assignments per vertex
- Generation of edge lists, tangent vectors, and LOD levels during
export (optional)
- Exporting of deformers (bone chains, nulls used as deformers)
direct to binary .skeleton format
- Exporting animations from the mixer, sampled IK skeletal animation and shape animation (vertex animation)
- Exporting of RealTime shaders on materials (OpenGL and DirectX)
- Exporting meshes with subdivsion using the current subD level
- Hidden polygons won't be exported. To hide polygons, create a cluster with clsvisibility property by selecting polygons then click Model -> Property -> Polygon Cluster Visibility)
- Exporting directly from script (no GUI)
Back To Top
How To Use
It's a simple case of selecting the objects you wish to export, and
clicking File > Export > OGRE Mesh / Skeleton... to bring up the
OGRE export dialog.
The first page of the exporter is concerned with the basic mesh export
settings.
Object(s) to export: This
is pre-populated with your current selection
Mesh:
This is the .mesh file to export - you must complete this. Once
you have selected a file, by default the other file-related fields in
the exporter will be completed for you based on the same filename
pattern.
Merge
objects with the same material?: If this is checked, all
polygon mesh objects with the same material will be merged into one for
efficiency. Most of the time you want this; but if you want more
control over the splitting of your SubMesh objects, deselect it.
Calculate
Edge Lists: Select this if you want your mesh to support
stencil shadows. This increases the size of the resulting .mesh object.
Calculate
Tangents: Select this if you wish to use normal mapping
or some other technique which requires tangents vectors.
Levels
of Detail: Increase this value above 0 if you want lower
LODs to be generated for this mesh. The rest of the parameters control
how the mesh is reduced.
Export
Materials: Whether to export a .material script or not.
The field underneath contains the name of the script to export, and is
pre-populated based on the .mesh selection on the first page.
Material
Prefix: Optional prefix to give the name of each
material.
Copy
Textures To Folder: If selected, any textures referenced
in your materials will be copied into the same folder as the .material
script.
Export
Skeleton: If checked, skeleton and animation will be
exported. Cannot be selected if no skeleton is referenced by this mesh.
The field underneath determines the target.skeleton file (pre-populated
based on the mesh name).
Frames
per second: How to translate XSI frames into time
values. Will be populated based on XSI's playback speed, but you can
alter it if you wish.
Animations:
This is a list of animations, which should be pre-populated with
what you have in the Mixer, with splits between multiple animations
'best guessed' by the exporter, but you can tweak them afterwards. You
can alter all the fields in the table.
Export?:
A checkbox determining whether to export this animation
Name: The name of the
animation.
Start: The first frame of the animation
End: The last frame of the animation
Sample Freq:
Skeletal animation which is based on Inverse Kinematics (IK) or other
constraints needs to be 'sampled' to turn it into Forward Kinematics
(FK) in OGRE. This option determines the number of frames between each sample. For vertex animation, this is ignored.
Back To Top
Back To Top
Using the Export Command
It is now possible to automate the exporting process by using
'OgreMeshExportCommand' from a script in Softimage. Below is a list of parameters of that command:
- targetMeshFileName: Exported mesh file name (default: "c:/default.mesh")
- mergeSubmeshes: Merge objects with same material? If false, a separate named SubMesh will be created for every PolygonMesh preserving your model divisions. If true, the exporter will merge all PolygonMesh objects with the same material, which is more efficient, but does not preserve your modelling divisions. (default: true)
- exportChildren: If true, children of all selected objects will be exported.(default: true)
- calculateEdgeLists: Calculate Edge Lists (stencil shadows). (default: true)
- calculateTangents: Calculate Tangents (normal mapping). (default: false)
- tangentSemantic: Tangent semantic. True for tangent, false for texture coords. (default: true)
- tangentsSplitMirrored: Split tangents at UV mirror. (default: false)
- tangentsSplitRotated: Split tangents at UV rotation. (default: false)
- tangentsUseParity: 4D Tangents. (default: false)
- numLodLevels: Levels of Detail. (default: 0)
- lodDistanceIncrement: Distance Increment. (default: 2000)
- lodQuota: Reduction Style. True for percentage, false for constant. (default: true)
- lodReduction: Reduction Value. (default: 50)
- exportMaterials: Export Materials. (default: true)
- targetMaterialFileName: Material Filename. (default: "c:/default.material")
- materialPrefix: Material Prefix. (default: "")
- copyTextures: Copy Textures To Folder. (default: true)
- exportVertexAnimation: Export Vertex Animation. (default: true)
- exportSkeleton: Export Skeleton. (default: true)
- targetSkeletonFilename: Skeleton Filename. (default: "c:/default.skeleton")
- fps: Frames per second. (default: 24)
- animationList: List of animations to be exported. Use GridData to populate the values. (default: null)
Back To Top
Tips
Important modelling / animating considerations:
- The exporter writes one SubMesh per material if 'Merge objects
with the same material' is selected. If unselected, you get one SubMesh
per PolygonMesh (or clusters with differing materials within them)
- The exporter writes all your export settings into a custom
property in your scene, meaning that all your preferences are
remembered for this scene, even between loads.
- The exporter only exports PolygonMesh objects, so if you work
with higher-order surfaces like NURBS you must create a PolygonMesh
object from these surfaces before exporting
- The exporter writes a single .mesh at a time and combines all the
objects selected (and their children, if you select that option)
- All global modelling coordinates are preserved, so the origin of
your resulting .mesh will be where the world origin is in XSI
- Animations must be placed in the mixer to be picked up by the exporter
- The exporter automatically samples any skeletal IK animation and turns it in to FK,
optimising the animation as it does it to remove redundant keys and tracks.
- Shape animation should be expressed in shape reference mode
'Local' if you expect the results to work in combination with skeletal
animation. If you don't use skeletal animation, either 'Local' or
'Object' will work. You shouldn't use 'Absolute' mode.
- Make sure you remove any active shape key composition on the
modifier stack
for your meshes before exporting, they can mess up the initial base
state of the mesh as seen by the exporter, since the shape keys are
relative to the mesh before this composition.
Important material considerations:
- The defaults that XSI gives to some real time material components
are not normally what you'd want (and not the OGRE default). For
example:
- OGLDraw and DXDraw objects have a default culling mode of
'None', meaning all materials are double-sided by default, you will
probably want to change that for efficiency
- OGLTexture and DXTexture both default to no mip mapping. You
will probably want to alter the defaults so that you have at least
sampled point mipmapping (in DXTexture this is a separate setting, in
OGLTexture it's combined with the minification filter)
Back To Top
Change Log
1.7.0
- Fixed a bug causing the bounding box to be larger than it should when selecting multiple meshes for export
- Added subdivision support
- Hidden polygon clusters will now not be exported
- Added a command to export from the script without invoking the export dialog
1.4.6
- Fix a bug when using advanced rigs where there are extra animation components, previously these were stripped out.
- Default the file name parameters to the name of the object(s) selected
- Deal with omission of file extensions gracefully
- Keep mesh/skeleton/material file names in sync when changing the mesh
name in all cases
1.4.0
- Fixed pose animation for models not located at the origin
- XSI v6 supported
1.2.0RC2
- Fixed translation and scale animation in skeletons
- Fixed vertex colour export
- Animations which take the skeleton outside the original mesh bounds will now pad the mesh bounds automatically
1.1.0
- Shape animation support. You can now use the Shape Manager to
define shape keys, and then place them in animations in the mixer at
varying weights and combine them, e.g. to make facial animation. The
exporter creates 'pose' animation in OGRE from this.
- Animation is now picked up from the mixer, not directly from
action sources. This is to allow a consistent approach to both skeletal
and vertex animation. Multiple animations must be split up in timeline
start/end frame pairs.
1.0.6a
- Significant optimisation allowing larger meshes to be exported quicker (approx 15x faster per 1,000 faces than 1.0.6).
1.0.6
- Don't export clusters that become empty because triangles have been assigned to other clusters to customise material ID
- Fix vertex bone assignments on vertices on the boundary of multiple clusters
- Added XSI v5 support
1.0.5
- Fix export of multiple animations where initial pose is different
- Material prefix should apply to the exported .mesh as well as the .material
1.0.3
- Don't crash if textures are not found, just warn
instead.
- Trap cases where too many texture coordinate sets
are used and terminate with error, rather than crash
1.0.1c
- Added material exporting
- Added animation sampling (handle IK, other constraints seamlessly)
- Fixed vertex output format for software skinning
- Fixed a problem with translation keyframes
- Added optimisation of resulting animations (eliminate identity
tracks, collapse identical keyframes)
- Fixed frame -> time conversion with varying Action bases
- Reorganised GUI a little
- Deal with case-insensitive fcurve references
- Linux build fixes
Back To Top
Reporting Issues
Please report any issues with the exporter in the OGRE Forums.
Back To Top