Model
Content
class |
CacheImpl |
class |
ModelImpl |
Functions
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
const char * |
|
const char * |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
bool |
|
void |
|
bool |
|
void |
|
bool |
|
void |
|
void |
|
double |
|
const char * |
|
const char * |
Detailed Description
-
class Model
The interface into a model. This class allows the definition of meshes, colors, matrices, instances, and other model data. It also provides means of modifying existing definitions. Querying of its name, model key, default camera, keys and many other aspects.
A model is closed when its destructor or cache.Close(model) is called.
In general operations on invalid keys or otherwise invalid usage will throw exceptions. Using try catch blocks around your code is advised.
A model has a default View, but unless a self include is created nothing will be visible when it is streamed. A model without a self include can be seen as an pure container for data, but unless it is included in some other model it is not directly viewable.
Consider a model containing a single instance of a sphere. If it was self included 4 times with different matrices then 4 spheres would be visible when the model is streamed and viewed. If it was included in a second model once, a single sphere would be visible in the second model.
Public Functions
-
~Model()
-
MeshKey Insert(MeshKeys const &meshes)
Insert a new definition into the model. This is a mesh selector with different mesh levels.
- Parameters
meshes – The MeshKeys. The index 0 is the highest representation and the Nth index is the lowest representation.
- Returns
A MeshKey.
-
MaterialKey Insert(Color const &color)
Insert a new definition into the model.
- Parameters
color – The Color.
- Returns
A MaterialKey.
-
MaterialKey Insert(Material const &material)
Insert a new definition into the model.
- Parameters
material – The Material.
- Returns
A MaterialKey.
-
LinePatternKey Insert(LinePattern const &line_pattern)
Insert a new definition into the model.
- Parameters
line_pattern – The Line Pattern.
- Returns
-
ImageKey Insert(uint32_t byte_count, uint8_t const *byte_data, ImageFormat format)
Insert a new definition into the model.
- Parameters
byte_count – The byte count.
byte_data – The image data of length byte_count.
format – The ImageFormat of the byte_data.
- Returns
An ImageKey.
-
ImageKey Insert(uint32_t width, uint32_t height, RGBA32 const *data)
Insert a new definition into the model.
-
ImageKey Insert(uint32_t width, uint32_t height, RGB24 const *data)
Insert a new definition into the model.
-
ImageKey Insert(uint32_t width, uint32_t height, Gray8 const *data)
Insert a new definition into the model.
-
ImageKey Insert(uint32_t width, uint32_t height, GrayAlpha16 const *data)
Insert a new definition into the model.
- Parameters
width – The image width.
width – The image height.
data – The GrayAlpha16 image data of length width * height.
- Returns
An ImageKey.
-
DataKey Insert(uint32_t byte_count, uint8_t const *byte_data, uint32_t priority = 0)
Insert a new definition into the model.
- Parameters
byte_count – The byte count.
byte_data – The bytes of length byte_count.
priority – The priority. Controls streaming order: 0 not sent by default - ~0 sent by request only and excluded from .scs; otherwise, highest first.
- Returns
A DataKey.
-
GroupKey Insert(InstanceIncs const &instance_incs, GroupIncs const &group_incs)
Insert a new definition into the model.
- Parameters
instance_incs – The InstanceIncs to insert.
group_incs – The GroupIncs to insert.
- Returns
A GroupKey.
-
MaterialMapKey Insert(MaterialKeys const &material_keys)
Insert a new definition into the model.
- Parameters
material_keys – The MaterialKeys to insert. These define a fully enumerated material map.
- Returns
-
MaterialMapKey Insert(MaterialMapElements const &material_map_elements)
Insert a new definition into the model.
- Parameters
material_map_elements – The MaterialMapElements to insert. These define a sparse material map.
- Returns
-
PolyPolygonKey Insert(uint32_t loop_count, uint32_t const *loop_counts, Point const *points)
Insert a new definition into the model.
- Parameters
loop_count – The loop count.
loop_counts – The counts for loop_count loops.
points – The points.
- Returns
-
ClipRegionKey Insert(ClipSubRegions const &clip_subregions)
Insert a new definition into the model.
- Parameters
key – clip_subregions ClipSubRegions to insert.
- Returns
-
MaterialKey FindOrInsert(Color const &color)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
- Parameters
color – The Color to match or insert.
- Returns
A MaterialKey.
-
MaterialKey FindOrInsert(Material const &material)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
- Parameters
material – The Material to match or insert.
- Returns
A MaterialKey.
-
MatrixKey FindOrInsert(Matrix3d const &matrix)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
-
MatrixKey FindOrInsert(DMatrix3d const &matrix)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
-
MaterialMapKey FindOrInsert(MaterialKeys const &material_keys)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
- Parameters
material_keys – The MaterialKeys to match or insert. These define a fully enumerated material map.
- Returns
-
MaterialMapKey FindOrInsert(MaterialMapElements const &material_map_elements)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
- Parameters
material_map_elements – The MaterialMapElements to match or insert. These define a sparse material map.
- Returns
-
PolyPolygonKey FindOrInsert(uint32_t loop_count, uint32_t const *loop_counts, Point const *points)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
- Parameters
loop_count – The loop count.
loop_counts – The counts for loop_count loops.
points – The points.
- Returns
-
ClipRegionKey FindOrInsert(ClipSubRegions const &clip_subregions)
Look up matching definition or insert if not found. Only definitions created using FindOrInsert are matchable. Helps create a more compact model if unique keying is not needed.
- Parameters
key – clip_subregions ClipSubRegions to match or insert.
- Returns
-
void Set(MeshKey key, MeshKeys const &meshes)
Replace the underlying definition for key.
- Parameters
key – The MeshKey to modify.
meshes – The replacement MeshKeys. The index 0 is the highest representation and the Nth index is the lowest representation.
-
void Set(MaterialKey key, Color const &color)
Replace the underlying definition for key.
- Parameters
key – The MaterialKey to modify.
color – The replacement Color.
-
void Set(MaterialKey key, Material const &material)
Replace the underlying definition for key.
- Parameters
key – The MaterialKey to modify.
material – The replacement Material.
-
void Set(ImageKey key, uint32_t byte_count, uint8_t const *byte_data, ImageFormat format)
Replace the underlying definition for key.
- Parameters
key – The ImageKey to modify.
byte_count – The replacement byte count.
byte_data – The replacement image data of length byte_count.
format – The replacement ImageFormat of the byte_data.
-
void Set(ImageKey key, uint32_t width, uint32_t height, RGBA32 const *data)
Replace the underlying definition for key.
-
void Set(ImageKey key, uint32_t width, uint32_t height, RGB24 const *data)
Replace the underlying definition for key.
-
void Set(ImageKey key, uint32_t width, uint32_t height, Gray8 const *data)
Replace the underlying definition for key.
-
void Set(ImageKey key, uint32_t width, uint32_t height, GrayAlpha16 const *data)
Replace the underlying definition for key.
- Parameters
key – The ImageKey to modify.
width – The replacement image width.
width – The replacement image height.
data – The replacement GrayAlpha16 image data of length width * height.
-
void Set(DataKey key, uint32_t byte_count, uint8_t const *byte_data)
Replace the underlying definition for key. The original priority is retained.
- Parameters
key – The DataKey to modify.
byte_count – The replacement byte count.
byte_data – The replacement bytes of length byte_count.
-
void Set(DataKey key, uint32_t byte_count, uint8_t const *byte_data, uint32_t priority)
Replace the underlying definition for key.
- Parameters
key – The DataKey to modify.
byte_count – The replacement byte count.
byte_data – The replacement bytes of length byte_count.
priority – The replacement priority. Controls streaming order: 0 not sent by default - ~0 sent by request only and excluded from .scs; otherwise, highest first.
-
void Set(GroupKey key, InstanceIncs const &instance_incs, GroupIncs const &group_incs)
Replace the underlying definition for key.
- Parameters
key – The GroupKey to modify.
instance_incs – The replacement InstanceIncs.
group_incs – The replacement GroupIncs.
-
void Set(MaterialMapKey key, MaterialKeys const &material_keys)
Replace the underlying definition for key.
- Parameters
key – The MaterialMapKey to modify.
material_keys – The replacement MaterialKeys. These define a fully enumerated material map.
-
void Set(MaterialMapKey key, MaterialMapElements const &material_map_elements)
Replace the underlying definition for key.
- Parameters
key – The MaterialMapKey to modify.
material_map_elements – The replacement MaterialMapElements. These define a sparse material map.
-
void Set(PolyPolygonKey key, uint32_t loop_count, uint32_t const *loop_counts, Point const *points)
Replace the underlying definition for key.
- Parameters
key – The PolyPolygonKey to modify.
loop_count – The replacement loop count.
loop_counts – The replacement counts for loop_count loops.
points – The replacement points.
-
void Set(ClipRegionKey key, ClipSubRegions const &clip_subregions)
Replace the underlying definition for key.
- Parameters
key – The ClipRegionKey to modify.
clip_subregions – The replacement ClipSubRegions.
-
InstanceKey Instance(MeshKey mesh, MatrixKey matrix = MatrixKey(), MaterialKey face_material = MaterialKey::Unspecified(), MaterialKey line_material = MaterialKey::Unspecified(), MaterialKey point_material = MaterialKey::Unspecified(), MaterialMapKey face_material_map = MaterialMapKey(), MaterialMapKey line_material_map = MaterialMapKey(), MaterialMapKey point_material_map = MaterialMapKey(), Visibility visibility = Visibility(), Modifiers modifiers = Modifiers(), ClipRegionKey clip_region = ClipRegionKey(), VectorCulling const &vector_culling = VectorCulling())
Creates an Instance of a mesh.
- Parameters
mesh – The MeshKey to instance.
matrix – The transform matrix for the instance. The default constructed MatrixKey is an identity matrix.
face_material – The MaterialKey for faces. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
line_material – The MaterialKey for lines. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
point_material – The MaterialKey for points. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
face_material_map – The MaterialMapKey for faces. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
line_material_map – The MaterialMapKey for lines. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
point_material_map – The MaterialMapKey for points. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
visibility – The Visibility. The default constructed Visibility is all on.
modifiers – The Modifiers. The default constructed Modifiers is none.
clip_region – The ClipRegionKey. The default constructed ClipRegionKey is none.
vector_culling – The VectorCulling setting. The default constructed VectorCulling is none.
- Returns
An InstanceKey.
-
InclusionKey Include(Model const &model, MatrixKey matrix = MatrixKey())
Include a model in this model’s views. May be a self inclusion. Inclusions present in the included model are not included, just the included model’s data.
- Parameters
- Returns
An InclusionKey.
-
void Set(InstanceKey key, MeshKey mesh)
Replace the mesh for an Instance.
- Parameters
key – The InstanceKey to modify.
mesh – The replacement MeshKey.
-
void Set(InstanceKey key, MatrixKey matrix)
Replace the matrix for an Instance.
- Parameters
key – The InstanceKey to modify.
matrix – The replacement MatrixKey.
-
void Set(InstanceKey key, VectorCulling const &vector_culling)
Replace the vector culling settings for an Instance.
- Parameters
key – The InstanceKey to modify.
vector_culling – The replacement VectorCulling setting.
-
void Set(InstanceKey key, MaterialKey face_material, MaterialKey line_material, MaterialKey point_material)
Replace the materials for an Instance.
- Parameters
key – The InstanceKey to modify.
face_material – The MaterialKey for faces. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
line_material – The MaterialKey for lines. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
point_material – The MaterialKey for points. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
-
void Set(InstanceKey key, MaterialMapKey face_material_map, MaterialMapKey line_material_map, MaterialMapKey point_material_map)
Replace the material maps for an Instance.
- Parameters
key – The InstanceKey to modify.
face_material_map – The MaterialMapKey for faces. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
line_material_map – The MaterialMapKey for lines. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
point_material_map – The MaterialMapKey for points. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
-
void Set(InstanceKey key, Visibility visibility)
Replace the visibility for an Instance.
- Parameters
key – The InstanceKey to modify.
visibility – The replacement Visibility.
-
void Set(InstanceKey key, Modifiers modifiers)
Replace the modifiers for an Instance.
- Parameters
key – The InstanceKey to modify.
modifiers – The replacement Modifiers.
-
void Set(InstanceKey key, ClipRegionKey clip_region)
Replace the clip region for an Instance.
- Parameters
key – The InstanceKey to modify.
clip_region – The replacement ClipRegionKey.
-
void Set(InstanceInc const &inc, MaterialKey face_material, MaterialKey line_material, MaterialKey point_material)
Override the materials for a specific InstanceInc.
- Parameters
inc – The InstanceInc to override.
face_material – The MaterialKey for faces. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
line_material – The MaterialKey for lines. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
point_material – The MaterialKey for points. If MaterialKey::Unspecified() is used then the mesh’s setting will be used.
-
void Set(InstanceInc const &inc, MaterialMapKey face_material_map, MaterialMapKey line_material_map, MaterialMapKey point_material_map)
Override the material maps for a specific InstanceInc.
- Parameters
inc – The InstanceInc to override.
face_material_map – The MaterialMapKey for faces. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
line_material_map – The MaterialMapKey for lines. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
point_material_map – The MaterialMapKey for points. If the default constructed MaterialMapKey is used the mesh’s setting will be used.
-
void Set(InstanceInc const &inc, Visibility visibility)
Override the visibility for a specific InstanceInc.
- Parameters
inc – The InstanceInc to override.
visibility – The override Visibility.
-
void Set(InstanceInc const &inc, Modifiers modifiers_to_add)
Add modifiers for a specific InstanceInc.
- Parameters
inc – The InstanceInc to add modifiers to.
modifiers_to_add – The additional Modifiers.
-
void Set(InstanceInc const &inc, ClipRegionKey clip_region)
Override clip region for a specific InstanceInc.
- Parameters
inc – The InstanceInc to override.
clip_region – The override ClipRegionKey.
-
void Delete(InclusionKey inclusion_key)
Remove an existing Inclusion from a model.
- Parameters
inclusion_key – The InclusionKey to remove.
-
void Delete(InstanceKey instance_key)
Remove an existing Instance from a model.
- Parameters
instance_key – The InstanceKey to remove.
-
void Delete(ViewKey view_key)
Remove an existing View from a model.
- Parameters
view_key – The ViewKey to remove.
-
ModelKey GetKey() const
Query the current ModelKey. ModelKeys are not stable values from one open model to another.
- Returns
A ModelKey.
-
const char *GetName() const
Query the name used by a model. The name is not sufficient to uniquely identify a model; use a path instead. Returned pointer is only valid until the next call.
- Returns
A pointer to a ‘C’ string with the UTF8 model name.
-
const char *GetPath() const
Query the file system path used by a model. Returned pointer is only valid until the next call.
- Returns
A pointer to a ‘C’ string with the UTF8 file system path.
-
void GetInstanceIncs(InstanceIncs &instance_incs) const
Query the InstanceIncs defined in a model.
- Parameters
instance_incs – A write back vector to return defined InstanceIncs.
-
void GetMeshIds(MeshIds &mesh_ids) const
Query the MeshIds defined in a model.
- Parameters
mesh_ids – A write back vector to return defined MeshIds.
-
void GetMaterialIds(MaterialIds &material_ids) const
Query the MaterialIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
material_ids – A write back vector to return defined MaterialIds.
-
void GetMatrixIds(MatrixIds &matrix_ids) const
Query the MatrixIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
matrix_ids – A write back vector to return defined MatrixIds.
-
void GetInstanceIds(InstanceIds &instance_ids) const
Query the InstanceIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
instance_ids – A write back vector to return defined InstanceIds.
-
void GetImageIds(ImageIds &image_ids) const
Query the ImageIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
image_ids – A write back vector to return defined ImageIds.
-
void GetDataIds(DataIds &data_ids) const
Query the DataIds defined in a model.
- Parameters
data_ids – A write back vector to return defined DataIds.
-
void GetGroupIds(GroupIds &group_ids) const
Query the GroupIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
group_ids – A write back vector to return defined GroupIds.
-
void GetMaterialMapIds(MaterialMapIds &material_map_ids) const
Query the MaterialMapIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
material_map_ids – A write back vector to return defined MaterialMapIds.
-
void GetPolyPolygonIds(PolyPolygonIds &polypolygon_ids) const
Query the PolyPolygonIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
polypolygon_ids – A write back vector to return defined PolyPolygonIds.
-
void GetClipRegionIds(ClipRegionIds &clip_region_ids) const
Query the ClipRegionIds defined in a model. Ids are not stable values from one open model to another.
- Parameters
clip_region_ids – A write back vector to return defined ClipRegionIds.
-
void GetMeshKeys(MeshKeys &mesh_keys) const
Query the MeshKeys defined in a model.
- Parameters
mesh_keys – A write back vector to return defined MeshKeys.
-
void GetMaterialKeys(MaterialKeys &material_keys) const
Query the MaterialKeys defined in a model.
- Parameters
material_keys – A write back vector to return defined MaterialKeys.
-
void GetMatrixKeys(MatrixKeys &matrix_keys) const
Query the MatrixKeys defined in a model.
- Parameters
matrix_keys – A write back vector to return defined MatrixKeys.
-
void GetInstanceKeys(InstanceKeys &instance_keys) const
Query the InstanceKeys defined in a model.
- Parameters
instance_keys – A write back vector to return defined InstanceKeys.
-
void GetImageKeys(ImageKeys &image_keys) const
Query the ImageKeys defined in a model.
- Parameters
image_keys – A write back vector to return defined ImageKeys.
-
void GetDataKeys(DataKeys &data_keys) const
Query the DataKeys defined in a model.
- Parameters
data_keys – A write back vector to return defined DataKeys.
-
void GetGroupKeys(GroupKeys &group_keys) const
Query the GroupKeys defined in a model.
- Parameters
group_keys – A write back vector to return defined GroupKeys.
-
void GetMaterialMapKeys(MaterialMapKeys &material_map_keys) const
Query the MaterialMapKeys defined in a model.
- Parameters
material_map_keys – A write back vector to return defined MaterialMapKeys.
-
void GetPolyPolygonKeys(PolyPolygonKeys &polypolygon_keys) const
Query the PolyPolygonKeys defined in a model.
- Parameters
polypolygon_keys – A write back vector to return defined PolyPolygonKeys.
-
void GetClipRegionKeys(ClipRegionKeys &clip_region_keys) const
Query the ClipRegionKeys defined in a model.
- Parameters
clip_region_keys – A write back vector to return defined ClipRegionKeys.
-
void Get(DataKey key, std::vector<uint8_t> &byte_data) const
Query the data associated with a DataKey.
- Parameters
key – The data to read
byte_data – The write back vector to return the associated data.
-
void Set(Camera const &camera, ViewKey view = ViewKey())
Set a views camera.
- Parameters
camera – The camera for the view.
view – The view to set the properties on. If unspecified the default view is used.
-
void Set(MaterialProperties const &material_properties, ViewKey view = ViewKey())
Set a views default material properties - these apply to all materials that do not have their own properties.
- Parameters
material_properties – The default properties for the view.
view – The view to set the properties on. If unspecified the default view is used.
-
bool Get(MaterialProperties &material_properties, ViewKey view = ViewKey())
Query a views default material properties.
- Parameters
material_properties – A write back value to return the MaterialProperties. Only valid if true is returned.
view – The view to query the properties on. If unspecified the default view is used.
- Returns
True if MaterialProperties have been set.
-
void Set(ViewKey view)
Set a new initial View. Only needed if more than one View exists.
- Parameters
view – The initial ViewKey.
-
bool Get(ViewKey &view)
Query an optional initial View. *
- Parameters
view – A write back value containing the initial ViewKey. Only valid if true is returned. *
- Returns
True if an optional View has been set.
-
void PrepareStream(CompressionStrategy compression_strategy = CompressionStrategy::Default)
Prepares this model for streaming. This should be done last when all data has been authored. *
- Parameters
compression_strategy – The strategy use to compress large meshes and images. Affects speed and output size
-
void ComputeBounding(Point &min, Point &max)
Compute the bounding for this model. This requires PrepareStream() has been called. If the stream has not been prepared an exception may be thrown.
-
double GetRootMeasurementUnit()
Returns the measurement unit of the root node in the model if any. Returns 0 if no measurement unit is set.
- Returns
The measurement unit of the root node.
-
const char *GenerateSCSFile(const char *utf8_scs_file_path = nullptr)
Generates an .scs file. Returned pointer is only valid until the next call.
- Parameters
utf8_scs_file_path – Specifies the full path and file name of the .scs file to generate include the .scs extension. If the utf8_scs_file_path is nullptr or empty a .scs file will be generated in the model directory with a default name.
- Returns
A pointer to a ‘C’ string UTF8 file system path of the generated .scs file.
-
const char *GenerateSCZFile(const char *utf8_scz_file_path = nullptr, bool include_derived = true, bool include_editable = true, bool create_bundled = false)
Generates an .scz file. Returned pointer is only valid until the next call. Using “include_derived = false” is not compatible with “include_editable = false” the resulting file is unusable and the call will throw. A bundled .scz can be streamed without decompression but will create a larger file and may only be opened read-only. A file created with “include_editable = false” can only be opened read-only.
- Parameters
utf8_scz_file_path – Specifies the full path and file name of the .scz file to generate include the .scz extension. If the utf8_scz_file_path is nullptr or empty a .scz file will be generated in the model directory with a default name.
include_derived – If true the .scz file will include the files needed from streaming.
include_editable – If true the .scz file will include the files needed for future editing.
create_bundled – If true the .scz file will be bundled rather than compressed.
- Returns
A pointer to a ‘C’ string UTF8 file system path of the generated .scz file.
Friends
- friend class TC::Store::CacheImpl
- friend class TC::Store::ModelImpl
-
~Model()