| SoVRVolFileReader Class | 
VOL file reader.
 Inheritance Hierarchy
Inheritance HierarchyNamespace: OIV.VolumeViz.Readers
 Syntax
SyntaxThe SoVRVolFileReader type exposes the following members.
 Constructors
Constructors| Name | Description | |
|---|---|---|
|  | SoVRVolFileReader | Constructor. | 
 Methods
Methods| Name | Description | |
|---|---|---|
|  | CloseAllHandles | 
Close all file handles currently opened by the reader.
(Inherited from SoVolumeReader.) | 
|  | CopyFieldValues(SoFieldContainer) | Calls CopyFieldValues(fc, false).(Inherited from SoFieldContainer.) | 
|  | CopyFieldValues(SoFieldContainer, Boolean) | Copies the contents of fc's fields into this object's fields. | 
|  | Dispose |  
Releases all resources used by SoDisposable.
(Inherited from SoDisposable.) | 
|  | EnableNotify | Notification at this Field Container is enabled (if flag == true) or disabled (if flag == false). | 
|  | Equals | Determines whether the specified Object is equal to the current Object.(Inherited from Object.) | 
|  | FieldsAreEqual | Returns true if this object's fields are exactly equal to fc's fields. | 
|  | Get | Returns the values of the fields of this object in the Open Inventor ASCII file format in the given string. | 
|  | GetAllFields | Returns a list of fields, including the eventIn's and eventOut's. | 
|  | GetBorderFlag | 
Returns border flag if stored in file.
(Inherited from SoVolumeReader.) | 
|  | GetConfiguredWriter | 
Returns a writer that correspond to this reader (same format, same parameters, etc...).
(Inherited from SoVolumeReader.) | 
|  | GetDataChar | (Overrides SoVolumeReaderGetDataChar(SbBox3f, SoDataSetDataTypes, SbVec3i32).) | 
|  | GetDirectCoordSys | 
Return whether the coordinate system used is direct or not.
(Inherited from SoVolumeReader.) | 
|  | GetDirectCoordSysAutoDetection | 
Return automatic detection value.
(Inherited from SoVolumeReader.) | 
|  | GetEventIn | Returns a the eventIn with the given name. | 
|  | GetEventOut | Returns the eventOut with the given name. | 
|  | GetField | Returns a the field of this object whose name is fieldName. | 
|  | GetFieldName | Returns the name of the given field in the fieldName argument. | 
|  | GetFields | Appends references to all of this object's fields to resultList, and returns the number of fields appended. | 
|  | GetHashCode | 
Overrides GetHashCode().
(Inherited from SoNetBase.) | 
|  | GetHistogram | 
Returns histogram if stored in file.
(Inherited from SoVolumeReader.) | 
|  | GetMinMax(Double, Double) | 
Returns min max if stored in file for float data type
(Inherited from SoVolumeReader.) | 
|  | GetMinMax(Int32, Int32) | 
Returns min max if stored in file (obsolete)
(Inherited from SoVolumeReader.) | 
|  | GetMinMax(Int64, Int64) | 
Returns min max if stored in file for integer data type
(Inherited from SoVolumeReader.) | 
|  | GetName | Returns the name of an instance. | 
|  | GetNumSignificantBits | 
This method is optional. It returns the number of significant bits of the volume data.
(Inherited from SoVolumeReader.) | 
|  | GetNumSubsampledTiles | 
Returns the number of data tiles that have been subsampled (non full resolution).
(Inherited from SoVolumeReader.) | 
|  | GetNumVoxels | Obsolete. 
Utility function provided by SoVolumeReader for subclass readers to call.
(Inherited from SoVolumeReader.) | 
|  | GetOriginalFilename | 
Returns original file name from which the data has been 
converted to LDM format if stored in file.
(Inherited from SoVolumeReader.) | 
|  | GetReaderType | 
Returns type of reader.
(Inherited from SoVolumeReader.) | 
|  | GetSizeToAllocate | Obsolete. 
Utility function provided by SoVolumeReader for subclass readers to call.
(Inherited from SoVolumeReader.) | 
|  | GetStringName | (Inherited from SoBase.) | 
|  | GetSubSlice(SbBox2i32, Int32, SbNativeArrayByte) | 
Method required by VolumeViz 3.0.
Must copy the rectangular part defined by subSlice of the XY slice sliceNumber
to the memory pointed to by data. 
Slices will not always be read sequentially.
(Inherited from SoVolumeReader.) | 
|  | GetSubSlice(SbBox2i32, Int32, SbNativeArray) | Obsolete. 
Obsolete method. Use generic version of data argument instead.
(Inherited from SoVolumeReader.) | 
|  | GetSubVolume | 
This method is optional.
If implemented, VolumeViz will use the data returned by the reader.
(Inherited from SoVolumeReader.) | 
|  | GetSubVolumeInfo | 
This method, if implemented, will be used by VolumeViz to know 
what the reader wants to do and what it is able to do.
(Inherited from SoVolumeReader.) | 
|  | GetTileMinMax | 
Returns the minimum and maximum data values for the given tile.
Used only if data is organized for the LDM module.
It allows to profit of optimizations such as SoLDMGlobalResourceParameters.setIgnoreFullyTransparentTiles().
Default implementation return new SbVec2d(System.Double.MaxValue, -System.Double.MaxValue))
(Inherited from SoVolumeReader.) | 
|  | GetTileSize | 
Returns tile size if using data stored in tiles. Return FALSE if data is not stored in tiles.
(Inherited from SoVolumeReader.) | 
|  | GetType | Gets the Type of the current instance.(Inherited from Object.) | 
|  | HasDefaultValues | Returns true if all of the object's fields have their default values. | 
|  | IsNotifyEnabled | Notification is the process of telling interested objects that this object has changed. | 
|  | IsSynchronizable | Gets the ScaleViz synchronizable state of this object. | 
|  | ReadTile(Int32, SbBox3i32) | 
Given an index, reads a tile if the data is organized in tiles (for LDM).
(Inherited from SoVolumeReader.) | 
|  | ReadTile(Int32, SbNativeArrayByte, SbBox3i32) | Obsolete. 
Given an index, reads a tile if the data is organized in tiles (for LDM).
In the default LDM architecture, the LDM data is based on an octree
topology (see SoVRLdmFileReader). The index passed is 0 for the tile
of lowest resolution representing the entire volume (octree root node).
The index increments linearly going down through the octree.
(Inherited from SoVolumeReader.) | 
|  | ReadTile(Int32, SbNativeByteArray, SbBox3i32) | Obsolete. 
Obsolete method. Use generic version of data argument instead.
(Inherited from SoVolumeReader.) | 
|  | Set | Sets one or more fields in this object to the values specified in the given string, which should be a string in the Open Inventor file format. | 
|  | SetDirectCoordSysAutoDetection | 
Sets whether or not the reader should automatically try to detect if the coordinate system
used is direct or not.
The function will return FALSE if the feature is not supported
by the current reader.
Default is false.
(Inherited from SoVolumeReader.) | 
|  | SetDirectCoorSys | 
Specify if the coordinate system used is direct or not.
The function will return FALSE if the feature is not supported
by the current reader.
Default is false.
(Inherited from SoVolumeReader.) | 
|  | SetFilename | 
Specifies the path of the file. Returns 0 for success. Any other return
value indicates failure.
(Inherited from SoVolumeReader.) | 
|  | SetName | (Inherited from SoBase.) | 
|  | SetOutputDataType | 
Sets the output data type. Returns FALSE if the reader does not support this feature.
(Inherited from SoVolumeReader.) | 
|  | SetSynchronizable | Sets this to be a ScaleViz synchronizable object. | 
|  | SetToDefaults | Sets all fields in this object to their default values. | 
|  | SetUserData |  
Stores the userData (for example the filename string) in the
m_data protected variable.
(Inherited from SoVolumeReader.) | 
|  | ToString | 
Converts this SoBase structure to a human readable string.
(Inherited from SoBase.) | 
|  | Touch | Marks an instance as modified, simulating a change to it. | 
 Properties
