ObjectLoader
Availability LightWave 6.0
Component Layout, Modeler
Header lwobjimp.h
Object loaders read object files that aren't in LightWave's native object file format.
When an object loader's activation function is called, it should open the object file
and try to recognize its contents. LightWave calls all of the installed object loaders in
sequence until one of them recognizes the file. Each object loader is therefore
responsible for identifying the files it can load. If the file isn't one the loader
understands, the loader sets the result field of the local structure to LWOBJIM_NOREC
and returns AFUNC_OK.
If, on the other hand, the loader understands the object file, it reads the file and
submits its contents to the host through the functions provided in the local
structure.
Handler Activation Function
XCALL_( int ) MyObjImport( long version, GlobalFunc *global,
LWObjectImport *local, void *serverData );
The local argument to an object loader's activation function is an
LWObjectImport.
typedef struct st_LWObjectImport {
int result;
const char *filename;
LWMonitor *monitor;
char *failedBuf;
int failedLen;
void *data;
void (*done) (void *);
void (*layer) (void *, short int lNum, const char *name);
void (*pivot) (void *, const LWFVector pivot);
void (*parent) (void *, int lNum);
void (*lFlags) (void *, int flags);
LWPntID (*point) (void *, const LWFVector xyz);
void (*vmap) (void *, LWID type, int dim,
const char *name);
void (*vmapVal) (void *, LWPntID point, const float *val);
LWPolID (*polygon) (void *, LWID type, int flags, int numPts,
const LWPntID *);
void (*polTag) (void *, LWPolID polygon, LWID type,
const char *tag);
void (*surface) (void *, const char *, const char *, int,
void *);
void (*vmapPDV) (void *, LWPntID point, LWPolID polygon,
const float *val);
} LWObjectImport;
- result
- Set this to indicate whether the object was loaded successfully. The result codes are
LWOBJIM_OK
- The object was loaded successfully.
- LWOBJIM_NOREC
- The loader didn't recognize the file format. This can happen frequently, since all
loaders are called in sequence until one of them doesn't return this result.
- LWOBJIM_BADFILE
- The loader couldn't open the file. If the loader is able to open the file but believes
it has found an error in the contents, it should return IPSTAT_NOREC.
- LWOBJIM_ABORTED
- Use this to indicate that the user cancelled the load operation. This can happen if you
use the monitor to indicate the progress of a lengthy image loading operation..
- LWOBJIM_FAILED
- An error occurred during loading, for example a memory allocation failed.
filename
- The name of the file to load.
monitor
- A monitor for displaying the progress of the load to the user. You don't have to use
this, but you're encouraged to if your object loading takes an unusual amount of time.
This is the same structure as that returned by the monitor
global's create function.
failedBuf
failedLen
- These are used to display an error message to the user when object loading fails. Use strcpy
or a similar function to copy a single-line error string into failedBuf. failedLen
is the maximum size of this string, and it may be 0.
data
- An opaque pointer to data used internally by LightWave during object loading. Pass this
as the first argument to the loading functions.
done( data )
- Call this when object loading is complete, after setting the result field.
layer( data, layernum, layername )
- Create a new layer. All of the geometry you load will be put in this layer until you
call layer again. Even if your object format doesn't support anything that could
be interpreted as layers, this needs to be called at least once to initialize a layer that
will receive your geometry. The layer name is optional and can be NULL. Layers are
ordinarily created in increasing numerical order, starting at 1, but this isn't required.
pivot( data, pivpoint )
- Set the pivot point for the current layer. The pivot point is the origin for rotations
in the layer.
parent( data, layernum )
- Set the parent layer for the current layer. Layer parenting is a mechanism for creating
object hierarchies.
lFlags( data, layerflags )
- Set flags for the current layer. The only flag currently defined is the low order bit,
1 << 0, which when set signifies that the layer is hidden.
pointID = point( data, pos )
- Create a point in the current layer. Returns a point ID that can be used later to refer
to the point in polygon vertex lists.
vmap( data, type, dim, name )
- Create or select a vertex map. If the vmap doesn't exist, this function creates it.
Otherwise it selects the vmap for subsequent calls to vmapVal. The lwmeshes.h header defines common vmap IDs, but you can
create custom vmap types for special purposes.
LWVMAP_PICK - selection set
LWVMAP_WGHT - weight map
LWVMAP_MNVW - subpatch weight map
LWVMAP_TXUV - texture UV coordinates
LWVMAP_MORF - relative vertex displacement (morph)
LWVMAP_SPOT - absolute vertex displacement (morph)
LWVMAP_RGB, LWVMAP_RGBA - vertex color
The dimension of a vmap is just the number of values per point.
- vmapVal( data, point, valarray )
- Set the value of the current vmap for the point. The number of elements in the value
array should be the same as the dimension of the vmap.
polID = polygon( data, type, flags, npoints, point_array )
- Create a polygon in the current layer. The type will usually be one of the polygon types
defined in lwmeshes.h.
LWPOLTYPE_FACE -
face
LWPOLTYPE_CURV - higher order curve
LWPOLTYPE_PTCH - subdivision control cage polygon
LWPOLTYPE_MBAL - metaball
LWPOLTYPE_BONE - bone
The flags are specific to each type. The point array contains npoints point
IDs returned by calls to the point function.
- polTag( data, polygon, type, tag )
- Associate a tag string with a polygon. A polygon's surface is set, for example, by
passing LWPTAG_SURF as the type and the surface name as the tag. Note that you
can do this without first having called surface.
surface( data, basename, refname, chunk_size, surf_chunk )
- Set parameters for a surface. The base name is the name of the surface, while the
reference name is the name of a "parent" surface (which can be NULL). Parameters
not explicitly defined for the surface will be taken from its reference, or parent,
surface. The surface data is passed as the memory image of a LightWave object file SURF
chunk. See the object file format document for
a detailed description of the contents of a SURF chunk.
Note that this method
of specifying surface parameters doesn't allow you to associate envelopes or image
textures with a surface. In the SURF chunk, envelopes and images are referenced
by index into ENVL and CLIP chunks, respectively, and object loaders
have no way to create these.
- vmapPDV( data, point, polygon, valarray )
- Like vmapVal, but sets the per-polygon, or discontinuous, vmap vector for a
polygon vertex.
Example
The vidscape sample loads VideoScape ASCII object
files. Several examples of this simple format (the files with .geo extensions)
are included in the directory. The singular merit of the VideoScape format is that it's
easy to write, even by hand, but in particular using languages like LScript, Perl and
BASIC. The qbasic program that generated the ball.geo object is included. The
vidscape sample also demonstrates the use of a MeshDataEdit plug-in
to save objects in non-LightWave formats. |