Coin
4.0.3
Coin3D core library
|
SoSTLFileKit is a class for using STL files with Coin. More...
#include <ForeignFiles/SoSTLFileKit.h>
Public Types | |
enum | Colorization { GREY , MATERIALISE , TNO_VISICAM } |
Public Types inherited from SoNode | |
enum | NodeType { INVENTOR = 0x0000 , VRML1 = 0x0001 , VRML2 = 0x0002 , INVENTOR_1 = 0x0004 , INVENTOR_2_0 = 0x0008 , INVENTOR_2_1 = 0x0010 , INVENTOR_2_5 = 0x0020 , INVENTOR_2_6 = 0x0040 , COIN_1_0 = 0x0080 , COIN_2_0 = 0x0100 , EXTENSION = 0x0200 , COIN_2_2 = 0x0400 , COIN_2_3 = 0x0800 , COIN_2_4 = 0x1000 , INVENTOR_5_0 = 0x2000 , COIN_2_5 = 0x4000 , COIN_3_0 = 0x8000 , INVENTOR_6_0 = 0x10000 , COIN_4_0 = 0x20000 } |
Public Attributes | |
SoSFBool | binary |
SoSFEnum | colorization |
SoSFString | info |
Protected Attributes | |
SoSFNode | coordinates |
SoSFNode | facets |
SoSFNode | material |
SoSFNode | materialbinding |
SoSFNode | normalbinding |
SoSFNode | normals |
SoSFNode | shapehints |
SoSFNode | texture |
Protected Attributes inherited from SoForeignFileKit | |
SoSFNode | topSeparator |
Protected Attributes inherited from SoBaseKit | |
SoSFNode | callbackList |
SoChildList * | children |
SbBool | connectionsSetUp |
Protected Attributes inherited from SoNode | |
SbUniqueId | uniqueId |
Protected Attributes inherited from SoFieldContainer | |
SbBool | isBuiltIn |
Additional Inherited Members | |
Protected Types inherited from SoBase | |
enum | BaseFlags { IS_ENGINE = 0x01 , IS_GROUP = 0x02 } |
Static Protected Attributes inherited from SoNode | |
static int | nextActionMethodIndex = 0 |
static SbUniqueId | nextUniqueId = 1 |
SoSTLFileKit is a class for using STL files with Coin.
Class for using STL files with Coin. You can use it to read and write STL files, and convert back and forth between Open Inventor scene graphs and SoSTLFileKits.
STL files are 3D models intended for 3D printers, and is a format supported by a wide variety of computer-aided design programs. STL models are, because of their intended purpose, always representations of solid objects. STL is short for stereolithography, the process used for 3D printing.
Ordinary STL models do not contain color information. There are, however, two extensions to the binary file format for specifying color. Currently neither extension is supported. This is caused by lack of sample models using the extensions and will be added as soon as such models are found. We have the specs on the extensions, and it should be pretty straight-forwards to implement, but we want to get it right at once since we have write support (we don't want to inadvertently create a third color extension ;).
When writing STL files, certain STL model criteria are not enforced by SoSTLFileKit. These are:
Since the color extensions are not supported yet, color information is not collected either when converting Open Inventor scene graphs to SoSTLFileKits.
Be aware that this class is an extension for Coin, and it is not available in the original SGI Open Inventor v2.1 API.
SoSTLFileKit::SoSTLFileKit | ( | void | ) |
Constructor.
|
protectedvirtual |
Destructor.
|
protected |
Adds one triangle to the STL model.
Checks if this concrete class can read the given file.
Reimplemented from SoForeignFileKit.
Checks if this concrete class can write to the given file.
Reimplemented from SoForeignFileKit.
|
virtual |
Converts (if necessary) the internal representation of the foreign file to a pure Coin scenegraph. Returns the root node with a refcount of 0.
Implements SoForeignFileKit.
|
static |
Returns the nodekit catalog which defines the layout of this class' kit.
|
staticprotected |
Returns the pointer to the pointer of the nodekit catalog for this class.
This static method returns the SoType object associated with objects of this class.
|
protectedvirtual |
Returns a pointer to the class-wide field data storage object for this instance. If no fields are present, returns NULL
.
Reimplemented from SoForeignFileKit.
|
staticprotected |
This API member is considered internal to the library, as it is not likely to be of interest to the application programmer.
Returns the SoFieldData class which holds information about fields in this node.
|
virtual |
Returns the nodekit catalog which defines the layout of this class' kit.
Reimplemented from SoForeignFileKit.
Returns the type identification of an object derived from a class inheriting SoBase. This is used for runtime type checking and "downward" casting.
Reimplemented from SoForeignFileKit.
|
static |
Returns whether or not filename is identified as an STL file.
Should be called after the STL model is completely set up in the SoSTLFileKit through import from a file or from a scene graph. The model will then be optimized for fast rendering.
|
virtual |
Reads in an STL file. Both ASCII and binary files are supported. For binary files, the color extensions are not implemented yet.
Returns FALSE if filename could not be opened or parsed correctly.
Reimplemented from SoForeignFileKit.
SbBool SoSTLFileKit::readScene | ( | SoNode * | scene | ) |
Converts a scene graph into an SoSTLFileKit. Useful for creating STL files.
|
virtual |
Writes the STL model to an STL file.
Reimplemented from SoForeignFileKit.