Properties| Name | Description | |
|---|---|---|
|  | DataConverted | 
The returned boolean indicates if the data is already organized for the LDM module.
If TRUE, VolumeViz will use the readTile method.
(Inherited from SoVolumeReader.) | 
|  | IsDisposable | ISafeDisposable interface implementation.
(Inherited from SoDisposable.) | 
|  | IsThreadSafe | 
Let the system know if the reader is thread safe or not.
this function is called by VolumeViz when using the multiIO mode.
(Inherited from SoVolumeReader.) | 
|  | UserData | 
Gets or sets the user data to be contained by the field container.
(Inherited from SoFieldContainer.) | 
 Remarks
RemarksVOL is a simple volume interchange format (see "Introduction to Volume Rendering", Lichtenbelt, Crane, Naqvi, 1998). The VolumeViz reader can load files containing 8- or 16-bit voxels.
The following is a slightly simplified description of the VOL file format.
All values in a VOL file are binary format, stored in "big-endian" order. In other words, values can used directly on most UNIX machines (SPARC, MIPS, PA-RISC, etc), but must be byte swapped on most Windows and Linux (X86) machines.
A VOL file consists of a variable length header followed by data values. The VolumeViz reader looks at the first seven or ten header values (depending on the value of magicNumber). All values in the header are 4 bytes long and are 32 bit integer or float as listed below. The header contains the total length of the header in bytes and the data values begin at this offset in the file. Data values are either 1 or 2 bytes long (8- or 16- bit integers). Data values are stored as a stack of images, in other words Z slices (X increasing fastest, then Y, then Z).
The header consists of:
magicNumber (int) should be 192837465 or 192837466
headerSize (int) in bytes
width (int) in voxels
height (int) in voxels
depth (int) in voxels
bitsPerVoxel (int) either 8 or 16 are valid
indexBits (int) not used
If "magicNumber" equals 192837466 (decimal) then header also contains three scale factors used to define nonuniform voxel spacing:
scaleX (float)
scaleY (float)
scaleZ (float)
 See Also
See Also