man SoOutput () - used to write Inventor data files

NAME

SoOutput - used to write Inventor data files

INHERITS FROM

SoOutput

SYNOPSIS

#include <Inventor/SoOutput.h> c } c } SoOutputReallocCB(void *ptr, size_t newSize) Methods from class SoOutput: c } c } SoOutput()

c } c } ~SoOutput()

c } c } setFilePointer(FILE *newFP)

c } c } getFilePointer() const

c } c } openFile(const char *fileName)

c } c } closeFile()

c } c } setBuffer(void *bufPointer, size_t initSize, SoOutputReallocCB *reallocFunc, int32_t offset = 0)

c } c } getBuffer(void *&bufPointer, size_t &nBytes) const

c } c } getBufferSize() const

c } c } resetBuffer()

c } c } setBinary(SbBool flag)

c } c } isBinary() const

c } c } setHeaderString(const SbString &str)

c } c } resetHeaderString()

c } c } getDefaultASCIIHeader()

c } c } getDefaultBinaryHeader()

c } c } setFloatPrecision(int precision)

DESCRIPTION

This class is used for writing Inventor data files. It supports both ASCII (default) and binary formats and provides some convenience functions for handling files. It can also write to a buffer in memory as well as to a file pointer. A user-defined header can be specified for the output file. An instance of SoOutput is contained in an SoWriteAction; this is typically the only instance needed.

METHODS

c } c } SoOutput()

c } c } ~SoOutput()

Constructor and destructor. The default SoOutput writes to stdout. The destructor closes any files opened by the SoOutput. c } c } setFilePointer(FILE *newFP)

Sets file pointer to write to. c } c } getFilePointer() const

Returns the file pointer in use, or NULL if using a buffer. c } c } openFile(const char *fileName)

Opens named file, sets file pointer to result. This returns FALSE on error. c } c } closeFile()

Closes current file if opened with openFile(). c } c } setBuffer(void *bufPointer, size_t initSize, SoOutputReallocCB *reallocFunc, int32_t offset = 0)

Sets up memory buffer to write to, initial size, reallocation function (which is called if there is not enough room in the buffer), and offset in the buffer at which to begin writing. If the reallocation function returns NULL, writing will be disabled. c } c } getBuffer(void *&bufPointer, size_t &nBytes) const

Returns pointer to memory buffer being written to and the new size of the buffer. Returns FALSE if not writing into a buffer. c } c } getBufferSize() const

The total number of bytes allocated to a memory buffer may be larger than the number of bytes written. This returns that total number. c } c } resetBuffer()

Resets buffer for output again. Output starts over at beginning of buffer. c } c } setBinary(SbBool flag)

Sets whether output should be ASCII (default) or binary. c } c } isBinary() const

Returns current state of binary flag. c } c } setHeaderString(const SbString &str)

Sets the header for output files. This is useful, for example, if you have a file format that is a superset of the Inventor file format and you want Inventor to read the files. It is highly recommend that in your new header you simply append to the header of the Inventor file format you are extending. For example, if a new file format is based on the Inventor 2.1 file format, register a header similar to: "#Inventor V2.1 ascii MY FILE FORMAT EXTENSION" Then all Inventor 2.1 applications (and later) can read the file. c } c } resetHeaderString()

Resets the header for output files to be the default header. c } c } getDefaultASCIIHeader()

Returns the string representing the default ASCII header. c } c } getDefaultBinaryHeader()

Returns the string representing the default binary header. c } c } setFloatPrecision(int precision)

Sets the precision for writing floating point numbers, i.e. the number of significant digits. Floating point numbers are written using %.xg format, where 'x' is the value of the precision argument.

SEE ALSO

SoInput, SoWriteAction, SoTranSender