Copy and adapt B-rep model
Detailed Description
-
group
a3d_copy_and_adapt_brep_model
Function Documentation
-
A3DStatus
A3DCopyAndAdaptBrepModel
(const A3DEntity *p, const A3DCopyAndAdaptBrepModelData *psSetting, A3DEntity **const pp) Copy and adapt B-rep parameters.
The B-rep used by HOOPS Exchange may not be completely compatible with modeling systems that do not support the full range of B-rep as employed by PRC. This function attempts to convert PRC B-rep into a format that is compatible with your system.
In order to use this function, you create a A3DCopyAndAdaptBrepModelData structure and configure it to create a new B-rep model using entities you are able to support. The function can transform predetermined surface types and curves to NURBS. It also can process parametric curves and 3D curves, as well as split periodic parametric surfaces.
Finally, it creates a new B-rep model. After using it, the new model should be deleted.
A3DCopyAndAdaptBrepModel will perform the following steps:
- For each face, the bearing surface and the 3D curves are converted
- Surfaces are reduced in size
- Cross-period UV curves are deleted if necessary
- Faces are split at periodic seams and/or mid-parameter for closed surfaces
- Final UV curves are computed
- A second surface shrink is performed with new UV parameters
- Final 3D curves are computed
Note
When the function A3DCopyAndAdaptBrepModel returns an error, you may try to set the parameters m_bSplitFaces and/or m_bForceComputeUV to ‘false’ and retry the conversion.
Parameters: - p – [in] A pointer to the source B-rep entity
- psSetting – [in] The structure that defines which types of B-rep you would like to convert to
- pp – [out] A pointer to the result B-rep entity or entities
Return values: - A3D_INVALID_ENTITY_TYPE –
- A3D_SRF_INVALID_PARAMETERS –
- A3D_CRV_INVALID_PARAMETER –
- A3D_ERROR –
- A3D_SUCCESS –
- A3D_INITIALIZE_BAD_VALUES –
- A3D_NOT_IMPLEMENTED –
- A3D_TOPO_VERTICES_MISSING –
- A3D_COEDGE_BAD_ORIENTATION_DATA –
- A3D_TOPO_GEOMETRY_MISSING –
- A3D_LOOP_BAD_ORIENTATION_DATA –
- A3D_SHELL_BAD_ORIENTATION_DATA –
- A3D_TOPO_WRONG_TOLERANCES –
- A3D_TOPO_CONSISTENCY –
- A3D_TOPO_NON_CONNEX_SHELL –
- A3D_TOPO_OPEN_SOLID –
- A3D_TOOLS_NURBSCONVERT_SURFACE_FAILURE –
- A3D_TOOLS_NURBSCONVERT_UV_FAILURE –
- A3D_TOOLS_NURBSCONVERT_3D_FAILURE –
- A3D_TOOLS_NURBSCONVERT_GENERAL_FAILURE –
- A3D_TOOLS_SPLIT_FAILURE –
- A3D_TOOLS_COMPUTE_UV_FAILURE –
- A3D_TOOLS_COMPUTE_3D_FAILURE –
- A3D_INVALID_ENTITY_NULL –
- A3D_EXCEPTION –
- A3D_BREPDATA_CANNOT_GETBOUNDINGBOX –
- A3D_INCOMPATIBLE_FUNCTION_WITH_KEEP_PARSED_ENTITY_MODE –
Returns: A3D_SUCCESS
on success, or an error code on failure
-
A3DStatus
A3DCopyAndAdaptBrepModelAdvanced
(const A3DEntity *p, const A3DCopyAndAdaptBrepModelData *psSetting, A3DEntity **const pp, A3DUns32 *puiNbErrors, A3DInt32 **paiErrors) Copy and adapt B-rep parameters.
Same as A3DCopyAndAdaptBrepModelData , but return status of each face in error if A3DCopyAndAdaptBrepModelData::m_bContinueOnError is set to true
puiNbErrors return the number of faces in error
paiErrors corresponds to a set of indexes and error codes
paiErrors[0] = type the topological element paiErrors[1] = error status paiErrors[2] = number of indexes to find element (connex = 1, shell = 2, face = 3, loop = 4, coedge /edge = 5) paiErrors[3] = first index ... paiErrors[2+paiErrors[2]] = last index
Parameters: - p – [in] A pointer to the source B-rep entity
- psSetting – [in] The structure that defines which types of B-rep you would like to convert to
- pp – [out] A pointer to the result B-rep entity or entities
- puiNbErrors – [out] Number of elements in error
- paiErrors – [out] Index and error code of each element
Return values: - A3D_INVALID_ENTITY_TYPE –
- A3D_SRF_INVALID_PARAMETERS –
- A3D_CRV_INVALID_PARAMETER –
- A3D_ERROR –
- A3D_SUCCESS –
- A3D_INITIALIZE_BAD_VALUES –
- A3D_NOT_IMPLEMENTED –
- A3D_TOPO_VERTICES_MISSING –
- A3D_COEDGE_BAD_ORIENTATION_DATA –
- A3D_TOPO_GEOMETRY_MISSING –
- A3D_LOOP_BAD_ORIENTATION_DATA –
- A3D_SHELL_BAD_ORIENTATION_DATA –
- A3D_TOPO_WRONG_TOLERANCES –
- A3D_TOPO_CONSISTENCY –
- A3D_TOPO_NON_CONNEX_SHELL –
- A3D_TOPO_OPEN_SOLID –
- A3D_TOOLS_NURBSCONVERT_SURFACE_FAILURE –
- A3D_TOOLS_NURBSCONVERT_UV_FAILURE –
- A3D_TOOLS_NURBSCONVERT_3D_FAILURE –
- A3D_TOOLS_NURBSCONVERT_GENERAL_FAILURE –
- A3D_TOOLS_SPLIT_FAILURE –
- A3D_TOOLS_COMPUTE_UV_FAILURE –
- A3D_TOOLS_COMPUTE_3D_FAILURE –
- A3D_INVALID_ENTITY_NULL –
- A3D_EXCEPTION –
- A3D_BREPDATA_CANNOT_GETBOUNDINGBOX –
- A3D_INCOMPATIBLE_FUNCTION_WITH_KEEP_PARSED_ENTITY_MODE –
Returns: A3D_SUCCESS
on success, or an error code on failure