diff --git a/dox/FILES_HTML.txt b/dox/FILES_HTML.txt index 46e89cb7a2..5fbca28ed3 100644 --- a/dox/FILES_HTML.txt +++ b/dox/FILES_HTML.txt @@ -33,13 +33,13 @@ user_guides/user_guides.md user_guides/foundation_classes/foundation_classes.md user_guides/modeling_data/modeling_data.md user_guides/modeling_algos/modeling_algos.md +user_guides/mesh/mesh.md user_guides/shape_healing/shape_healing.md user_guides/visualization/visualization.md user_guides/iges/iges.md user_guides/step/step.md user_guides/xde/xde.md user_guides/ocaf/ocaf.md -user_guides/tobj/tobj.md user_guides/draw_test_harness/draw_test_harness.md user_guides/inspector/inspector.md user_guides/vis/vis.md diff --git a/dox/FILES_PDF.txt b/dox/FILES_PDF.txt index a26c0f7464..c7850a7006 100644 --- a/dox/FILES_PDF.txt +++ b/dox/FILES_PDF.txt @@ -4,21 +4,22 @@ # Empty spaces are allowed. # Strings starting with '#' are treated as comments and ignored. -specification/brep_wp/brep_wp.md +tutorial/tutorial.md + +upgrade/upgrade.md + user_guides/foundation_classes/foundation_classes.md -user_guides/iges/iges.md user_guides/modeling_data/modeling_data.md user_guides/modeling_algos/modeling_algos.md -specification/boolean_operations/boolean_operations.md -user_guides/shape_healing/shape_healing.md +user_guides/mesh/mesh.md user_guides/ocaf/ocaf.md -user_guides/step/step.md -user_guides/draw_test_harness/draw_test_harness.md -user_guides/inspector/inspector.md -user_guides/tobj/tobj.md user_guides/visualization/visualization.md -user_guides/xde/xde.md user_guides/vis/vis.md +user_guides/iges/iges.md +user_guides/step/step.md +user_guides/xde/xde.md +user_guides/inspector/inspector.md +user_guides/draw_test_harness/draw_test_harness.md contribution/contribution_workflow/contribution_workflow.md contribution/documentation/documentation.md @@ -26,7 +27,6 @@ contribution/coding_rules.md contribution/git_guide/git_guide.md contribution/tests/tests.md -upgrade/upgrade.md +specification/boolean_operations/boolean_operations.md +specification/brep_format.md specification/pbr_math.md - -tutorial/tutorial.md diff --git a/dox/introduction/introduction.md b/dox/introduction/introduction.md index e1b9c43f4a..d2df5501b6 100644 --- a/dox/introduction/introduction.md +++ b/dox/introduction/introduction.md @@ -281,7 +281,7 @@ Each sub-domain of Shape Healing has its own scope of functionality: | Customization | Modifies the shape representation to fit specific needs. | The shape is not modified, only the mathematical form of its internal representation is changed. | | Processing | Mechanism of shape modification via a user-editable resource file. | | -For more details, refer to @ref occt_shg "Shape Healing User's guide". +For more details, refer to @ref occt_user_guides__shape_healing "Shape Healing User's guide". @subsection intro_overview_ocaf Application Framework diff --git a/dox/user_guides/draw_test_harness/draw_test_harness.md b/dox/user_guides/draw_test_harness/draw_test_harness.md index 5104cfe955..255352e87c 100644 --- a/dox/user_guides/draw_test_harness/draw_test_harness.md +++ b/dox/user_guides/draw_test_harness/draw_test_harness.md @@ -6979,7 +6979,7 @@ sr is a shape COMPOUND FORWARD Free Modified The new algorithm of Boolean operations avoids a large number of weak points and limitations presented in the old Boolean operation algorithm. It also provides wider range of options and diagnostics. -The algorithms of Boolean component are fully described in the @ref specification__boolean_1 "Boolean Operations" of boolean operation user guide. +The algorithms of Boolean component are fully described in the @ref specification__boolean_operations "Boolean Operations" of boolean operation user guide. For the Draw commands to perform operations in Boolean component, read the dedicated section @ref occt_draw_bop "Boolean operations commands" @@ -11733,4 +11733,3 @@ The procedure consists in defining the system variables and using the *pload* co Draw[]> set env(CSF_MyDrawPluginDefaults) /users/test Draw[]> pload -MyDrawPlugin ALL ~~~~ - diff --git a/dox/user_guides/foundation_classes/foundation_classes.md b/dox/user_guides/foundation_classes/foundation_classes.md index 9a144a9080..45844ef7eb 100644 --- a/dox/user_guides/foundation_classes/foundation_classes.md +++ b/dox/user_guides/foundation_classes/foundation_classes.md @@ -7,7 +7,6 @@ Foundation Classes {#occt_user_guides__foundation_classes} This manual explains how to use Open CASCADE Technology (**OCCT**) Foundation Classes. It provides basic documentation on foundation classes. -For advanced information on foundation classes and their applications, see our E-learning & Training offerings. Foundation Classes provide a variety of general-purpose services such as automated dynamic memory management (manipulation of objects by handle), collections, exception handling, genericity by down-casting and plug-in creation. diff --git a/dox/user_guides/foundation_classes/images/foundation_classes_image004.png b/dox/user_guides/foundation_classes/images/foundation_classes_image004.png index 6d00d38d4a..9dfe2ac521 100644 Binary files a/dox/user_guides/foundation_classes/images/foundation_classes_image004.png and b/dox/user_guides/foundation_classes/images/foundation_classes_image004.png differ diff --git a/dox/user_guides/foundation_classes/images/foundation_classes_image005.png b/dox/user_guides/foundation_classes/images/foundation_classes_image005.png index 6ad4232577..a11addb082 100644 Binary files a/dox/user_guides/foundation_classes/images/foundation_classes_image005.png and b/dox/user_guides/foundation_classes/images/foundation_classes_image005.png differ diff --git a/dox/user_guides/foundation_classes/images/foundation_classes_image006.png b/dox/user_guides/foundation_classes/images/foundation_classes_image006.png index 6e920054ac..a57756d0a8 100644 Binary files a/dox/user_guides/foundation_classes/images/foundation_classes_image006.png and b/dox/user_guides/foundation_classes/images/foundation_classes_image006.png differ diff --git a/dox/user_guides/iges/iges.md b/dox/user_guides/iges/iges.md index 76654aa7d9..3e09800e06 100644 --- a/dox/user_guides/iges/iges.md +++ b/dox/user_guides/iges/iges.md @@ -1,4 +1,4 @@ -IGES Support {#occt_user_guides__iges} +IGES Translator {#occt_user_guides__iges} ================== @tableofcontents @@ -15,7 +15,7 @@ Other kinds of data such as colors and names can be read or written with the hel * an IGES entity is an entity in the IGES normal sense. * a root entity is the highest level entity of any given type, e.g. type 144 for surfaces and type 186 for solids. Roots are not referenced by other entities. -This manual mainly explains how to convert an IGES file to an Open CASCADE Technology (**OCCT**) shape and vice versa. It provides basic documentation on conversion. For advanced information on conversion, see our E-learning & Training offerings. +This manual mainly explains how to convert an IGES file to an Open CASCADE Technology (**OCCT**) shape and vice versa. It provides basic documentation on conversion. IGES files produced in accordance with IGES standard versions up to and including version 5.3 can be read. IGES files that are produced by this interface conform to IGES version 5.3 (Initial Graphics Exchange Specification, IGES 5.3. ANS US PRO/IPO-100-1996). diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image056.png b/dox/user_guides/mesh/images/modeling_algos_image056.png similarity index 100% rename from dox/user_guides/modeling_algos/images/modeling_algos_image056.png rename to dox/user_guides/mesh/images/modeling_algos_image056.png diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image057.png b/dox/user_guides/mesh/images/modeling_algos_image057.png similarity index 100% rename from dox/user_guides/modeling_algos/images/modeling_algos_image057.png rename to dox/user_guides/mesh/images/modeling_algos_image057.png diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_mesh_001.svg b/dox/user_guides/mesh/images/modeling_algos_mesh_001.svg similarity index 100% rename from dox/user_guides/modeling_algos/images/modeling_algos_mesh_001.svg rename to dox/user_guides/mesh/images/modeling_algos_mesh_001.svg diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_mesh_002.svg b/dox/user_guides/mesh/images/modeling_algos_mesh_002.svg similarity index 100% rename from dox/user_guides/modeling_algos/images/modeling_algos_mesh_002.svg rename to dox/user_guides/mesh/images/modeling_algos_mesh_002.svg diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_mesh_003.svg b/dox/user_guides/mesh/images/modeling_algos_mesh_003.svg similarity index 100% rename from dox/user_guides/modeling_algos/images/modeling_algos_mesh_003.svg rename to dox/user_guides/mesh/images/modeling_algos_mesh_003.svg diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_mesh_004.svg b/dox/user_guides/mesh/images/modeling_algos_mesh_004.svg similarity index 100% rename from dox/user_guides/modeling_algos/images/modeling_algos_mesh_004.svg rename to dox/user_guides/mesh/images/modeling_algos_mesh_004.svg diff --git a/dox/user_guides/mesh/mesh.md b/dox/user_guides/mesh/mesh.md new file mode 100644 index 0000000000..43976aae64 --- /dev/null +++ b/dox/user_guides/mesh/mesh.md @@ -0,0 +1,228 @@ +Mesh {#occt_user_guides__mesh} +========================= + +@tableofcontents + +@section occt_modalg_11_1 Mesh presentations + +In addition to support of exact geometrical representation of 3D objects Open CASCADE Technology provides functionality to work with tessellated representations of objects in form of meshes. + +Open CASCADE Technology mesh functionality provides: +- data structures to store surface mesh data associated to shapes, and some basic algorithms to handle these data +- data structures and algorithms to build surface triangular mesh from *BRep* objects (shapes). +- tools to extend 3D visualization capabilities of Open CASCADE Technology with displaying meshes along with associated pre- and post-processor data. + +Open CASCADE Technology includes two mesh converters: +- VRML converter translates Open CASCADE shapes to VRML 1.0 files (Virtual Reality Modeling Language). Open CASCADE shapes may be translated in two representations: shaded or wireframe. A shaded representation present shapes as sets of triangles computed by a mesh algorithm while a wireframe representation present shapes as sets of curves. +- STL converter translates Open CASCADE shapes to STL files. STL (STtereoLithography) format is widely used for rapid prototyping. + +Open CASCADE SAS also offers Advanced Mesh Products: +- Open CASCADE Mesh Framework (OMF) +- Express Mesh + +Besides, we can efficiently help you in the fields of surface and volume meshing algorithms, mesh optimization algorithms etc. If you require a qualified advice about meshing algorithms, do not hesitate to benefit from the expertise of our team in that domain. + +The projects dealing with numerical simulation can benefit from using SALOME - an Open Source Framework for CAE with CAD data interfaces, generic Pre- and Post- F.E. processors and API for integrating F.E. solvers. + +Learn more about SALOME platform on https://www.salome-platform.org + +@section occt_modalg_11_2 Meshing algorithm + +The algorithm of shape triangulation is provided by the functionality of *BRepMesh_IncrementalMesh* class, which adds a triangulation of the shape to its topological data structure. This triangulation is used to visualize the shape in shaded mode. + +~~~~~ +#include +#include +#include + +Standard_Boolean meshing_explicit_parameters() +{ + const Standard_Real aRadius = 10.0; + const Standard_Real aHeight = 25.0; + BRepPrimAPI_MakeCylinder aCylinder(aRadius, aHeight); + TopoDS_Shape aShape = aCylinder.Shape(); + + const Standard_Real aLinearDeflection = 0.01; + const Standard_Real anAngularDeflection = 0.5; + BRepMesh_IncrementalMesh aMesher (aShape, aLinearDeflection, Standard_False, anAngularDeflection, Standard_True); + const Standard_Integer aStatus = aMesher.GetStatusFlags(); + return !aStatus; +} + +Standard_Boolean meshing_imeshtools_parameters() +{ + const Standard_Real aRadius = 10.0; + const Standard_Real aHeight = 25.0; + BRepPrimAPI_MakeCylinder aCylinder(aRadius, aHeight); + TopoDS_Shape aShape = aCylinder.Shape(); + + IMeshTools_Parameters aMeshParams; + aMeshParams.Deflection = 0.01; + aMeshParams.Angle = 0.5; + aMeshParams.Relative = Standard_False; + aMeshParams.InParallel = Standard_True; + aMeshParams.MinSize = Precision::Confusion(); + aMeshParams.InternalVerticesMode = Standard_True; + aMeshParams.ControlSurfaceDeflection = Standard_True; + + BRepMesh_IncrementalMesh aMesher (aShape, aMeshParams); + const Standard_Integer aStatus = aMesher.GetStatusFlags(); + return !aStatus; +} +~~~~~ + +The default meshing algorithm *BRepMesh_IncrementalMesh* has two major options to define triangulation -- linear and angular deflections. + +At the first step all edges from a face are discretized according to the specified parameters. + +At the second step, the faces are tessellated. Linear deflection limits the distance between a curve and its tessellation, whereas angular deflection limits the angle between subsequent segments in a polyline. + +@figure{/user_guides/mesh/images/modeling_algos_image056.png,"Deflection parameters of BRepMesh_IncrementalMesh algorithm",420} + +There are additional options to control behavior of the meshing of face interior: *DeflectionInterior* and *AngleInterior*. *DeflectionInterior* limits the distance between triangles and the face interior. *AngleInterior* (used for tessellation of B-spline faces only) limits the angle between normals (N1, N2 and N3 in the picture) in the nodes of every link of the triangle. There is an exception for the links along the face boundary edges, "Angular Deflection" is used for them during edges discretization. + +@figure{/user_guides/mesh/images/modeling_algos_image057.png,"Linear and angular interior deflections",420} + +Note that if a given value of linear deflection is less than shape tolerance then the algorithm will skip this value and will take into account the shape tolerance. + +The application should provide deflection parameters to compute a satisfactory mesh. Angular deflection is relatively simple and allows using a default value (12-20 degrees). Linear deflection has an absolute meaning and the application should provide the correct value for its models. Giving small values may result in a too huge mesh (consuming a lot of memory, which results in a long computation time and slow rendering) while big values result in an ugly mesh. + +For an application working in dimensions known in advance it can be reasonable to use the absolute linear deflection for all models. This provides meshes according to metrics and precision used in the application (for example, it it is known that the model will be stored in meters, 0.004 m is enough for most tasks). + +However, an application that imports models created in other applications may not use the same deflection for all models. Note that actually this is an abnormal situation and this application is probably just a viewer for CAD models with dimensions varying by an order of magnitude. This problem can be solved by introducing the concept of a relative linear deflection with some LOD (level of detail). The level of detail is a scale factor for absolute deflection, which is applied to model dimensions. + +Meshing covers a shape with a triangular mesh. Other than hidden line removal, you can use meshing to transfer the shape to another tool: a manufacturing tool, a shading algorithm, a finite element algorithm, or a collision algorithm. + +You can obtain information on the shape by first exploring it. To access triangulation of a face in the shape later, use *BRepTool::Triangulation*. To access a polygon, which is the approximation of an edge of the face, use *BRepTool::PolygonOnTriangulation*. + +@section occt_modalg_11_3 BRepMesh Architecture +@subsection occt_modalg_11_3_1 Goals + +The main goals of the chosen architecture are: + * Remove tight connections between data structures, auxiliary tools and algorithms to create an extensible solution, easy for maintenance and improvements; + * Separate the code among several functional units responsible for specific operation for the sake of simplification of debugging and readability; + * Introduce new data structures enabling the possibility to manipulate a discrete model of a particular entity (edge, wire, face) in order to perform computations locally instead of processing the entire model; + * Implement a new triangulation algorithm replacing the existing functionality that contains overcomplicated solutions that need to be moved to the upper level. In addition, provide the possibility to change the algorithm depending on surface type (initially to speed up meshing of planes). + +@subsection occt_modalg_11_3_2 General workflow +@figure{/user_guides/mesh/images/modeling_algos_mesh_001.svg,"General workflow of BRepMesh component",500} + +Generally, the workflow of the component can be divided into six parts: + * **Creation of model data structure**: source *TopoDS_Shape* passed to algorithm is analyzed and exploded into faces and edges. The reflection corresponding to each topological entity is created in the data model. Note that underlying algorithms use the data model as input and access it via a common interface which allows creating a custom data model with necessary dependencies between particular entities (see the paragraph "Data model interface"); + * **Discretize edges 3D & 2D curves**: 3D curve as well as an associated set of 2D curves of each model edge is discretized in order to create a coherent skeleton used as a base in face meshing process. If an edge of the source shape already contains polygonal data which suits the specified parameters, it is extracted from the shape and stored in the model as is. Each edge is processed separately, the adjacency is not taken into account; + * **Heal discrete model**: the source *TopoDS_Shape* can contain problems, such as open wires or self-intersections, introduced during design, exchange or modification of model. In addition, some problems like self-intersections can be introduced by roughly discretized edges. This stage is responsible for analysis of a discrete model in order to detect and repair problems or to refuse further processing of a model part in case if a problem cannot be solved; + * **Preprocess discrete model**: defines actions specific to the implemented approach to be performed before meshing of faces. By default, this operation iterates over model faces, checks the consistency of existing triangulations and cleans topological faces and adjacent edges from polygonal data in case of inconsistency or marks a face of the discrete model as not required for the computation; + * **Discretize faces**: represents the core part performing mesh generation for a particular face based on 2D discrete data. This operation caches polygonal data associated with face edges in the data model for further processing and stores the generated mesh to *TopoDS_Face*; + * **Postprocess discrete model**: defines actions specific for the implemented approach to be performed after meshing of faces. By default, this operation stores polygonal data obtained at the previous stage to *TopoDS_Edge* objects of the source model. + +@subsection occt_modalg_11_3_3 Common interfaces +The component structure contains two units: IMeshData (see Data model interface) and IMeshTools, defining common interfaces for the data model and algorithmic tools correspondingly. Class *IMeshTools_Context* represents a connector between these units. The context class caches the data model as well as the tools corresponding to each of six stages of the workflow mentioned above and provides methods to call the corresponding tool safely (designed similarly to *IntTools_Context* in order to keep consistency with OCCT core tools). All stages, except for the first one, use the data model as input and perform a specific action on the entire structure. Thus, API class *IMeshTools_ModelAlgo* is defined in order to unify the interface of tools manipulating the data model. Each tool supposed to process the data model should inherit this interface enabling the possibility to cache it in context. In contrast to others, the model builder interface is defined by another class *IMeshTools_ModelBuilder* due to a different meaning of the stage. The entry point starting the entire workflow is represented by *IMeshTools_MeshBuilder*. + +The default implementation of *IMeshTools_Context* is given in *BRepMesh_Context* class initializing the context by instances of default algorithmic tools. + +The factory interface *IMeshTools_MeshAlgoFactory* gives the possibility to change the triangulation algorithm for a specific surface. The factory returns an instance of the triangulation algorithm via *IMeshTools_MeshAlgo* interface depending on the type of surface passed as parameter. It is supposed to be used at the face discretization stage. + +The default implementation of AlgoFactory is given in *BRepMesh_MeshAlgoFactory* returning algorithms of different complexity chosen according to the passed surface type. In its turn, it is used as the initializer of *BRepMesh_FaceDiscret* algorithm representing the starter of face discretization stage. + +@figure{/user_guides/mesh/images/modeling_algos_mesh_002.svg,"Interface describing entry point to meshing workflow",500} + +Remaining interfaces describe auxiliary tools: + * *IMeshTools_CurveTessellator*: provides a common interface to the algorithms responsible for creation of discrete polygons on 3D and 2D curves as well as tools for extraction of existing polygons from *TopoDS_Edge* allowing to obtain discrete points and the corresponding parameters on curve regardless of the implementation details (see examples of usage of derived classes *BRepMesh_CurveTessellator*, *BRepMesh_EdgeTessellationExtractor* in *BRepMesh_EdgeDiscret*); + * *IMeshTools_ShapeExplorer*: the last two interfaces represent visitor design pattern and are intended to separate iteration over elements of topological shape (edges and faces) from the operations performed on a particular element; + * *IMeshTools_ShapeVisitor*: provides a common interface for operations on edges and faces of the target topological shape. It can be used in couple with *IMeshTools_ShapeExplorer*. The default implementation available in *BRepMesh_ShapeVisitor* performs initialization of the data model. The advantage of such approach is that the implementation of *IMeshTools_ShapeVisitor* can be changed according to the specific data model whereas the shape explorer implementation remains the same. + +@subsection occt_modalg_11_3_4 Create model data structure +The data structures intended to keep discrete and temporary data required by underlying algorithms are created at the first stage of the meshing procedure. Generally, the model represents dependencies between entities of the source topological shape suitable for the target task. + +#### Data model interface +Unit IMeshData provides common interfaces specifying the data model API used on different stages of the entire workflow. Dependencies and references of the designed interfaces are given in the figure below. A specific interface implementation depends on the target application which allows the developer to implement different models and use custom low-level data structures, e.g. different collections, either NCollection or STL. *IMeshData_Shape* is used as the base class for all data structures and tools keeping the topological shape in order to avoid possible copy-paste. + +The default implementation of interfaces is given in BRepMeshData unit. The main aim of the default data model is to provide features performing discretization of edges in a parallel mode. Thus, curve, pcurve and other classes are based on STL containers and smart-pointers as far as NCollection does not provide thread-safety for some cases (e.g. *NCollection_Sequence*). In addition, it closely reflects topology of the source shape, i.e. the number of edges in the data model is equal to the number of edges in the source model; each edge contains a set of pcurves associated with its adjacent faces which allows creation of discrete polygons for all pcurves or the 3D curve of a particular edge in a separate thread. + +**Advantages**: +In case of necessity, the data model (probably with algorithms for its processing) can be easily substituted by another implementation supporting another kind of dependencies between elements. + +An additional example of a different data model is the case when it is not required to create a mesh with discrete polygons synchronized between adjacent faces, i.e. in case of necessity to speed up creation of a rough per-face tessellation used for visualization or quick computation only (the approach used in *XDEDRAW_Props*). + +@figure{/user_guides/mesh/images/modeling_algos_mesh_003.svg,"Common API of data model",500} + +#### Collecting data model +At this stage the data model is filled by entities according to the topological structure of the source shape. A default implementation of the data model is given in BRepMeshData unit and represents the model as two sets: a set of edges and a set of faces. Each face consists of one or several wires, the first of which always represents the outer wire, while others are internal. In its turn, each wire depicts the ordered sequence of oriented edges. Each edge is characterized by a single 3D curve and zero (in case of free edge) or more 2D curves associated with faces adjacent to this edge. Both 3D and 2D curves represent a set of pairs point-parameter defined in 3D and 2D space of the reference face correspondingly. An additional difference between a curve and a pcurve is that the latter has a reference to the face it is defined for. + +Model filler algorithm is represented by *BRepMesh_ShapeVisitor* class creating the model as a reflection to topological shape with help of *BRepMesh_ShapeExplorer* performing iteration over edges and faces of the target shape. Note that the algorithm operates on a common interface of the data model and creates a structure without any knowledge about the implementation details and underlying data structures. The entry point to collecting functionality is *BRepMesh_ModelBuilder* class. + +@subsection occt_modalg_11_3_5 Discretize edges 3D & 2D curves +At this stage only the edges of the data model are considered. Each edge is processed separately (with the possibility to run processing in multiple threads). The edge is checked for existing polygonal data. In case if at least one representation exists and suits the meshing parameters, it is recuperated and used as reference data for tessellation of the whole set of pcurves as well as 3D curve assigned to the edge (see *BRepMesh_EdgeTessellationExtractor*). Otherwise, a new tessellation algorithm is created and used to generate the initial polygon (see *BRepMesh_CurveTessellator*) and the edge is marked as outdated. In addition, the model edge is updated by deflection as well as recomputed same range, same parameter and degeneracy parameters. See *BRepMesh_EdgeDiscret* for implementation details. + +IMeshData unit defines interface *IMeshData_ParametersListArrayAdaptor*, which is intended to adapt arbitrary data structures to the *NCollection_Array1* container API. This solution is made to use both *NCollection_Array1* and *IMeshData_Curve* as the source for *BRepMesh_EdgeParameterProvider* tool intended to generate a consistent parametrization taking into account the same parameter property. + +@subsection occt_modalg_11_3_6 Heal discrete model +In general, this stage represents a set of operations performed on the entire discrete model in order to resolve inconsistencies due to the problems caused by design, translation or rough discretization. A different sequence of operations can be performed depending on the target triangulation algorithm, e.g. there are different approaches to process self-intersections – either to amplify edges discretization by decreasing the target precision or to split links at the intersection points. At this stage the whole set of edges is considered in aggregate and their adjacency is taken into account. A default implementation of the model healer is given in *BRepMesh_ModelHealer* which performs the following actions: + * Iterates over model faces and checks their wires for consistency, i.e. whether the wires are closed and do not contain self-intersections. The data structures are designed free of collisions, thus it is possible to run processing in a parallel mode; + * Forcibly connects the ends of adjacent edges in the parametric space, closing gaps between possible disconnected parts. The aim of this operation is to create a correct discrete model defined relatively to the parametric space of the target face taking into account connectivity and tolerances of 3D space only. This means that no specific computations are made to determine U and V tolerance; + * Registers intersections on edges forming the face shape. Two solutions are possible in order to resolve self-intersection: + * Decrease deflection of a particular edge and update its discrete model. After that the workflow "intersection check – amplification" is repeated up to 5 times. As the result, target edges contain a finer tessellation and meshing continues or the face is marked by *IMeshData_SelfIntersectingWire* status and refused from further processing; + * Split target edges by intersection point and synchronize the updated polygon with curve and remaining pcurves associated to each edge. This operation presents a more robust solution comparing to the amplification procedure with a guaranteed result, but it is more difficult for implementation from the point of view of synchronization functionality. + +@subsection occt_modalg_11_3_7 Preprocess discrete model +This stage implements actions to be performed before meshing of faces. Depending on target goals it can be changed or omitted. By default, *BRepMesh_ModelPreProcessor* implements the functionality checking topological faces for consistency of existing triangulation, i.e.: consistency with the target deflection parameter; indices of nodes referenced by triangles do not exceed the number of nodes stored in a triangulation. If the face fails some checks, it is cleaned from triangulation and its adjacent edges are cleaned from existing polygons. This does not affect a discrete model and does not require any recomputation as the model keeps tessellations for the whole set of edges despite consistency of their polygons. + +@subsection occt_modalg_11_3_8 Discretize faces +Discretization of faces is the general part of meshing algorithm. At this stage edges tessellation data obtained and processed on previous steps is used to form contours of target faces and passed as input to the triangulation algorithm. Default implementation is provided by *BRepMesh_FaceDiscret* class which represents a starter for triangulation algorithm. It iterates over faces available in the data model, creates an instance of the triangulation algorithm according to the type of surface associated with each face via *IMeshTools_MeshAlgoFactory* and executes it. Each face is processed separately, thus it is possible to process faces in a parallel mode. The class diagram of face discretization is given in the figure below. + +@figure{/user_guides/mesh/images/modeling_algos_mesh_004.svg,"Class diagram of face discrete stage",300} + +In general, face meshing algorithms have the following structure: + * *BRepMesh_BaseMeshAlgo* implements *IMeshTools_MeshAlgo* interface and the base functionality for inherited algorithms. The main goal of this class is to initialize an instance of *BRepMesh_DataStructureOfDelaun* as well as auxiliary data structures suitable for nested algorithms using face model data passed as input parameter. Despite implementation of triangulation algorithm this structure is currently supposed as common for OCCT. However, the user is free to implement a custom algorithm and supporting data structure accessible via *IMeshTools_MeshAlgo* interface, e.g. to connect a 3-rd party meshing tool that does not support *TopoDS_Shape* out of box. For this, such structure provides the possibility to distribute connectors to various algorithms in the form of plugins; + * *BRepMesh_DelaunayBaseMeshAlgo* and *BRepMesh_SweepLineMeshAlgo* classes implement core meshing functionality operating directly on an instance of *BRepMesh_DataStructureOfDelaun*. The algorithms represent mesh generation tools adding new points from the data structure to the final mesh; + * *BRepMesh_NodeInsertionMeshAlgo* class represents a wrapper intended to extend the algorithm inherited from *BRepMesh_BaseMeshAlgo* to enable the functionality generating surface nodes and inserting them into the structure. On this level, an instance of the classification tool is created and can be used to accept-reject internal nodes. In addition, computations necessary for scaling UV coordinates of points relatively to the range specified for the corresponding direction are performed. As far as both triangulation algorithms work on static data provided by the structure, new nodes are added at the initialization stage. Surface nodes are generated by an auxiliary tool called range splitter and passed as template parameter (see Range splitter); + * Classes *BRepMesh_DelaunayNodeInsertionMeshAlgo* and *BRepMesh_SweepLineNodeInsertionMeshAlgo* implement algorithm-specific functionality related to addition of internal nodes supplementing functionality provided by *BRepMesh_NodeInsertionMeshAlgo*; + * *BRepMesh_DelaunayDeflectionControlMeshAlgo* extends functionality of *BRepMesh_DelaunayNodeInsertionMeshAlgo* by additional procedure controlling deflection of generated triangles. + + + + + +BRepMesh provides user a way to switch default triangulation algorithm to a custom one, either implemented by user or available worldwide. There are three base classes that can be currently used to integrate 3rd-party algorithms: + +* *BRepMesh_ConstrainedBaseMeshAlgo* base class for tools providing generation of triangulations with constraints requiring no common processing by BRepMesh; +* *BRepMesh_CustomBaseMeshAlgo* provides the entry point for generic algorithms without support of constraints and supposed for generation of base mesh only. Constraint edges are processed using standard functionality provided by the component itself upon background mesh produced by 3rd-party solver; +* *BRepMesh_CustomDelaunayBaseMeshAlgo* contains initialization part for tools used by BRepMesh for checks or optimizations using results of 3rd-party algorithm. + +Meshing algorithms could be provided by implemeting *IMeshTools_MeshAlgoFactory* with related interfaces and passing it to *BRepMesh_Context::SetFaceDiscret()*. OCCT comes with two base 2D meshing algorithms: *BRepMesh_MeshAlgoFactory* (used by default) and *BRepMesh_DelabellaMeshAlgoFactory*. + +The following example demonstrates how it could be done from *Draw* environment: + +~~~~~ +psphere s 10 + +### Default Algo ### +incmesh s 0.0001 -algo default + +### Delabella Algo ### +incmesh s 0.0001 -algo delabella +~~~~~ + +The code snippet below shows passing a custom mesh factory to BRepMesh_IncrementalMesh: + +~~~~~ +IMeshTools_Parameters aMeshParams; +Handle(IMeshTools_Context) aContext = new BRepMesh_Context(); +aContext->SetFaceDiscret (new BRepMesh_FaceDiscret (new BRepMesh_DelabellaMeshAlgoFactory())); + +BRepMesh_IncrementalMesh aMesher; +aMesher.SetShape (aShape); +aMesher.ChangeParameters() = aMeshParams; + +aMesher.Perform (aContext); +~~~~~ + +#### Range splitter +Range splitter tools provide functionality to generate internal surface nodes defined within the range computed using discrete model data. The base functionality is provided by *BRepMesh_DefaultRangeSplitter* which can be used without modifications in case of planar surface. The default splitter does not generate any internal node. + +*BRepMesh_ConeRangeSplitter*, *BRepMesh_CylinderRangeSplitter* and *BRepMesh_SphereRangeSplitter* are specializations of the default splitter intended for quick generation of internal nodes for the corresponding type of analytical surface. + +*BRepMesh_UVParamRangeSplitter* implements base functionality taking discretization points of face border into account for node generation. Its successors BRepMesh_TorusRangeSplitter and *BRepMesh_NURBSRangeSplitter* extend the base functionality for toroidal and NURBS surfaces correspondingly. + +@subsection occt_modalg_11_3_9 Postprocess discrete model +This stage implements actions to be performed after meshing of faces. Depending on target goals it can be changed or omitted. By default, *BRepMesh_ModelPostProcessor* commits polygonal data stored in the data model to *TopoDS_Edge*. \ No newline at end of file diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image003.png b/dox/user_guides/modeling_algos/images/modeling_algos_image003.png index d3ee059e52..6d51f6e72b 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image003.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image003.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image004.png b/dox/user_guides/modeling_algos/images/modeling_algos_image004.png index 6b371fb255..de827453c3 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image004.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image004.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image014.png b/dox/user_guides/modeling_algos/images/modeling_algos_image014.png index 42bf360518..2820ffa093 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image014.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image014.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image015.png b/dox/user_guides/modeling_algos/images/modeling_algos_image015.png index 7ff604a603..ea9bebb18d 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image015.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image015.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image016.png b/dox/user_guides/modeling_algos/images/modeling_algos_image016.png index 2e1367d331..919d1dcfe7 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image016.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image016.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image017.png b/dox/user_guides/modeling_algos/images/modeling_algos_image017.png index 88e0101e49..c56ae77fd2 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image017.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image017.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image021.png b/dox/user_guides/modeling_algos/images/modeling_algos_image021.png index d390c72d98..54bd1b6457 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image021.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image021.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image023.png b/dox/user_guides/modeling_algos/images/modeling_algos_image023.png index 505d403a5f..42061ea6d9 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image023.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image023.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image028.png b/dox/user_guides/modeling_algos/images/modeling_algos_image028.png index d93ccea447..072eb71bab 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image028.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image028.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image030.png b/dox/user_guides/modeling_algos/images/modeling_algos_image030.png index 7ce050d437..bd23d61bb9 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image030.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image030.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image035.png b/dox/user_guides/modeling_algos/images/modeling_algos_image035.png index df85effd0c..1a5f60f6b1 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image035.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image035.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image037.gif b/dox/user_guides/modeling_algos/images/modeling_algos_image037.gif new file mode 100644 index 0000000000..4693c9cbf0 Binary files /dev/null and b/dox/user_guides/modeling_algos/images/modeling_algos_image037.gif differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image040.png b/dox/user_guides/modeling_algos/images/modeling_algos_image040.png index 6a44f40111..b72cd4ce9b 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image040.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image040.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image041.png b/dox/user_guides/modeling_algos/images/modeling_algos_image041.png index 281438243a..263b4b3378 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image041.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image041.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image043.png b/dox/user_guides/modeling_algos/images/modeling_algos_image043.png index 31c47f92f7..504d71726c 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image043.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image043.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image045.png b/dox/user_guides/modeling_algos/images/modeling_algos_image045.png index 8ab7eba802..d9c5dfb7d2 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image045.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image045.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image047.png b/dox/user_guides/modeling_algos/images/modeling_algos_image047.png index 784681e85e..f0c0b1472f 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image047.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image047.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image048.png b/dox/user_guides/modeling_algos/images/modeling_algos_image048.png index 5f9a7369f4..a35fc4bd39 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image048.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image048.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image049.png b/dox/user_guides/modeling_algos/images/modeling_algos_image049.png index 746e721f0a..ec330cc88d 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image049.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image049.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image051.png b/dox/user_guides/modeling_algos/images/modeling_algos_image051.png index f52a14560c..c0eb80ee61 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image051.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image051.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_algos_image058.png b/dox/user_guides/modeling_algos/images/modeling_algos_image058.png index 6d96ab4d51..61179be280 100644 Binary files a/dox/user_guides/modeling_algos/images/modeling_algos_image058.png and b/dox/user_guides/modeling_algos/images/modeling_algos_image058.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_data_image003.png b/dox/user_guides/modeling_algos/images/modeling_data_image003.png new file mode 100644 index 0000000000..593342d591 Binary files /dev/null and b/dox/user_guides/modeling_algos/images/modeling_data_image003.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_data_image014.png b/dox/user_guides/modeling_algos/images/modeling_data_image014.png new file mode 100644 index 0000000000..801244f8e0 Binary files /dev/null and b/dox/user_guides/modeling_algos/images/modeling_data_image014.png differ diff --git a/dox/user_guides/modeling_algos/images/modeling_data_image015.png b/dox/user_guides/modeling_algos/images/modeling_data_image015.png new file mode 100644 index 0000000000..6f98d72fe3 Binary files /dev/null and b/dox/user_guides/modeling_algos/images/modeling_data_image015.png differ diff --git a/dox/user_guides/modeling_algos/modeling_algos.md b/dox/user_guides/modeling_algos/modeling_algos.md index 20734055b0..b763132d32 100644 --- a/dox/user_guides/modeling_algos/modeling_algos.md +++ b/dox/user_guides/modeling_algos/modeling_algos.md @@ -5,7 +5,7 @@ Modeling Algorithms {#occt_user_guides__modeling_algos} @section occt_modalg_1 Introduction -This manual explains how to use the Modeling Algorithms. It provides basic documentation on modeling algorithms. For advanced information on Modeling Algorithms, see our E-learning & Training offerings. +This manual explains how to use the Modeling Algorithms. It provides basic documentation on modeling algorithms. The Modeling Algorithms module brings together a wide range of topological algorithms used in modeling. Along with these tools, you will find the geometric algorithms, which they call. @@ -28,7 +28,7 @@ The Intersections component is used to compute intersections between 2D or 3D ge The *Geom2dAPI_InterCurveCurve* class allows the evaluation of the intersection points (*gp_Pnt2d*) between two geometric curves (*Geom2d_Curve*) and the evaluation of the points of self-intersection of a curve. -@figure{/user_guides/modeling_algos/images/modeling_algos_image003.png,"Intersection and self-intersection of curves",420} +@figure{/user_guides/modeling_algos/images/modeling_algos_image003.png,"Intersection and self-intersection of curves",300} In both cases, the algorithm requires a value for the tolerance (Standard_Real) for the confusion between two points. The default tolerance value used in all constructors is *1.0e-6.* @@ -1050,342 +1050,6 @@ Handle(Geom_Curve) C3d = GeomAPI::To3d(C2d, Pln); ~~~~~ -@section occt_modalg_2_topo_tools Topological Tools - -Open CASCADE Technology topological tools provide algorithms to - * Create wires from edges; - * Create faces from wires; - * Compute state of the shape relatively other shape; - * Orient shapes in container; - * Create new shapes from the existing ones; - * Build PCurves of edges on the faces; - * Check the validity of the shapes; - * Take the point in the face; - * Get the normal direction for the face. - - -@subsection occt_modalg_2_topo_tools_1 Creation of the faces from wireframe model - -It is possible to create the planar faces from the arbitrary set of planar edges randomly located in 3D space. -This feature might be useful if you need for instance to restore the shape from the wireframe model: - - - - - -
@figure{/user_guides/modeling_algos/images/modeling_algos_image062.png,"Wireframe model",160}@figure{/user_guides/modeling_algos/images/modeling_algos_image063.png,"Faces of the model",160}
- -To make the faces from edges it is, firstly, necessary to create planar wires from the given edges and than create planar faces from each wire. -The static methods *BOPAlgo_Tools::EdgesToWires* and *BOPAlgo_Tools::WiresToFaces* can be used for that: -~~~~~ -TopoDS_Shape anEdges = ...; /* The input edges */ -Standard_Real anAngTol = 1.e-8; /* The angular tolerance for distinguishing the planes in which the wires are located */ -Standard_Boolean bShared = Standard_False; /* Defines whether the edges are shared or not */ -// -TopoDS_Shape aWires; /* resulting wires */ -Standard_Integer iErr = BOPAlgo_Tools::EdgesToWires(anEdges, aWires, bShared, anAngTol); -if (iErr) { - cout << "Error: Unable to build wires from given edges\n"; - return; -} -// -TopoDS_Shape aFaces; /* resulting faces */ -Standard_Boolean bDone = BOPAlgo_Tools::WiresToFaces(aWires, aFaces, anAngTol); -if (!bDone) { - cout << "Error: Unable to build faces from wires\n"; - return; -} -~~~~~ - -These methods can also be used separately: - * *BOPAlgo_Tools::EdgesToWires* allows creating planar wires from edges. -The input edges may be not shared, but the output wires will be sharing the coinciding vertices and edges. For this the intersection of the edges is performed. -Although, it is possible to skip the intersection stage (if the input edges are already shared) by passing the corresponding flag into the method. -The input edges are expected to be planar, but the method does not check it. Thus, if the input edges are not planar, the output wires will also be not planar. -In general, the output wires are non-manifold and may contain free vertices, as well as multi-connected vertices. - * *BOPAlgo_Tools::WiresToFaces* allows creating planar faces from the planar wires. -In general, the input wires are non-manifold and may be not closed, but should share the coinciding parts. -The wires located in the same plane and completely included into other wires will create holes in the faces built from outer wires: - - - - - - -
@figure{/user_guides/modeling_algos/images/modeling_algos_image064.png,"Wireframe model",160}@figure{/user_guides/modeling_algos/images/modeling_algos_image065.png,"Two faces (red face has a hole)",160}
- - -@subsection occt_modalg_2_topo_tools_2 Classification of the shapes - -The following methods allow classifying the different shapes relatively other shapes: - * The variety of the *BOPTools_AlgoTools::ComputState* methods classify the vertex/edge/face relatively solid; - * *BOPTools_AlgoTools::IsHole* classifies wire relatively face; - * *IntTools_Tools::ClassifyPointByFace* classifies point relatively face. - -@subsection occt_modalg_2_topo_tools_3 Orientation of the shapes in the container - -The following methods allow reorienting shapes in the containers: - * *BOPTools_AlgoTools::OrientEdgesOnWire* correctly orients edges on the wire; - * *BOPTools_AlgoTools::OrientFacesOnShell* correctly orients faces on the shell. - -@subsection occt_modalg_2_topo_tools_4 Making new shapes - -The following methods allow creating new shapes from the existing ones: - * The variety of the *BOPTools_AlgoTools::MakeNewVertex* creates the new vertices from other vertices and edges; - * *BOPTools_AlgoTools::MakeSplitEdge* splits the edge by the given parameters. - -@subsection occt_modalg_2_topo_tools_5 Building PCurves - -The following methods allow building PCurves of edges on faces: - * *BOPTools_AlgoTools::BuildPCurveForEdgeOnFace* computes PCurve for the edge on the face; - * *BOPTools_AlgoTools::BuildPCurveForEdgeOnPlane* and *BOPTools_AlgoTools::BuildPCurveForEdgesOnPlane* allow building PCurves for edges on the planar face; - * *BOPTools_AlgoTools::AttachExistingPCurve* takes PCurve on the face from one edge and attach this PCurve to other edge coinciding with the first one. - -@subsection occt_modalg_2_topo_tools_6 Checking the validity of the shapes - -The following methods allow checking the validity of the shapes: - * *BOPTools_AlgoTools::IsMicroEdge* detects the small edges; - * *BOPTools_AlgoTools::ComputeTolerance* computes the correct tolerance of the edge on the face; - * *BOPTools_AlgoTools::CorrectShapeTolerances* and *BOPTools_AlgoTools::CorrectTolerances* allow correcting the tolerances of the sub-shapes. - * *BRepLib::FindValidRange* finds a range of 3d curve of the edge not covered by tolerance spheres of vertices. - -@subsection occt_modalg_2_topo_tools_7 Taking a point inside the face - -The following methods allow taking a point located inside the face: - * The variety of the *BOPTools_AlgoTools3D::PointNearEdge* allows getting a point inside the face located near the edge; - * *BOPTools_AlgoTools3D::PointInFace* allows getting a point inside the face. - -@subsection occt_modalg_2_topo_tools_8 Getting normal for the face - -The following methods allow getting the normal direction for the face/surface: - * *BOPTools_AlgoTools3D::GetNormalToSurface* computes the normal direction for the surface in the given point defined by UV parameters; - * *BOPTools_AlgoTools3D::GetNormalToFaceOnEdge* computes the normal direction for the face in the point located on the edge of the face; - * *BOPTools_AlgoTools3D::GetApproxNormalToFaceOnEdge* computes the normal direction for the face in the point located near the edge of the face. - - - -@section occt_modalg_3a The Topology API - -The Topology API of Open CASCADE Technology (**OCCT**) includes the following six packages: - * *BRepAlgoAPI* - * *BRepBuilderAPI* - * *BRepFilletAPI* - * *BRepFeat* - * *BRepOffsetAPI* - * *BRepPrimAPI* - -The classes provided by the API have the following features: - * The constructors of classes provide different construction methods; - * The class retains different tools used to build objects as fields; - * The class provides a casting method to obtain the result automatically with a function-like call. - -Let us use the class *BRepBuilderAPI_MakeEdge* to create a linear edge from two points. - -~~~~~ -gp_Pnt P1(10,0,0), P2(20,0,0); -TopoDS_Edge E = BRepBuilderAPI_MakeEdge(P1,P2); -~~~~~ - -This is the simplest way to create edge E from two points P1, P2, but the developer can test for errors when he is not as confident of the data as in the previous example. - -~~~~~ -#include -#include -#include -void EdgeTest() -{ -gp_Pnt P1; -gp_Pnt P2; -BRepBuilderAPI_MakeEdge ME(P1,P2); -if (!ME.IsDone()) -{ -// doing ME.Edge() or E = ME here -// would raise StdFail_NotDone -Standard_DomainError::Raise -(“ProcessPoints::Failed to createan edge”); -} -TopoDS_Edge E = ME; -} -~~~~~ - -In this example an intermediary object ME has been introduced. This can be tested for the completion of the function before accessing the result. More information on **error handling** in the topology programming interface can be found in the next section. - -*BRepBuilderAPI_MakeEdge* provides valuable information. For example, when creating an edge from two points, two vertices have to be created from the points. Sometimes you may be interested in getting these vertices quickly without exploring the new edge. Such information can be provided when using a class. The following example shows a function creating an edge and two vertices from two points. - -~~~~~ -void MakeEdgeAndVertices(const gp_Pnt& P1, -const gp_Pnt& P2, -TopoDS_Edge& E, -TopoDS_Vertex& V1, -TopoDS_Vertex& V2) -{ -BRepBuilderAPI_MakeEdge ME(P1,P2); -if (!ME.IsDone()) { -Standard_DomainError::Raise -(“MakeEdgeAndVerices::Failed to create an edge”); -} -E = ME; -V1 = ME.Vextex1(); -V2 = ME.Vertex2(); -~~~~~ - -The class *BRepBuilderAPI_MakeEdge* provides two methods *Vertex1* and *Vertex2*, which return two vertices used to create the edge. - -How can *BRepBuilderAPI_MakeEdge* be both a function and a class? It can do this because it uses the casting capabilities of C++. The *BRepBuilderAPI_MakeEdge* class has a method called Edge; in the previous example the line E = ME could have been written. - -~~~~~ -E = ME.Edge(); -~~~~~ - -This instruction tells the C++ compiler that there is an **implicit casting** of a *BRepBuilderAPI_MakeEdge* into a *TopoDS_Edge* using the *Edge* method. It means this method is automatically called when a *BRepBuilderAPI_MakeEdge* is found where a *TopoDS_Edge* is required. - -This feature allows you to provide classes, which have the simplicity of function calls when required and the power of classes when advanced processing is necessary. All the benefits of this approach are explained when describing the topology programming interface classes. - - -@subsection occt_modalg_3a_1 Error Handling in the Topology API - -A method can report an error in the two following situations: - * The data or arguments of the method are incorrect, i.e. they do not respect the restrictions specified by the methods in its specifications. Typical example: creating a linear edge from two identical points is likely to lead to a zero divide when computing the direction of the line. - * Something unexpected happened. This situation covers every error not included in the first category. Including: interruption, programming errors in the method or in another method called by the first method, bad specifications of the arguments (i.e. a set of arguments that was not expected to fail). - -The second situation is supposed to become increasingly exceptional as a system is debugged and it is handled by the **exception mechanism**. Using exceptions avoids handling error statuses in the call to a method: a very cumbersome style of programming. - -In the first situation, an exception is also supposed to be raised because the calling method should have verified the arguments and if it did not do so, there is a bug. For example, if before calling *MakeEdge* you are not sure that the two points are non-identical, this situation must be tested. - -Making those validity checks on the arguments can be tedious to program and frustrating as you have probably correctly surmised that the method will perform the test twice. It does not trust you. -As the test involves a great deal of computation, performing it twice is also time-consuming. - -Consequently, you might be tempted to adopt the highly inadvisable style of programming illustrated in the following example: - -~~~~~ -#include -try { -TopoDS_Edge E = BRepBuilderAPI_MakeEdge(P1,P2); -// go on with the edge -} -catch { -// process the error. -} -~~~~~ - -To help the user, the Topology API classes only raise the exception *StdFail_NotDone*. Any other exception means that something happened which was unforeseen in the design of this API. - -The *NotDone* exception is only raised when the user tries to access the result of the computation and the original data is corrupted. At the construction of the class instance, if the algorithm cannot be completed, the internal flag *NotDone* is set. This flag can be tested and in some situations a more complete description of the error can be queried. If the user ignores the *NotDone* status and tries to access the result, an exception is raised. - -~~~~~ -BRepBuilderAPI_MakeEdge ME(P1,P2); -if (!ME.IsDone()) { -// doing ME.Edge() or E = ME here -// would raise StdFail_NotDone -Standard_DomainError::Raise -(“ProcessPoints::Failed to create an edge”); -} -TopoDS_Edge E = ME; -~~~~~ - - -@subsection occt_modalg_hist History support - -All topological API algorithms support the history of shape modifications (or just History) for their arguments. -Generally, the history is available for the following types of sub-shapes of input shapes: -* Vertex; -* Edge; -* Face. - -Some algorithms also support the history for Solids. - -The history information consists of the following information: -* Information about Deleted shapes; -* Information about Modified shapes; -* Information about Generated shapes. - -The History is filled basing on the result of the operation. History cannot return any shapes not contained in the result. -If the result of the operation is an empty shape, all input shapes will be considered as Deleted and none will have Modified and Generated shapes. - -The history information can be accessed by the API methods: -* *Standard_Boolean IsDeleted(const TopoDS_Shape& theS)* - to check if the shape has been Deleted during the operation; -* *const TopTools_ListOfShape& Modified(const TopoDS_Shape& theS)* - to get the shapes Modified from the given shape; -* *const TopTools_ListOfShape& Generated(const TopoDS_Shape& theS)* - to get the shapes Generated from the given shape. - -@subsubsection occt_modalg_hist_del Deleted shapes - -The shape is considered as Deleted during the operation if all of the following conditions are met: -* The shape is a part of the argument shapes of the operation; -* The result shape does not contain the shape itself; -* The result shape does not contain any of the splits of the shape. - -For example, in the CUT operation between two intersecting solids all vertices/edges/faces located completely inside the Tool solid will be Deleted during the operation. - -@subsubsection occt_modalg_hist_mod Modified shapes - -The shape is considered as Modified during the operation if the result shape contains the splits of the shape, not the shape itself. The shape can be modified only into the shapes with the same dimension. -The splits of the shape contained in the result shape are Modified from the shape. -The Modified shapes are created from the sub-shapes of the input shapes and, generally, repeat their geometry. - -The list of Modified elements will contain only those contributing to the result of the operation. If the list is empty, the shape has not been modified and it is necessary to check if it has been Deleted. - -For example, after translation of the shape in any direction all its sub-shapes will be modified into their translated copies. - -@subsubsection occt_modalg_hist_gen Generated shapes - -The shapes contained in the result shape are considered as Generated from the input shape if they were produced during the operation and have a different dimension from the shapes from which they were created. - -The list of Generated elements will contain only those included in the result of the operation. If the list is empty, no new shapes have been Generated from the shape. - -For example, extrusion of the edge in some direction will create a face. This face will be generated from the edge. - -@subsubsection occt_modalg_hist_tool BRepTools_History - -*BRepTools_History* is the general History tool intended for unification of the histories of different algorithms. - -*BRepTools_History* can be created from any algorithm supporting the standard history methods *(IsDeleted(), Modified()* and *Generated())*: -~~~~ -// The arguments of the operation -TopoDS_Shape aS = ...; - -// Perform transformation on the shape -gp_Trsf aTrsf; -aTrsf.SetTranslationPart(gp_Vec(0, 0, 1)); -BRepBuilderAPI_Transform aTransformer(aS, aTrsf); // Transformation API algorithm -const TopoDS_Shape& aRes = aTransformer.Shape(); - -// Create the translation history object -TopTools_ListOfShape anArguments; -anArguments.Append(aS); -BRepTools_History aHistory(anArguments, aTransformer); -~~~~ - -*BRepTools_History* also allows merging histories. Thus, if you have two or more subsequent operations you can get one final history combined from histories of these operations: - -~~~~ -Handle(BRepTools_History) aHist1 = ...; // History of first operation -Handle(BRepTools_History) aHist2 = ...; // History of second operation -~~~~ - -It is possible to merge the second history into the first one: -~~~~ -aHist1->Merge(aHist2); -~~~~ - -Or create the new history keeping the two histories unmodified: -~~~~ -Handle(BRepTools_History) aResHistory = new BRepTools_History; -aResHistory->Merge(aHist1); -aResHistory->Merge(aHist2); -~~~~ - -The possibilities of Merging histories and history creation from the API algorithms allow providing easy History support for the new algorithms. - -@subsubsection occt_modalg_hist_draw DRAW history support - -DRAW History support for the algorithms is provided by three basic commands: -* *isdeleted*; -* *modified*; -* *generated*. - -For more information on the Draw History mechanism, refer to the corresponding chapter in the Draw users guide - @ref occt_draw_hist "History commands". - - @section occt_modalg_3 Standard Topological Objects The following standard topological objects can be created: @@ -1797,43 +1461,6 @@ Use *BRepBuilderAPI_MakeShell* class to build a Shell from a set of Faces. What The solid is a composite shape built not from a geometry, but by the assembly of shells. Use *BRepBuilderAPI_MakeSolid* class to build a Solid from a set of Shells. Its use is similar to the use of the MakeWire class: shells are added to the solid in the same way that edges are added to the wire in MakeWire. -@section occt_modalg_3b Object Modification - -@subsection occt_modalg_3b_1 Transformation -*BRepBuilderAPI_Transform* class can be used to apply a transformation to a shape (see class *gp_Trsf*). The methods have a boolean argument to copy or share the original shape, as long as the transformation allows (it is only possible for direct isometric transformations). By default, the original shape is shared. - -The following example deals with the rotation of shapes. - -~~~~~ - -TopoDS_Shape myShape1 = ...; -// The original shape 1 -TopoDS_Shape myShape2 = ...; -// The original shape2 -gp_Trsf T; -T.SetRotation(gp_Ax1(gp_Pnt(0.,0.,0.),gp_Vec(0.,0.,1.)), -2.*PI/5.); -BRepBuilderAPI_Transformation theTrsf(T); -theTrsf.Perform(myShape1); -TopoDS_Shape myNewShape1 = theTrsf.Shape() -theTrsf.Perform(myShape2,Standard_True); -// Here duplication is forced -TopoDS_Shape myNewShape2 = theTrsf.Shape() -~~~~~ - -@subsection occt_modalg_3b_2 Duplication - -Use the *BRepBuilderAPI_Copy* class to duplicate a shape. A new shape is thus created. -In the following example, a solid is copied: - -~~~~~ -TopoDS Solid MySolid; -....// Creates a solid - -TopoDS_Solid myCopy = BRepBuilderAPI_Copy(mySolid); -~~~~~ - - @section occt_modalg_4 Primitives The BRepPrimAPI package provides an API (Application Programming Interface) for construction of primitives such as: @@ -2053,7 +1680,10 @@ TopoDS_Solid R2 = BRepPrimAPI_MakeRevol(F,axis,ang); @figure{/user_guides/modeling_algos/images/modeling_algos_image035.png,"Full and partial rotation",420} -@section occt_modalg_5 Boolean Operations + + + +@section occt_modalg_5 Boolean Operations Boolean operations are used to create new shapes from the combinations of two groups of shapes. @@ -2114,14 +1744,305 @@ TopoDS_Shape S = BRepAlgoAPI_Cut(A,B); *BRepAlgoAPI_Section* performs the section, described as a *TopoDS_Compound* made of *TopoDS_Edge*. -@figure{/user_guides/modeling_algos/images/modeling_algos_image037.png,"Section operation",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_image037.png,"Section operation",220} ~~~~~ TopoDS_Shape A = ..., TopoDS_ShapeB = ...; TopoDS_Shape S = BRepAlgoAPI_Section(A,B); ~~~~~ -@section occt_modalg_6 Fillets and Chamfers + + + +@section occt_modalg_2_topo_tools Topological Tools + +Open CASCADE Technology topological tools provide algorithms to + * Create wires from edges; + * Create faces from wires; + * Compute state of the shape relatively other shape; + * Orient shapes in container; + * Create new shapes from the existing ones; + * Build PCurves of edges on the faces; + * Check the validity of the shapes; + * Take the point in the face; + * Get the normal direction for the face. + + +@subsection occt_modalg_2_topo_tools_1 Creation of the faces from wireframe model + +It is possible to create the planar faces from the arbitrary set of planar edges randomly located in 3D space. +This feature might be useful if you need for instance to restore the shape from the wireframe model: + +@figure{/user_guides/modeling_algos/images/modeling_algos_image062.png,"Wireframe model",160} +@figure{/user_guides/modeling_algos/images/modeling_algos_image063.png,"Faces of the model",160} + + +To make the faces from edges it is, firstly, necessary to create planar wires from the given edges and than create planar faces from each wire. +The static methods *BOPAlgo_Tools::EdgesToWires* and *BOPAlgo_Tools::WiresToFaces* can be used for that: +~~~~~ +TopoDS_Shape anEdges = ...; /* The input edges */ +Standard_Real anAngTol = 1.e-8; /* The angular tolerance for distinguishing the planes in which the wires are located */ +Standard_Boolean bShared = Standard_False; /* Defines whether the edges are shared or not */ +// +TopoDS_Shape aWires; /* resulting wires */ +Standard_Integer iErr = BOPAlgo_Tools::EdgesToWires(anEdges, aWires, bShared, anAngTol); +if (iErr) { + cout << "Error: Unable to build wires from given edges\n"; + return; +} +// +TopoDS_Shape aFaces; /* resulting faces */ +Standard_Boolean bDone = BOPAlgo_Tools::WiresToFaces(aWires, aFaces, anAngTol); +if (!bDone) { + cout << "Error: Unable to build faces from wires\n"; + return; +} +~~~~~ + +These methods can also be used separately: + * *BOPAlgo_Tools::EdgesToWires* allows creating planar wires from edges. +The input edges may be not shared, but the output wires will be sharing the coinciding vertices and edges. For this the intersection of the edges is performed. +Although, it is possible to skip the intersection stage (if the input edges are already shared) by passing the corresponding flag into the method. +The input edges are expected to be planar, but the method does not check it. Thus, if the input edges are not planar, the output wires will also be not planar. +In general, the output wires are non-manifold and may contain free vertices, as well as multi-connected vertices. + * *BOPAlgo_Tools::WiresToFaces* allows creating planar faces from the planar wires. +In general, the input wires are non-manifold and may be not closed, but should share the coinciding parts. +The wires located in the same plane and completely included into other wires will create holes in the faces built from outer wires: + +@figure{/user_guides/modeling_algos/images/modeling_algos_image064.png,"Wireframe model",160} +@figure{/user_guides/modeling_algos/images/modeling_algos_image065.png,"Two faces (red face has a hole)",160} + + + +@subsection occt_modalg_2_topo_tools_2 Classification of the shapes + +The following methods allow classifying the different shapes relatively other shapes: + * The variety of the *BOPTools_AlgoTools::ComputState* methods classify the vertex/edge/face relatively solid; + * *BOPTools_AlgoTools::IsHole* classifies wire relatively face; + * *IntTools_Tools::ClassifyPointByFace* classifies point relatively face. + +@subsection occt_modalg_2_topo_tools_3 Orientation of the shapes in the container + +The following methods allow reorienting shapes in the containers: + * *BOPTools_AlgoTools::OrientEdgesOnWire* correctly orients edges on the wire; + * *BOPTools_AlgoTools::OrientFacesOnShell* correctly orients faces on the shell. + +@subsection occt_modalg_2_topo_tools_4 Making new shapes + +The following methods allow creating new shapes from the existing ones: + * The variety of the *BOPTools_AlgoTools::MakeNewVertex* creates the new vertices from other vertices and edges; + * *BOPTools_AlgoTools::MakeSplitEdge* splits the edge by the given parameters. + +@subsection occt_modalg_2_topo_tools_5 Building PCurves + +The following methods allow building PCurves of edges on faces: + * *BOPTools_AlgoTools::BuildPCurveForEdgeOnFace* computes PCurve for the edge on the face; + * *BOPTools_AlgoTools::BuildPCurveForEdgeOnPlane* and *BOPTools_AlgoTools::BuildPCurveForEdgesOnPlane* allow building PCurves for edges on the planar face; + * *BOPTools_AlgoTools::AttachExistingPCurve* takes PCurve on the face from one edge and attach this PCurve to other edge coinciding with the first one. + +@subsection occt_modalg_2_topo_tools_6 Checking the validity of the shapes + +The following methods allow checking the validity of the shapes: + * *BOPTools_AlgoTools::IsMicroEdge* detects the small edges; + * *BOPTools_AlgoTools::ComputeTolerance* computes the correct tolerance of the edge on the face; + * *BOPTools_AlgoTools::CorrectShapeTolerances* and *BOPTools_AlgoTools::CorrectTolerances* allow correcting the tolerances of the sub-shapes. + * *BRepLib::FindValidRange* finds a range of 3d curve of the edge not covered by tolerance spheres of vertices. + +@subsection occt_modalg_2_topo_tools_7 Taking a point inside the face + +The following methods allow taking a point located inside the face: + * The variety of the *BOPTools_AlgoTools3D::PointNearEdge* allows getting a point inside the face located near the edge; + * *BOPTools_AlgoTools3D::PointInFace* allows getting a point inside the face. + +@subsection occt_modalg_2_topo_tools_8 Getting normal for the face + +The following methods allow getting the normal direction for the face/surface: + * *BOPTools_AlgoTools3D::GetNormalToSurface* computes the normal direction for the surface in the given point defined by UV parameters; + * *BOPTools_AlgoTools3D::GetNormalToFaceOnEdge* computes the normal direction for the face in the point located on the edge of the face; + * *BOPTools_AlgoTools3D::GetApproxNormalToFaceOnEdge* computes the normal direction for the face in the point located near the edge of the face. + + + +@section occt_modalg_3a The Topology API + +The Topology API of Open CASCADE Technology (**OCCT**) includes the following six packages: + * *BRepAlgoAPI* + * *BRepBuilderAPI* + * *BRepFilletAPI* + * *BRepFeat* + * *BRepOffsetAPI* + * *BRepPrimAPI* + +The classes provided by the API have the following features: + * The constructors of classes provide different construction methods; + * The class retains different tools used to build objects as fields; + * The class provides a casting method to obtain the result automatically with a function-like call. + +Let us use the class *BRepBuilderAPI_MakeEdge* to create a linear edge from two points. + +~~~~~ +gp_Pnt P1(10,0,0), P2(20,0,0); +TopoDS_Edge E = BRepBuilderAPI_MakeEdge(P1,P2); +~~~~~ + +This is the simplest way to create edge E from two points P1, P2, but the developer can test for errors when he is not as confident of the data as in the previous example. + +~~~~~ +#include +#include +#include +void EdgeTest() +{ +gp_Pnt P1; +gp_Pnt P2; +BRepBuilderAPI_MakeEdge ME(P1,P2); +if (!ME.IsDone()) +{ +// doing ME.Edge() or E = ME here +// would raise StdFail_NotDone +Standard_DomainError::Raise +(“ProcessPoints::Failed to createan edge”); +} +TopoDS_Edge E = ME; +} +~~~~~ + +In this example an intermediary object ME has been introduced. This can be tested for the completion of the function before accessing the result. More information on **error handling** in the topology programming interface can be found in the next section. + +*BRepBuilderAPI_MakeEdge* provides valuable information. For example, when creating an edge from two points, two vertices have to be created from the points. Sometimes you may be interested in getting these vertices quickly without exploring the new edge. Such information can be provided when using a class. The following example shows a function creating an edge and two vertices from two points. + +~~~~~ +void MakeEdgeAndVertices(const gp_Pnt& P1, +const gp_Pnt& P2, +TopoDS_Edge& E, +TopoDS_Vertex& V1, +TopoDS_Vertex& V2) +{ +BRepBuilderAPI_MakeEdge ME(P1,P2); +if (!ME.IsDone()) { +Standard_DomainError::Raise +(“MakeEdgeAndVerices::Failed to create an edge”); +} +E = ME; +V1 = ME.Vextex1(); +V2 = ME.Vertex2(); +~~~~~ + +The class *BRepBuilderAPI_MakeEdge* provides two methods *Vertex1* and *Vertex2*, which return two vertices used to create the edge. + +How can *BRepBuilderAPI_MakeEdge* be both a function and a class? It can do this because it uses the casting capabilities of C++. The *BRepBuilderAPI_MakeEdge* class has a method called Edge; in the previous example the line E = ME could have been written. + +~~~~~ +E = ME.Edge(); +~~~~~ + +This instruction tells the C++ compiler that there is an **implicit casting** of a *BRepBuilderAPI_MakeEdge* into a *TopoDS_Edge* using the *Edge* method. It means this method is automatically called when a *BRepBuilderAPI_MakeEdge* is found where a *TopoDS_Edge* is required. + +This feature allows you to provide classes, which have the simplicity of function calls when required and the power of classes when advanced processing is necessary. All the benefits of this approach are explained when describing the topology programming interface classes. + + +@subsection occt_modalg_hist History support + +All topological API algorithms support the history of shape modifications (or just History) for their arguments. +Generally, the history is available for the following types of sub-shapes of input shapes: +* Vertex; +* Edge; +* Face. + +Some algorithms also support the history for Solids. + +The history information consists of the following information: +* Information about Deleted shapes; +* Information about Modified shapes; +* Information about Generated shapes. + +The History is filled basing on the result of the operation. History cannot return any shapes not contained in the result. +If the result of the operation is an empty shape, all input shapes will be considered as Deleted and none will have Modified and Generated shapes. + +The history information can be accessed by the API methods: +* *Standard_Boolean IsDeleted(const TopoDS_Shape& theS)* - to check if the shape has been Deleted during the operation; +* *const TopTools_ListOfShape& Modified(const TopoDS_Shape& theS)* - to get the shapes Modified from the given shape; +* *const TopTools_ListOfShape& Generated(const TopoDS_Shape& theS)* - to get the shapes Generated from the given shape. + +@subsubsection occt_modalg_hist_del Deleted shapes + +The shape is considered as Deleted during the operation if all of the following conditions are met: +* The shape is a part of the argument shapes of the operation; +* The result shape does not contain the shape itself; +* The result shape does not contain any of the splits of the shape. + +For example, in the CUT operation between two intersecting solids all vertices/edges/faces located completely inside the Tool solid will be Deleted during the operation. + +@subsubsection occt_modalg_hist_mod Modified shapes + +The shape is considered as Modified during the operation if the result shape contains the splits of the shape, not the shape itself. The shape can be modified only into the shapes with the same dimension. +The splits of the shape contained in the result shape are Modified from the shape. +The Modified shapes are created from the sub-shapes of the input shapes and, generally, repeat their geometry. + +The list of Modified elements will contain only those contributing to the result of the operation. If the list is empty, the shape has not been modified and it is necessary to check if it has been Deleted. + +For example, after translation of the shape in any direction all its sub-shapes will be modified into their translated copies. + +@subsubsection occt_modalg_hist_gen Generated shapes + +The shapes contained in the result shape are considered as Generated from the input shape if they were produced during the operation and have a different dimension from the shapes from which they were created. + +The list of Generated elements will contain only those included in the result of the operation. If the list is empty, no new shapes have been Generated from the shape. + +For example, extrusion of the edge in some direction will create a face. This face will be generated from the edge. + +@subsubsection occt_modalg_hist_tool BRepTools_History + +*BRepTools_History* is the general History tool intended for unification of the histories of different algorithms. + +*BRepTools_History* can be created from any algorithm supporting the standard history methods *(IsDeleted(), Modified()* and *Generated())*: +~~~~ +// The arguments of the operation +TopoDS_Shape aS = ...; + +// Perform transformation on the shape +gp_Trsf aTrsf; +aTrsf.SetTranslationPart(gp_Vec(0, 0, 1)); +BRepBuilderAPI_Transform aTransformer(aS, aTrsf); // Transformation API algorithm +const TopoDS_Shape& aRes = aTransformer.Shape(); + +// Create the translation history object +TopTools_ListOfShape anArguments; +anArguments.Append(aS); +BRepTools_History aHistory(anArguments, aTransformer); +~~~~ + +*BRepTools_History* also allows merging histories. Thus, if you have two or more subsequent operations you can get one final history combined from histories of these operations: + +~~~~ +Handle(BRepTools_History) aHist1 = ...; // History of first operation +Handle(BRepTools_History) aHist2 = ...; // History of second operation +~~~~ + +It is possible to merge the second history into the first one: +~~~~ +aHist1->Merge(aHist2); +~~~~ + +Or create the new history keeping the two histories unmodified: +~~~~ +Handle(BRepTools_History) aResHistory = new BRepTools_History; +aResHistory->Merge(aHist1); +aResHistory->Merge(aHist2); +~~~~ + +The possibilities of Merging histories and history creation from the API algorithms allow providing easy History support for the new algorithms. + +@subsubsection occt_modalg_hist_draw DRAW history support + +DRAW History support for the algorithms is provided by three basic commands: +* *isdeleted*; +* *modified*; +* *generated*. + +For more information on the Draw History mechanism, refer to the corresponding chapter in the Draw users guide - @ref occt_draw_hist "History commands". + +@subsection occt_modalg_6 Fillets and Chamfers This library provides algorithms to make fillets and chamfers on shape edges. The following cases are addressed: @@ -2131,8 +2052,8 @@ The following cases are addressed: If there is a concavity, both surfaces that need to be extended and those, which do not, are processed. -@subsection occt_modalg_6_1 Fillets -@subsection occt_modalg_6_1_1 Fillet on shape +@subsubsection occt_modalg_6_1 Fillets +@subsubsection occt_modalg_6_1_1 Fillet on shape A fillet is a smooth face replacing a sharp edge. @@ -2206,7 +2127,7 @@ void CSampleTopologicalOperationsDoc::OnEvolvedblend1() @figure{/user_guides/modeling_algos/images/modeling_algos_image040.png,"Fillet with changing radius",360} -@subsection occt_modalg_6_1_2 Chamfer +@subsubsection occt_modalg_6_1_2 Chamfer A chamfer is a rectilinear edge replacing a sharp vertex of the face. @@ -2221,7 +2142,7 @@ Add(d1, d2, E, F) with d1 on the face F. @figure{/user_guides/modeling_algos/images/modeling_algos_image041.png,"Chamfer",360} -@subsection occt_modalg_6_1_3 Fillet on a planar face +@subsubsection occt_modalg_6_1_3 Fillet on a planar face *BRepFilletAPI_MakeFillet2d* class allows constructing fillets and chamfers on planar faces. To create a fillet on planar face: define it, indicate, which vertex is to be deleted, and give the fillet radius with *AddFillet* method. @@ -2270,7 +2191,7 @@ TopoDS_Shape FilletFace(const Standard_Real a, } ~~~~~ -@section occt_modalg_7 Offsets, Drafts, Pipes and Evolved shapes +@subsection occt_modalg_7 Offsets, Drafts, Pipes and Evolved shapes These classes provide the following services: @@ -2281,7 +2202,7 @@ These classes provide the following services: * Creation of tapered shapes using draft angles; * Creation of sweeps. -@subsection occt_modalg_7_1 Offset computation +@subsubsection occt_modalg_7_1 Offset computation Offset computation can be performed using *BRepOffsetAPI_MakeOffsetShape*. This class provides API to the two different offset algorithms: @@ -2315,7 +2236,7 @@ The snippets below show usage examples: NewShape = OffsetMaker2.Shape(); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -@subsection occt_modalg_7_2 Shelling +@subsubsection occt_modalg_7_2 Shelling Shelling is used to offset given faces of a solid by a specific value. It rounds or intersects adjacent faces along its edges depending on the convexity of the edge. The MakeThickSolidByJoin method of the *BRepOffsetAPI_MakeThickSolid* takes the solid, the list of faces to remove and an offset value as input. @@ -2353,7 +2274,7 @@ Also it is possible to create solid between shell, offset shell. This functional Solid = SolidMaker.Shape(); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -@subsection occt_modalg_7_3 Draft Angle +@subsubsection occt_modalg_7_3 Draft Angle *BRepOffsetAPI_DraftAngle* class allows modifying a shape by applying draft angles to its planar, cylindrical and conical faces. @@ -2405,7 +2326,7 @@ else { @figure{/user_guides/modeling_algos/images/modeling_algos_image043.png,"DraftAngle",420} -@subsection occt_modalg_7_4 Pipe Constructor +@subsubsection occt_modalg_7_4 Pipe Constructor *BRepOffsetAPI_MakePipe* class allows creating a pipe from a Spine, which is a Wire and a Profile which is a Shape. This implementation is limited to spines with smooth transitions, sharp transitions are precessed by *BRepOffsetAPI_MakePipeShell*. To be more precise the continuity must be G1, which means that the tangent must have the same direction, though not necessarily the same magnitude, at neighboring edges. @@ -2419,7 +2340,7 @@ TopoDS_Shape Pipe = BRepOffsetAPI_MakePipe(Spine,Profile); @figure{/user_guides/modeling_algos/images/modeling_algos_image044.png,"Example of a Pipe",320} -@subsection occt_modalg_7_5 Evolved Solid +@subsubsection occt_modalg_7_5 Evolved Solid *BRepOffsetAPI_MakeEvolved* class allows creating an evolved solid from a Spine (planar face or wire) and a profile (wire). @@ -2442,9 +2363,87 @@ TopoDS_Shape Evol = BRepOffsetAPI_MakeEvolved(Spine,Profile); ~~~~~ -@section occt_modalg_8 Sewing +@subsection occt_modalg_3b Object Modification -@subsection occt_modalg_8_1 Introduction +@subsubsection occt_modalg_3b_1 Transformation +*BRepBuilderAPI_Transform* class can be used to apply a transformation to a shape (see class *gp_Trsf*). The methods have a boolean argument to copy or share the original shape, as long as the transformation allows (it is only possible for direct isometric transformations). By default, the original shape is shared. + +The following example deals with the rotation of shapes. + +~~~~~ + +TopoDS_Shape myShape1 = ...; +// The original shape 1 +TopoDS_Shape myShape2 = ...; +// The original shape2 +gp_Trsf T; +T.SetRotation(gp_Ax1(gp_Pnt(0.,0.,0.),gp_Vec(0.,0.,1.)), +2.*PI/5.); +BRepBuilderAPI_Transformation theTrsf(T); +theTrsf.Perform(myShape1); +TopoDS_Shape myNewShape1 = theTrsf.Shape() +theTrsf.Perform(myShape2,Standard_True); +// Here duplication is forced +TopoDS_Shape myNewShape2 = theTrsf.Shape() +~~~~~ + +@subsubsection occt_modalg_3b_2 Duplication + +Use the *BRepBuilderAPI_Copy* class to duplicate a shape. A new shape is thus created. +In the following example, a solid is copied: + +~~~~~ +TopoDS Solid MySolid; +....// Creates a solid + +TopoDS_Solid myCopy = BRepBuilderAPI_Copy(mySolid); +~~~~~ + +@subsection occt_modalg_3a_1 Error Handling in the Topology API + +A method can report an error in the two following situations: + * The data or arguments of the method are incorrect, i.e. they do not respect the restrictions specified by the methods in its specifications. Typical example: creating a linear edge from two identical points is likely to lead to a zero divide when computing the direction of the line. + * Something unexpected happened. This situation covers every error not included in the first category. Including: interruption, programming errors in the method or in another method called by the first method, bad specifications of the arguments (i.e. a set of arguments that was not expected to fail). + +The second situation is supposed to become increasingly exceptional as a system is debugged and it is handled by the **exception mechanism**. Using exceptions avoids handling error statuses in the call to a method: a very cumbersome style of programming. + +In the first situation, an exception is also supposed to be raised because the calling method should have verified the arguments and if it did not do so, there is a bug. For example, if before calling *MakeEdge* you are not sure that the two points are non-identical, this situation must be tested. + +Making those validity checks on the arguments can be tedious to program and frustrating as you have probably correctly surmised that the method will perform the test twice. It does not trust you. +As the test involves a great deal of computation, performing it twice is also time-consuming. + +Consequently, you might be tempted to adopt the highly inadvisable style of programming illustrated in the following example: + +~~~~~ +#include +try { +TopoDS_Edge E = BRepBuilderAPI_MakeEdge(P1,P2); +// go on with the edge +} +catch { +// process the error. +} +~~~~~ + +To help the user, the Topology API classes only raise the exception *StdFail_NotDone*. Any other exception means that something happened which was unforeseen in the design of this API. + +The *NotDone* exception is only raised when the user tries to access the result of the computation and the original data is corrupted. At the construction of the class instance, if the algorithm cannot be completed, the internal flag *NotDone* is set. This flag can be tested and in some situations a more complete description of the error can be queried. If the user ignores the *NotDone* status and tries to access the result, an exception is raised. + +~~~~~ +BRepBuilderAPI_MakeEdge ME(P1,P2); +if (!ME.IsDone()) { +// doing ME.Edge() or E = ME here +// would raise StdFail_NotDone +Standard_DomainError::Raise +(“ProcessPoints::Failed to create an edge”); +} +TopoDS_Edge E = ME; +~~~~~ + + +@subsection occt_modalg_8 Sewing + +@subsubsection occt_modalg_8_1 Introduction Sewing allows creation of connected topology (shells and wires) from a set of separate topological elements (faces and edges). For example, Sewing can be used to create of shell from a compound of separate faces. @@ -2461,7 +2460,7 @@ Let us define several terms: * **Sewn faces** should have edges shared with each other. * **Sewn edges** should have vertices shared with each other. -@subsection occt_modalg_8_2 Sewing Algorithm +@subsubsection occt_modalg_8_2 Sewing Algorithm The sewing algorithm is one of the basic algorithms used for shape processing, therefore its quality is very important. @@ -2500,7 +2499,7 @@ To connect a set of *n* contiguous but independent faces, do the following: If all faces have been sewn correctly, the result is a shell. Otherwise, it is a compound. After a successful sewing operation all faces have a coherent orientation. -@subsection occt_modalg_8_3 Tolerance Management +@subsubsection occt_modalg_8_3 Tolerance Management To produce a closed shell, Sewing allows specifying the value of working tolerance, exceeding the size of small faces belonging to the shape. @@ -2512,7 +2511,7 @@ The following recommendations can be proposed for tuning-up the sewing process: - If it is expected to obtain a shell with holes (free boundaries) as a result of sewing, the working tolerance should be set to a value not greater than the size of the smallest element (edge) or smallest distance between elements of such free boundary. Otherwise the free boundary may be sewn only partially. - It should be mentioned that the Sewing algorithm is unable to understand which small (less than working tolerance) free boundary should be kept and which should be sewn. -@subsection occt_modalg_8_4 Manifold and Non-manifold Sewing +@subsubsection occt_modalg_8_4 Manifold and Non-manifold Sewing To create one or several shells from a set of faces, sewing merges edges, which belong to different faces or one closed face. @@ -2524,7 +2523,7 @@ For a complex topology it is advisable to apply first the manifold sewing and th Giving a large tolerance value to non manifold sewing will cause a lot of incorrectness since all nearby geometry will be sewn. -@subsection occt_modalg_8_5 Local Sewing +@subsubsection occt_modalg_8_5 Local Sewing If a shape still has some non-sewn faces or edges after sewing, it is possible to use local sewing with a greater tolerance. @@ -2558,11 +2557,11 @@ TopoDS_Shape aRes = aSewing.SewedShape(); ~~~~ -@section occt_modalg_9 Features +@subsection occt_modalg_9 Features This library contained in *BRepFeat* package is necessary for creation and manipulation of form and mechanical features that go beyond the classical boundary representation of shapes. In that sense, *BRepFeat* is an extension of *BRepBuilderAPI* package. -@subsection occt_modalg_9_1 Form Features +@subsubsection occt_modalg_9_1 Form Features The form features are depressions or protrusions including the following types: @@ -2593,7 +2592,7 @@ of removing unwanted matter to get the same result. The *Form* from *BRepFeat* package is a deferred class used as a root for form features. It inherits *MakeShape* from *BRepBuilderAPI* and provides implementation of methods keep track of all sub-shapes. -@subsubsection occt_modalg_9_1_1 Prism +**Prism** The class *BRepFeat_MakePrism* is used to build a prism interacting with a shape. It is created or initialized from * a shape (the basic shape), @@ -2638,7 +2637,7 @@ if (thePrism.IsDone()) { @figure{/user_guides/modeling_algos/images/modeling_algos_image048.png,"Creating a prism between two faces with Perform()",320} -@subsubsection occt_modalg_9_1_2 Draft Prism +**Draft Prism** The class *BRepFeat_MakeDPrism* is used to build draft prism topologies interacting with a basis shape. These can be depressions or protrusions. A class object is created or initialized from: * a shape (basic shape), @@ -2691,7 +2690,7 @@ TopoDS_Shape res1 = MKDP.Shape(); @figure{/user_guides/modeling_algos/images/modeling_algos_image049.png,"A tapered prism",320} -@subsubsection occt_modalg_9_1_3 Revolution +**Revolution** The class *BRepFeat_MakeRevol* is used to build a revolution interacting with a shape. It is created or initialized from: * a shape (the basic shape,) @@ -2733,7 +2732,7 @@ if (theRevol.IsDone()) { } ~~~~~ -@subsubsection occt_modalg_9_1_4 Pipe +**Pipe** The class *BRepFeat_MakePipe* constructs compound shapes with pipe features: depressions or protrusions. A class object is created or initialized from: * a shape (basic shape), @@ -2801,7 +2800,7 @@ TopoDS_Shape res1 = MKPipe.Shape(); @figure{/user_guides/modeling_algos/images/modeling_algos_image050.png,"Pipe depression",240} -@subsection occt_modalg_9_2 Mechanical Features +@subsubsection occt_modalg_9_2 Mechanical Features Mechanical features include ribs, protrusions and grooves (or slots), depressions along planar (linear) surfaces or revolution surfaces. @@ -2822,7 +2821,7 @@ A class object is created or initialized from * a Boolean indicating the type of operation (fusion=rib or cut=groove) on the basic shape; * another Boolean indicating if self-intersections have to be found (not used in every case). -@subsubsection occt_modalg_9_2_1 Linear Form +**Linear Form** Linear form is implemented in *MakeLinearForm* class, which creates a rib or a groove along a planar surface. There is one *Perform()* method, which performs a prism from the wire along the *direction1* and *direction2* interacting with base shape *Sbase*. The height of the prism is *Magnitude(Direction1)+Magnitude(direction2)*. @@ -2861,7 +2860,7 @@ TopoDS_Shape res = aform.Shape(); @figure{/user_guides/modeling_algos/images/modeling_algos_image051.png,"Creating a rib",240} -@subsubsection occt_modalg_9_2_3 Gluer +**Gluer** The class *BRepFeat_Gluer* allows gluing two solids along faces. The contact faces of the glued shape must not have parts outside the contact faces of the basic shape. Upon completion the algorithm gives the glued shape with cut out parts of faces inside the shape. @@ -2922,6 +2921,328 @@ TopoDS_Shape theResult = Spls; ... ~~~~~ +@subsection occt_modalg_defeaturing 3D Model Defeaturing + +The Open CASCADE Technology Defeaturing algorithm is intended for removal of the unwanted parts or features from the model. These parts can be holes, protrusions, gaps, chamfers, fillets, etc. + +Feature detection is not performed, and all features to be removed should be defined by the user. The input shape is not modified during Defeaturing, the new shape is built in the result. + +On the API level the Defeaturing algorithm is implemented in the *BRepAlgoAPI_Defeaturing* class. At input the algorithm accepts the shape to remove the features from and the features (one or many) to be removed from the shape. +Currently, the input shape should be either SOLID, or COMPSOLID, or COMPOUND of SOLIDs. +The features to be removed are defined by the sets of faces forming them. It does not matter how the feature faces are given: as separate faces or their collections. The faces should belong to the initial shape, else they are ignored. + +The actual features removal is performed by the low-level *BOPAlgo_RemoveFeatures* algorithm. On the API level, all inputs are passed into the tool and the method *BOPAlgo_RemoveFeatures::Perform()* is called. + +Before removing features, all faces to be removed from the shape are sorted into connected blocks - each block represents a single feature to be removed. +The features are removed from the shape one by one, which allows removing all possible features even if there are some problems with their removal (e.g. due to incorrect input data). + +The removed feature is filled by the extension of the faces adjacent to it. In general, the algorithm removing a single feature from the shape goes as follows: +* Find the faces adjacent to the feature; +* Extend the adjacent faces to cover the feature; +* Trim the extended faces by the bounds of the original face (except for the bounds common with the feature), so that they cover the feature only; +* Rebuild the solids with reconstructed adjacent faces avoiding the feature faces. + +If the single feature removal was successful, the result shape is overwritten with the new shape, otherwise the results are not kept, and the warning is given. +Either way the process continues with the next feature. + +The Defeaturing algorithm has the following options: +* History support; + +and the options available from base class (*BOPAlgo_Options*): +* Error/Warning reporting system; +* Parallel processing mode. + +Note that the other options of the base class are not supported here and will have no effect. + +History support allows tracking modification of the input shape in terms of Modified, IsDeleted and Generated. By default, the history is collected, but it is possible to disable it using the method *SetToFillHistory(false)*. +On the low-level the history information is collected by the history tool *BRepTools_History*, which can be accessed through the method *BOPAlgo_RemoveFeatures::History()*. + +Error/Warning reporting system allows obtaining the extended overview of the Errors/Warnings occurred during the operation. As soon as any error appears, the algorithm stops working. The warnings allow continuing the job and informing the user that something went wrong. The algorithm returns the following errors/warnings: +* *BOPAlgo_AlertUnsupportedType* - the alert will be given as an error if the input shape does not contain any solids, and as a warning if the input shape contains not only solids, but also other shapes; +* *BOPAlgo_AlertNoFacesToRemove* - the error alert is given in case there are no faces to remove from the shape (nothing to do); +* *BOPAlgo_AlertUnableToRemoveTheFeature* - the warning alert is given to inform the user the removal of the feature is not possible. The algorithm will still try to remove the other features; +* *BOPAlgo_AlertRemoveFeaturesFailed* - the error alert is given in case if the operation was aborted by the unknown reason. + +For more information on the error/warning reporting system, see the chapter @ref specification__boolean_ers "Errors and warnings reporting system" of Boolean operations user guide. + +Parallel processing mode - allows running the algorithm in parallel mode obtaining the result faster. + +The algorithm has certain limitations: +* Intersection of the surfaces of the connected faces adjacent to the feature should not be empty. It means, that such faces should not be tangent to each other. +If the intersection of the adjacent faces will be empty, the algorithm will be unable to trim the faces correctly and, most likely, the feature will not be removed. +* The algorithm does not process the INTERNAL parts of the solids, they are simply removed during reconstruction. + +Note, that for successful removal of the feature, the extended faces adjacent to the feature should cover the feature completely, otherwise the solids will not be rebuild. +Take a look at the simple shape on the image below: +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im001.png,"",220} + +Removal of all three faces of the gap is not going to work, because there will be no face to fill the transverse part of the step. +Although, removal of only two faces, keeping one of the transverse faces, will fill the gap with the kept face: + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im002.png,"Keeping the right transverse face",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im003.png,"Keeping the left transverse face",220} + +@subsubsection occt_modalg_defeaturing_usage Usage + +Here is the example of usage of the *BRepAlgoAPI_Defeaturing* algorithm on the C++ level: +~~~~ +TopoDS_Shape aSolid = ...; // Input shape to remove the features from +TopTools_ListOfShape aFeatures = ...; // Features to remove from the shape +Standard_Boolean bRunParallel = ...; // Parallel processing mode +Standard_Boolean isHistoryNeeded = ...; // History support + +BRepAlgoAPI_Defeaturing aDF; // Defeaturing algorithm +aDF.SetShape(aSolid); // Set the shape +aDF.AddFacesToRemove(aFaces); // Add faces to remove +aDF.SetRunParallel(bRunParallel); // Define the processing mode (parallel or single) +aDF.SetToFillHistory(isHistoryNeeded); // Define whether to track the shapes modifications +aDF.Build(); // Perform the operation +if (!aDF.IsDone()) // Check for the errors +{ + // error treatment + Standard_SStream aSStream; + aDF.DumpErrors(aSStream); + return; +} +if (aDF.HasWarnings()) // Check for the warnings +{ + // warnings treatment + Standard_SStream aSStream; + aDF.DumpWarnings(aSStream); +} +const TopoDS_Shape& aResult = aDF.Shape(); // Result shape +~~~~ + +Use the API history methods to track the history of a shape: +~~~~ +// Obtain modification of the shape +const TopTools_ListOfShape& BRepAlgoAPI_Defeaturing::Modified(const TopoDS_Shape& theS); + +// Obtain shapes generated from the shape +const TopTools_ListOfShape& BRepAlgoAPI_Defeaturing::Generated(const TopoDS_Shape& theS); + +// Check if the shape is removed or not +Standard_Boolean BRepAlgoAPI_Defeaturing::IsDeleted(const TopoDS_Shape& theS); +~~~~ + +The command removefeatures allows using the Defeaturing algorithm on the Draw level. + +The @ref occt_draw_hist "standard history commands" can be used to track the history of shape modification during Defeaturing. + +For more details on commands above, refer to the @ref occt_draw_defeaturing "Defeaturing commands" of the Draw test harness user guide. + +@subsubsection occt_modalg_defeaturing_examples Examples + +Here are the examples of defeaturing of the ANC101 model: + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im004.png,"ANC101 model",220} + + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im005.png,"Removing the cylindrical protrusion",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im006.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im007.png,"Removing the cylindrical holes",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im008.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im009.png,"Removing the cylindrical holes",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im010.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im011.png,"Removing the small gaps in the front",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im012.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im013.png,"Removing the gaps in the front completely",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im014.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im015.png,"Removing the cylindrical protrusion",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im016.png,"Result",220} + +Here are the few examples of defeaturing of the model containing boxes with blends: + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im017.png,"Box blend model",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im018.png,"Removing the blend",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im019.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im020.png,"Removing the blend",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im021.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im022.png,"Removing the blend",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im023.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im024.png,"Removing the blend",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im025.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im026.png,"Removing the blend",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im027.png,"Result",220} + +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im028.png,"Removing the blend",220} +@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im029.png,"Result",220} + + +@subsection occt_modalg_makeperiodic 3D Model Periodicity + +Open CASCADE Technology provides tools for making an arbitrary 3D model (or just shape) periodic in 3D space in the specified directions. + +Periodicity of the shape means that the shape can be repeated in any periodic direction any number of times without creation of the new geometry or splits. +The idea of this algorithm is to make the shape look similarly on the opposite sides or on the period bounds of periodic directions. +It does not mean that the opposite sides of the shape will be mirrored. It just means that the opposite sides of the shape should be split by each other and obtain the same geometry on opposite sides. +Such approach will allow repeating the shape, i.e. translating the copy of a shape on the period, without creation of new geometry because there will be no coinciding parts of different dimension. + +For better understanding of what periodicity means lets create a simple prism and make it periodic. +The following draw script creates the L-shape prism with extensions 10x5x10: +~~~~ +polyline p 0 0 0 0 0 10 5 0 10 5 0 5 10 0 5 10 0 0 0 0 0 +mkplane f p +prism s f 0 5 0 +~~~~ +@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im001.png,"Shape to make periodic",220} + +Making this shape periodic in X, Y and Z directions with the periods matching the shape's extensions should make the splits of negative X and Z sides of the shape. The shape is already similar on opposite sides of Y directions, thus no new splits is expected. +Here is the shape after making it periodic: +@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im002.png,"Periodic shape",220} +And here is the repetition of the shape once in X and Z directions: +@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im003.png,"Repeated shape",220} + +The OCCT Shape Periodicity tools also allows making the shape periodic with the period not matching the shape's extensions. Let's make the shape periodic with 11, 6 and 11 for X, Y, Z periods accordingly. +Such values of periods mean that there will be a gap between repeated shapes, and since during repetition the opposite sides do not touch the shape will not be split at all. +Here is the repetition of the shape once in X and Z directions: +@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im004.png,"Repeated shape",220} +As expected, the shape is not split and the repeated elements do not touch. + +If necessary the algorithm will trim the shape to fit into the requested period by splitting it with the planes limiting the shape's requested periods. +E.g. let's make the L-shape periodic only in X direction with the period 2 starting at X parameter 4: +@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im005.png,"Periodic trimmed shape",220} + +@subsubsection occt_modalg_makeperiodic_how_it_works How the shape is made periodic + +For making the shape periodic in certain direction the algorithm performs the following steps: +* Creates the copy of the shape and moves it on the period into negative side of the requested direction; +* Splits the negative side of the shape by the moved copy, ensuring copying of the geometry from positive side to negative; +* Creates the copy of the shape (with already split negative side) and moves it on the period into the positive side of the requested direction; +* Splits the positive side of the shape by the moved copy, ensuring copying of the geometry from negative side to positive. + +Repeated copying of the geometry ensures that the corner edges of the periodic shape will have the same geometry on opposite sides of all periodic directions. + +Thus, in the periodic shape the geometry from positive side of the shape is always copied on the negative side of periodic directions. + +@subsubsection occt_modalg_makeperiodic_association Opposite shapes association + +The algorithm also associates the identical (or twin) shapes located on the opposite sides of the periodic shape. By the construction, the twin shapes should always have the same geometry and distanced from each other on the period. +It is possible that the shape does not have any twins. It means that when repeating this shape will not touch the opposite side of the shape. In the example when the periods of the shape are grater than its extensions, non of the sub-shapes has a twin. + +@subsubsection occt_modalg_makeperiodic_repetition Periodic shape repetition + +The algorithm also provides the methods to repeat the periodic shape in periodic directions. To repeat shape the algorithm makes the requested number of copies of the shape and translates them one by one on the time * period value. +After all copies are made and translated they are glued to have valid shape. +The subsequent repetitions are performed on the repeated shape, thus e.g. repeating the shape two times in any periodic direction will create result containing three shapes (original plus two copies). +Single subsequent repetition in any direction will result already in 6 shapes. + +The repetitions can be cleared and started over. + +@subsubsection occt_modalg_makeperiodic_history History support + +The algorithm supports the history of shapes modifications, thus it is possible to track how the shapes have been changed to make it periodic and what new shapes have been created during repetitions. +Both split history and history of periodic shape repetition are available here. Note, that all repeated shapes are stored as generated into the history. + + +*BRepTools_History* is used for history support. + +@subsubsection occt_modalg_makeperiodic_errors Errors/Warnings + +The algorithm supports the Error/Warning reporting system which allows obtaining the extended overview of the errors and warning occurred during the operation. +As soon as any error appears the algorithm stops working. The warnings allow continuing the job, informing the user that something went wrong. +The algorithm returns the following alerts: +* *BOPAlgo_AlertNoPeriodicityRequired* - Error alert is given if no periodicity has been requested in any direction; +* *BOPAlgo_AlertUnableToTrim* - Error alert is given if the trimming of the shape for fitting it into requested period has failed; +* *BOPAlgo_AlertUnableToMakeIdentical* - Error alert is given if splitting of the shape by its moved copies has failed; +* *BOPAlgo_AlertUnableToRepeat* - Warning alert is given if the gluing of the repeated shapes has failed. + +For more information on the error/warning reporting system please see the chapter @ref specification__boolean_ers "Errors and warnings reporting system" of Boolean operations user guide. + +@subsubsection occt_modalg_makeperiodic_usage Usage + +The algorithm is implemented in the class *BOPAlgo_MakePeriodic*. +Here is the example of its usage on the API level: +~~~~ +TopoDS_Shape aShape = ...; // The shape to make periodic +Standard_Boolean bMakeXPeriodic = ...; // Flag for making or not the shape periodic in X direction +Standard_Real aXPeriod = ...; // X period for the shape +Standard_Boolean isXTrimmed = ...; // Flag defining whether it is necessary to trimming + // the shape to fit to X period +Standard_Real aXFirst = ...; // Start of the X period + // (really necessary only if the trimming is requested) +Standard_Boolean bRunParallel = ...; // Parallel processing mode or single + +BOPAlgo_MakePeriodic aPeriodicityMaker; // Periodicity maker +aPeriodicityMaker.SetShape(aShape); // Set the shape +aPeriodicityMaker.MakeXPeriodic(bMakePeriodic, aXPeriod); // Making the shape periodic in X direction +aPeriodicityMaker.SetTrimmed(isXTrimmed, aXFirst); // Trim the shape to fit X period +aPeriodicityMaker.SetRunParallel(bRunParallel); // Set the parallel processing mode +aPeriodicityMaker.Perform(); // Performing the operation + +if (aPeriodicityMaker.HasErrors()) // Check for the errors +{ + // errors treatment + Standard_SStream aSStream; + aPeriodicityMaker.DumpErrors(aSStream); + return; +} +if (aPeriodicityMaker.HasWarnings()) // Check for the warnings +{ + // warnings treatment + Standard_SStream aSStream; + aPeriodicityMaker.DumpWarnings(aSStream); +} +const TopoDS_Shape& aPeriodicShape = aPeriodicityMaker.Shape(); // Result periodic shape + +aPeriodicityMaker.XRepeat(2); // Making repetitions +const TopoDS_Shape& aRepeat = aPeriodicityMaker.RepeatedShape(); // Getting the repeated shape +aPeriodicityMaker.ClearRepetitions(); // Clearing the repetitions +~~~~ + +Please note, that the class is based on the options class *BOPAlgo_Options*, which provides the following options for the algorithm: +* Error/Warning reporting system; +* Parallel processing mode. +The other options of the base class are not supported here and will have no effect. + +All the history information obtained during the operation is stored into *BRepTools_History* object and available through *History()* method: +~~~~ +// Get the history object +const Handle(BRepTools_History)& BOPAlgo_MakePeriodic::History(); +~~~~ + +For the usage of the MakePeriodic algorithm on the Draw level the following commands have been implemented: +* **makeperiodic** +* **repeatshape** +* **periodictwins** +* **clearrepetitions** + +For more details on the periodicity commands please refer the @ref occt_draw_makeperiodic "Periodicity commands" of the Draw test harness user guide. + +To track the history of a shape modification during MakePeriodic operation the @ref occt_draw_hist "standard history commands" can be used. + +To have possibility to access the error/warning shapes of the operation use the *bdrawwarnshapes* command before running the algorithm (see command usage in the @ref specification__boolean_ers "Errors and warnings reporting system" of Boolean operations user guide). + +@subsubsection occt_modalg_makeperiodic_examples Examples + +Imagine that you need to make the drills in the plate on the same distance from each other. To model this process it is necessary to make a lot of cylinders (simulating the drills) and cut these cylinders from the plate. +With the periodicity tool, the process looks very simple: +~~~~ +# create plate 100 x 100 +box plate -50 -50 0 100 100 1 +# create a single drill with radius 1 +pcylinder drill 1 1 +# locate the drill in the left corner +ttranslate drill -48 -48 0 +# make the drill periodic with 4 as X and Y periods, so the distance between drills will be 2 +makeperiodic drill drill -x 4 -trim -50 -y 4 -trim -50 +# repeat the drill to fill the plate, in result we get net of 25 x 25 drills +repeatshape drills -x 24 -y 24 +# cut the drills from the plate +bcut result plate drills +~~~~ +@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im006.png,"Plate with drills",220} + @section occt_modalg_10 Hidden Line Removal @@ -3073,570 +3394,6 @@ TopoDS_Shape OutLineHCompound = aPolyHLRToShape.OutLineHCompound(); ~~~~~ -@section occt_modalg_11 Meshing - -@subsection occt_modalg_11_1 Mesh presentations - -In addition to support of exact geometrical representation of 3D objects Open CASCADE Technology provides functionality to work with tessellated representations of objects in form of meshes. - -Open CASCADE Technology mesh functionality provides: -- data structures to store surface mesh data associated to shapes, and some basic algorithms to handle these data -- data structures and algorithms to build surface triangular mesh from *BRep* objects (shapes). -- tools to extend 3D visualization capabilities of Open CASCADE Technology with displaying meshes along with associated pre- and post-processor data. - -Open CASCADE Technology includes two mesh converters: -- VRML converter translates Open CASCADE shapes to VRML 1.0 files (Virtual Reality Modeling Language). Open CASCADE shapes may be translated in two representations: shaded or wireframe. A shaded representation present shapes as sets of triangles computed by a mesh algorithm while a wireframe representation present shapes as sets of curves. -- STL converter translates Open CASCADE shapes to STL files. STL (STtereoLithography) format is widely used for rapid prototyping. - -Open CASCADE SAS also offers Advanced Mesh Products: -- Open CASCADE Mesh Framework (OMF) -- Express Mesh - -Besides, we can efficiently help you in the fields of surface and volume meshing algorithms, mesh optimization algorithms etc. If you require a qualified advice about meshing algorithms, do not hesitate to benefit from the expertise of our team in that domain. - -The projects dealing with numerical simulation can benefit from using SALOME - an Open Source Framework for CAE with CAD data interfaces, generic Pre- and Post- F.E. processors and API for integrating F.E. solvers. - -Learn more about SALOME platform on https://www.salome-platform.org - -@subsection occt_modalg_11_2 Meshing algorithm - -The algorithm of shape triangulation is provided by the functionality of *BRepMesh_IncrementalMesh* class, which adds a triangulation of the shape to its topological data structure. This triangulation is used to visualize the shape in shaded mode. - -~~~~~ -#include -#include -#include - -Standard_Boolean meshing_explicit_parameters() -{ - const Standard_Real aRadius = 10.0; - const Standard_Real aHeight = 25.0; - BRepPrimAPI_MakeCylinder aCylinder(aRadius, aHeight); - TopoDS_Shape aShape = aCylinder.Shape(); - - const Standard_Real aLinearDeflection = 0.01; - const Standard_Real anAngularDeflection = 0.5; - BRepMesh_IncrementalMesh aMesher (aShape, aLinearDeflection, Standard_False, anAngularDeflection, Standard_True); - const Standard_Integer aStatus = aMesher.GetStatusFlags(); - return !aStatus; -} - -Standard_Boolean meshing_imeshtools_parameters() -{ - const Standard_Real aRadius = 10.0; - const Standard_Real aHeight = 25.0; - BRepPrimAPI_MakeCylinder aCylinder(aRadius, aHeight); - TopoDS_Shape aShape = aCylinder.Shape(); - - IMeshTools_Parameters aMeshParams; - aMeshParams.Deflection = 0.01; - aMeshParams.Angle = 0.5; - aMeshParams.Relative = Standard_False; - aMeshParams.InParallel = Standard_True; - aMeshParams.MinSize = Precision::Confusion(); - aMeshParams.InternalVerticesMode = Standard_True; - aMeshParams.ControlSurfaceDeflection = Standard_True; - - BRepMesh_IncrementalMesh aMesher (aShape, aMeshParams); - const Standard_Integer aStatus = aMesher.GetStatusFlags(); - return !aStatus; -} -~~~~~ - -The default meshing algorithm *BRepMesh_IncrementalMesh* has two major options to define triangulation -- linear and angular deflections. - -At the first step all edges from a face are discretized according to the specified parameters. - -At the second step, the faces are tessellated. Linear deflection limits the distance between a curve and its tessellation, whereas angular deflection limits the angle between subsequent segments in a polyline. - -@figure{/user_guides/modeling_algos/images/modeling_algos_image056.png,"Deflection parameters of BRepMesh_IncrementalMesh algorithm",420} - -There are additional options to control behavior of the meshing of face interior: *DeflectionInterior* and *AngleInterior*. *DeflectionInterior* limits the distance between triangles and the face interior. *AngleInterior* (used for tessellation of B-spline faces only) limits the angle between normals (N1, N2 and N3 in the picture) in the nodes of every link of the triangle. There is an exception for the links along the face boundary edges, "Angular Deflection" is used for them during edges discretization. - -@figure{/user_guides/modeling_algos/images/modeling_algos_image057.png,"Linear and angular interior deflections",420} - -Note that if a given value of linear deflection is less than shape tolerance then the algorithm will skip this value and will take into account the shape tolerance. - -The application should provide deflection parameters to compute a satisfactory mesh. Angular deflection is relatively simple and allows using a default value (12-20 degrees). Linear deflection has an absolute meaning and the application should provide the correct value for its models. Giving small values may result in a too huge mesh (consuming a lot of memory, which results in a long computation time and slow rendering) while big values result in an ugly mesh. - -For an application working in dimensions known in advance it can be reasonable to use the absolute linear deflection for all models. This provides meshes according to metrics and precision used in the application (for example, it it is known that the model will be stored in meters, 0.004 m is enough for most tasks). - -However, an application that imports models created in other applications may not use the same deflection for all models. Note that actually this is an abnormal situation and this application is probably just a viewer for CAD models with dimensions varying by an order of magnitude. This problem can be solved by introducing the concept of a relative linear deflection with some LOD (level of detail). The level of detail is a scale factor for absolute deflection, which is applied to model dimensions. - -Meshing covers a shape with a triangular mesh. Other than hidden line removal, you can use meshing to transfer the shape to another tool: a manufacturing tool, a shading algorithm, a finite element algorithm, or a collision algorithm. - -You can obtain information on the shape by first exploring it. To access triangulation of a face in the shape later, use *BRepTool::Triangulation*. To access a polygon, which is the approximation of an edge of the face, use *BRepTool::PolygonOnTriangulation*. - -@subsection occt_modalg_11_3 BRepMesh Architecture -@subsubsection occt_modalg_11_3_1 Goals - -The main goals of the chosen architecture are: - * Remove tight connections between data structures, auxiliary tools and algorithms to create an extensible solution, easy for maintenance and improvements; - * Separate the code among several functional units responsible for specific operation for the sake of simplification of debugging and readability; - * Introduce new data structures enabling the possibility to manipulate a discrete model of a particular entity (edge, wire, face) in order to perform computations locally instead of processing the entire model; - * Implement a new triangulation algorithm replacing the existing functionality that contains overcomplicated solutions that need to be moved to the upper level. In addition, provide the possibility to change the algorithm depending on surface type (initially to speed up meshing of planes). - -@subsubsection occt_modalg_11_3_2 General workflow -@figure{/user_guides/modeling_algos/images/modeling_algos_mesh_001.svg,"General workflow of BRepMesh component",500} - -Generally, the workflow of the component can be divided into six parts: - * **Creation of model data structure**: source *TopoDS_Shape* passed to algorithm is analyzed and exploded into faces and edges. The reflection corresponding to each topological entity is created in the data model. Note that underlying algorithms use the data model as input and access it via a common interface which allows creating a custom data model with necessary dependencies between particular entities (see the paragraph "Data model interface"); - * **Discretize edges 3D & 2D curves**: 3D curve as well as an associated set of 2D curves of each model edge is discretized in order to create a coherent skeleton used as a base in face meshing process. If an edge of the source shape already contains polygonal data which suits the specified parameters, it is extracted from the shape and stored in the model as is. Each edge is processed separately, the adjacency is not taken into account; - * **Heal discrete model**: the source *TopoDS_Shape* can contain problems, such as open wires or self-intersections, introduced during design, exchange or modification of model. In addition, some problems like self-intersections can be introduced by roughly discretized edges. This stage is responsible for analysis of a discrete model in order to detect and repair problems or to refuse further processing of a model part in case if a problem cannot be solved; - * **Preprocess discrete model**: defines actions specific to the implemented approach to be performed before meshing of faces. By default, this operation iterates over model faces, checks the consistency of existing triangulations and cleans topological faces and adjacent edges from polygonal data in case of inconsistency or marks a face of the discrete model as not required for the computation; - * **Discretize faces**: represents the core part performing mesh generation for a particular face based on 2D discrete data. This operation caches polygonal data associated with face edges in the data model for further processing and stores the generated mesh to *TopoDS_Face*; - * **Postprocess discrete model**: defines actions specific for the implemented approach to be performed after meshing of faces. By default, this operation stores polygonal data obtained at the previous stage to *TopoDS_Edge* objects of the source model. - -@subsubsection occt_modalg_11_3_3 Common interfaces -The component structure contains two units: IMeshData (see Data model interface) and IMeshTools, defining common interfaces for the data model and algorithmic tools correspondingly. Class *IMeshTools_Context* represents a connector between these units. The context class caches the data model as well as the tools corresponding to each of six stages of the workflow mentioned above and provides methods to call the corresponding tool safely (designed similarly to *IntTools_Context* in order to keep consistency with OCCT core tools). All stages, except for the first one, use the data model as input and perform a specific action on the entire structure. Thus, API class *IMeshTools_ModelAlgo* is defined in order to unify the interface of tools manipulating the data model. Each tool supposed to process the data model should inherit this interface enabling the possibility to cache it in context. In contrast to others, the model builder interface is defined by another class *IMeshTools_ModelBuilder* due to a different meaning of the stage. The entry point starting the entire workflow is represented by *IMeshTools_MeshBuilder*. - -The default implementation of *IMeshTools_Context* is given in *BRepMesh_Context* class initializing the context by instances of default algorithmic tools. - -The factory interface *IMeshTools_MeshAlgoFactory* gives the possibility to change the triangulation algorithm for a specific surface. The factory returns an instance of the triangulation algorithm via *IMeshTools_MeshAlgo* interface depending on the type of surface passed as parameter. It is supposed to be used at the face discretization stage. - -The default implementation of AlgoFactory is given in *BRepMesh_MeshAlgoFactory* returning algorithms of different complexity chosen according to the passed surface type. In its turn, it is used as the initializer of *BRepMesh_FaceDiscret* algorithm representing the starter of face discretization stage. - -@figure{/user_guides/modeling_algos/images/modeling_algos_mesh_002.svg,"Interface describing entry point to meshing workflow",500} - -Remaining interfaces describe auxiliary tools: - * *IMeshTools_CurveTessellator*: provides a common interface to the algorithms responsible for creation of discrete polygons on 3D and 2D curves as well as tools for extraction of existing polygons from *TopoDS_Edge* allowing to obtain discrete points and the corresponding parameters on curve regardless of the implementation details (see examples of usage of derived classes *BRepMesh_CurveTessellator*, *BRepMesh_EdgeTessellationExtractor* in *BRepMesh_EdgeDiscret*); - * *IMeshTools_ShapeExplorer*: the last two interfaces represent visitor design pattern and are intended to separate iteration over elements of topological shape (edges and faces) from the operations performed on a particular element; - * *IMeshTools_ShapeVisitor*: provides a common interface for operations on edges and faces of the target topological shape. It can be used in couple with *IMeshTools_ShapeExplorer*. The default implementation available in *BRepMesh_ShapeVisitor* performs initialization of the data model. The advantage of such approach is that the implementation of *IMeshTools_ShapeVisitor* can be changed according to the specific data model whereas the shape explorer implementation remains the same. - -@subsubsection occt_modalg_11_3_4 Create model data structure -The data structures intended to keep discrete and temporary data required by underlying algorithms are created at the first stage of the meshing procedure. Generally, the model represents dependencies between entities of the source topological shape suitable for the target task. - -#### Data model interface -Unit IMeshData provides common interfaces specifying the data model API used on different stages of the entire workflow. Dependencies and references of the designed interfaces are given in the figure below. A specific interface implementation depends on the target application which allows the developer to implement different models and use custom low-level data structures, e.g. different collections, either NCollection or STL. *IMeshData_Shape* is used as the base class for all data structures and tools keeping the topological shape in order to avoid possible copy-paste. - -The default implementation of interfaces is given in BRepMeshData unit. The main aim of the default data model is to provide features performing discretization of edges in a parallel mode. Thus, curve, pcurve and other classes are based on STL containers and smart-pointers as far as NCollection does not provide thread-safety for some cases (e.g. *NCollection_Sequence*). In addition, it closely reflects topology of the source shape, i.e. the number of edges in the data model is equal to the number of edges in the source model; each edge contains a set of pcurves associated with its adjacent faces which allows creation of discrete polygons for all pcurves or the 3D curve of a particular edge in a separate thread. - -**Advantages**: -In case of necessity, the data model (probably with algorithms for its processing) can be easily substituted by another implementation supporting another kind of dependencies between elements. - -An additional example of a different data model is the case when it is not required to create a mesh with discrete polygons synchronized between adjacent faces, i.e. in case of necessity to speed up creation of a rough per-face tessellation used for visualization or quick computation only (the approach used in *XDEDRAW_Props*). - -@figure{/user_guides/modeling_algos/images/modeling_algos_mesh_003.svg,"Common API of data model",500} - -#### Collecting data model -At this stage the data model is filled by entities according to the topological structure of the source shape. A default implementation of the data model is given in BRepMeshData unit and represents the model as two sets: a set of edges and a set of faces. Each face consists of one or several wires, the first of which always represents the outer wire, while others are internal. In its turn, each wire depicts the ordered sequence of oriented edges. Each edge is characterized by a single 3D curve and zero (in case of free edge) or more 2D curves associated with faces adjacent to this edge. Both 3D and 2D curves represent a set of pairs point-parameter defined in 3D and 2D space of the reference face correspondingly. An additional difference between a curve and a pcurve is that the latter has a reference to the face it is defined for. - -Model filler algorithm is represented by *BRepMesh_ShapeVisitor* class creating the model as a reflection to topological shape with help of *BRepMesh_ShapeExplorer* performing iteration over edges and faces of the target shape. Note that the algorithm operates on a common interface of the data model and creates a structure without any knowledge about the implementation details and underlying data structures. The entry point to collecting functionality is *BRepMesh_ModelBuilder* class. - -@subsubsection occt_modalg_11_3_5 Discretize edges 3D & 2D curves -At this stage only the edges of the data model are considered. Each edge is processed separately (with the possibility to run processing in multiple threads). The edge is checked for existing polygonal data. In case if at least one representation exists and suits the meshing parameters, it is recuperated and used as reference data for tessellation of the whole set of pcurves as well as 3D curve assigned to the edge (see *BRepMesh_EdgeTessellationExtractor*). Otherwise, a new tessellation algorithm is created and used to generate the initial polygon (see *BRepMesh_CurveTessellator*) and the edge is marked as outdated. In addition, the model edge is updated by deflection as well as recomputed same range, same parameter and degeneracy parameters. See *BRepMesh_EdgeDiscret* for implementation details. - -IMeshData unit defines interface *IMeshData_ParametersListArrayAdaptor*, which is intended to adapt arbitrary data structures to the *NCollection_Array1* container API. This solution is made to use both *NCollection_Array1* and *IMeshData_Curve* as the source for *BRepMesh_EdgeParameterProvider* tool intended to generate a consistent parametrization taking into account the same parameter property. - -@subsubsection occt_modalg_11_3_6 Heal discrete model -In general, this stage represents a set of operations performed on the entire discrete model in order to resolve inconsistencies due to the problems caused by design, translation or rough discretization. A different sequence of operations can be performed depending on the target triangulation algorithm, e.g. there are different approaches to process self-intersections – either to amplify edges discretization by decreasing the target precision or to split links at the intersection points. At this stage the whole set of edges is considered in aggregate and their adjacency is taken into account. A default implementation of the model healer is given in *BRepMesh_ModelHealer* which performs the following actions: - * Iterates over model faces and checks their wires for consistency, i.e. whether the wires are closed and do not contain self-intersections. The data structures are designed free of collisions, thus it is possible to run processing in a parallel mode; - * Forcibly connects the ends of adjacent edges in the parametric space, closing gaps between possible disconnected parts. The aim of this operation is to create a correct discrete model defined relatively to the parametric space of the target face taking into account connectivity and tolerances of 3D space only. This means that no specific computations are made to determine U and V tolerance; - * Registers intersections on edges forming the face shape. Two solutions are possible in order to resolve self-intersection: - * Decrease deflection of a particular edge and update its discrete model. After that the workflow "intersection check – amplification" is repeated up to 5 times. As the result, target edges contain a finer tessellation and meshing continues or the face is marked by *IMeshData_SelfIntersectingWire* status and refused from further processing; - * Split target edges by intersection point and synchronize the updated polygon with curve and remaining pcurves associated to each edge. This operation presents a more robust solution comparing to the amplification procedure with a guaranteed result, but it is more difficult for implementation from the point of view of synchronization functionality. - -@subsubsection occt_modalg_11_3_7 Preprocess discrete model -This stage implements actions to be performed before meshing of faces. Depending on target goals it can be changed or omitted. By default, *BRepMesh_ModelPreProcessor* implements the functionality checking topological faces for consistency of existing triangulation, i.e.: consistency with the target deflection parameter; indices of nodes referenced by triangles do not exceed the number of nodes stored in a triangulation. If the face fails some checks, it is cleaned from triangulation and its adjacent edges are cleaned from existing polygons. This does not affect a discrete model and does not require any recomputation as the model keeps tessellations for the whole set of edges despite consistency of their polygons. - -@subsubsection occt_modalg_11_3_8 Discretize faces -Discretization of faces is the general part of meshing algorithm. At this stage edges tessellation data obtained and processed on previous steps is used to form contours of target faces and passed as input to the triangulation algorithm. Default implementation is provided by *BRepMesh_FaceDiscret* class which represents a starter for triangulation algorithm. It iterates over faces available in the data model, creates an instance of the triangulation algorithm according to the type of surface associated with each face via *IMeshTools_MeshAlgoFactory* and executes it. Each face is processed separately, thus it is possible to process faces in a parallel mode. The class diagram of face discretization is given in the figure below. - -@figure{/user_guides/modeling_algos/images/modeling_algos_mesh_004.svg,"Class diagram of face discrete stage",300} - -In general, face meshing algorithms have the following structure: - * *BRepMesh_BaseMeshAlgo* implements *IMeshTools_MeshAlgo* interface and the base functionality for inherited algorithms. The main goal of this class is to initialize an instance of *BRepMesh_DataStructureOfDelaun* as well as auxiliary data structures suitable for nested algorithms using face model data passed as input parameter. Despite implementation of triangulation algorithm this structure is currently supposed as common for OCCT. However, the user is free to implement a custom algorithm and supporting data structure accessible via *IMeshTools_MeshAlgo* interface, e.g. to connect a 3-rd party meshing tool that does not support *TopoDS_Shape* out of box. For this, such structure provides the possibility to distribute connectors to various algorithms in the form of plugins; - * *BRepMesh_DelaunayBaseMeshAlgo* and *BRepMesh_SweepLineMeshAlgo* classes implement core meshing functionality operating directly on an instance of *BRepMesh_DataStructureOfDelaun*. The algorithms represent mesh generation tools adding new points from the data structure to the final mesh; - * *BRepMesh_NodeInsertionMeshAlgo* class represents a wrapper intended to extend the algorithm inherited from *BRepMesh_BaseMeshAlgo* to enable the functionality generating surface nodes and inserting them into the structure. On this level, an instance of the classification tool is created and can be used to accept-reject internal nodes. In addition, computations necessary for scaling UV coordinates of points relatively to the range specified for the corresponding direction are performed. As far as both triangulation algorithms work on static data provided by the structure, new nodes are added at the initialization stage. Surface nodes are generated by an auxiliary tool called range splitter and passed as template parameter (see Range splitter); - * Classes *BRepMesh_DelaunayNodeInsertionMeshAlgo* and *BRepMesh_SweepLineNodeInsertionMeshAlgo* implement algorithm-specific functionality related to addition of internal nodes supplementing functionality provided by *BRepMesh_NodeInsertionMeshAlgo*; - * *BRepMesh_DelaunayDeflectionControlMeshAlgo* extends functionality of *BRepMesh_DelaunayNodeInsertionMeshAlgo* by additional procedure controlling deflection of generated triangles. - -BRepMesh provides user a way to switch default triangulation algorithm to a custom one, either implemented by user or available worldwide. -There are three base classes that can be currently used to integrate 3rd-party algorithms: - * *BRepMesh_ConstrainedBaseMeshAlgo* base class for tools providing generation of triangulations with constraints requiring no common processing by BRepMesh; - * *BRepMesh_CustomBaseMeshAlgo* provides the entry point for generic algorithms without support of constraints and supposed for generation of base mesh only. - Constraint edges are processed using standard functionality provided by the component itself upon background mesh produced by 3rd-party solver; - * *BRepMesh_CustomDelaunayBaseMeshAlgo* contains initialization part for tools used by BRepMesh for checks or optimizations using results of 3rd-party algorithm. - -Meshing algorithms could be provided by implemeting IMeshTools_MeshAlgoFactory with related interfaces and passing it to BRepMesh_Context::SetFaceDiscret(). -OCCT comes with two base 2D meshing algorithms: BRepMesh_MeshAlgoFactory (used by default) and BRepMesh_DelabellaMeshAlgoFactory. - -The following example demonstrates how it could be done from Draw environment: -~~~~~ -psphere s 10 - -### Default Algo ### -incmesh s 0.0001 -algo default - -### Delabella Algo ### -incmesh s 0.0001 -algo delabella -~~~~~ - -The code snippet below shows passing a custom mesh factory to BRepMesh_IncrementalMesh: -~~~~~ -IMeshTools_Parameters aMeshParams; -Handle(IMeshTools_Context) aContext = new BRepMesh_Context(); -aContext->SetFaceDiscret (new BRepMesh_FaceDiscret (new BRepMesh_DelabellaMeshAlgoFactory())); - -BRepMesh_IncrementalMesh aMesher; -aMesher.SetShape (aShape); -aMesher.ChangeParameters() = aMeshParams; - -aMesher.Perform (aContext); -~~~~~ - -#### Range splitter -Range splitter tools provide functionality to generate internal surface nodes defined within the range computed using discrete model data. The base functionality is provided by *BRepMesh_DefaultRangeSplitter* which can be used without modifications in case of planar surface. The default splitter does not generate any internal node. - -*BRepMesh_ConeRangeSplitter*, *BRepMesh_CylinderRangeSplitter* and *BRepMesh_SphereRangeSplitter* are specializations of the default splitter intended for quick generation of internal nodes for the corresponding type of analytical surface. - -*BRepMesh_UVParamRangeSplitter* implements base functionality taking discretization points of face border into account for node generation. Its successors BRepMesh_TorusRangeSplitter and *BRepMesh_NURBSRangeSplitter* extend the base functionality for toroidal and NURBS surfaces correspondingly. - -@subsubsection occt_modalg_11_3_9 Postprocess discrete model -This stage implements actions to be performed after meshing of faces. Depending on target goals it can be changed or omitted. By default, *BRepMesh_ModelPostProcessor* commits polygonal data stored in the data model to *TopoDS_Edge*. - - -@section occt_modalg_defeaturing 3D Model Defeaturing - -The Open CASCADE Technology Defeaturing algorithm is intended for removal of the unwanted parts or features from the model. These parts can be holes, protrusions, gaps, chamfers, fillets, etc. - -Feature detection is not performed, and all features to be removed should be defined by the user. The input shape is not modified during Defeaturing, the new shape is built in the result. - -On the API level the Defeaturing algorithm is implemented in the *BRepAlgoAPI_Defeaturing* class. At input the algorithm accepts the shape to remove the features from and the features (one or many) to be removed from the shape. -Currently, the input shape should be either SOLID, or COMPSOLID, or COMPOUND of SOLIDs. -The features to be removed are defined by the sets of faces forming them. It does not matter how the feature faces are given: as separate faces or their collections. The faces should belong to the initial shape, else they are ignored. - -The actual features removal is performed by the low-level *BOPAlgo_RemoveFeatures* algorithm. On the API level, all inputs are passed into the tool and the method *BOPAlgo_RemoveFeatures::Perform()* is called. - -Before removing features, all faces to be removed from the shape are sorted into connected blocks - each block represents a single feature to be removed. -The features are removed from the shape one by one, which allows removing all possible features even if there are some problems with their removal (e.g. due to incorrect input data). - -The removed feature is filled by the extension of the faces adjacent to it. In general, the algorithm removing a single feature from the shape goes as follows: -* Find the faces adjacent to the feature; -* Extend the adjacent faces to cover the feature; -* Trim the extended faces by the bounds of the original face (except for the bounds common with the feature), so that they cover the feature only; -* Rebuild the solids with reconstructed adjacent faces avoiding the feature faces. - -If the single feature removal was successful, the result shape is overwritten with the new shape, otherwise the results are not kept, and the warning is given. -Either way the process continues with the next feature. - -The Defeaturing algorithm has the following options: -* History support; - -and the options available from base class (*BOPAlgo_Options*): -* Error/Warning reporting system; -* Parallel processing mode. - -Note that the other options of the base class are not supported here and will have no effect. - -History support allows tracking modification of the input shape in terms of Modified, IsDeleted and Generated. By default, the history is collected, but it is possible to disable it using the method *SetToFillHistory(false)*. -On the low-level the history information is collected by the history tool *BRepTools_History*, which can be accessed through the method *BOPAlgo_RemoveFeatures::History()*. - -Error/Warning reporting system allows obtaining the extended overview of the Errors/Warnings occurred during the operation. As soon as any error appears, the algorithm stops working. The warnings allow continuing the job and informing the user that something went wrong. The algorithm returns the following errors/warnings: -* *BOPAlgo_AlertUnsupportedType* - the alert will be given as an error if the input shape does not contain any solids, and as a warning if the input shape contains not only solids, but also other shapes; -* *BOPAlgo_AlertNoFacesToRemove* - the error alert is given in case there are no faces to remove from the shape (nothing to do); -* *BOPAlgo_AlertUnableToRemoveTheFeature* - the warning alert is given to inform the user the removal of the feature is not possible. The algorithm will still try to remove the other features; -* *BOPAlgo_AlertRemoveFeaturesFailed* - the error alert is given in case if the operation was aborted by the unknown reason. - -For more information on the error/warning reporting system, see the chapter @ref specification__boolean_ers "Errors and warnings reporting system" of Boolean operations user guide. - -Parallel processing mode - allows running the algorithm in parallel mode obtaining the result faster. - -The algorithm has certain limitations: -* Intersection of the surfaces of the connected faces adjacent to the feature should not be empty. It means, that such faces should not be tangent to each other. -If the intersection of the adjacent faces will be empty, the algorithm will be unable to trim the faces correctly and, most likely, the feature will not be removed. -* The algorithm does not process the INTERNAL parts of the solids, they are simply removed during reconstruction. - -Note, that for successful removal of the feature, the extended faces adjacent to the feature should cover the feature completely, otherwise the solids will not be rebuild. -Take a look at the simple shape on the image below: -@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im001.png,"",220} - -Removal of all three faces of the gap is not going to work, because there will be no face to fill the transverse part of the step. -Although, removal of only two faces, keeping one of the transverse faces, will fill the gap with the kept face: - - - - - -
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im002.png,"Keeping the right transverse face",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im003.png,"Keeping the left transverse face",220}
- -@subsection occt_modalg_defeaturing_usage Usage - -Here is the example of usage of the *BRepAlgoAPI_Defeaturing* algorithm on the C++ level: -~~~~ -TopoDS_Shape aSolid = ...; // Input shape to remove the features from -TopTools_ListOfShape aFeatures = ...; // Features to remove from the shape -Standard_Boolean bRunParallel = ...; // Parallel processing mode -Standard_Boolean isHistoryNeeded = ...; // History support - -BRepAlgoAPI_Defeaturing aDF; // Defeaturing algorithm -aDF.SetShape(aSolid); // Set the shape -aDF.AddFacesToRemove(aFaces); // Add faces to remove -aDF.SetRunParallel(bRunParallel); // Define the processing mode (parallel or single) -aDF.SetToFillHistory(isHistoryNeeded); // Define whether to track the shapes modifications -aDF.Build(); // Perform the operation -if (!aDF.IsDone()) // Check for the errors -{ - // error treatment - Standard_SStream aSStream; - aDF.DumpErrors(aSStream); - return; -} -if (aDF.HasWarnings()) // Check for the warnings -{ - // warnings treatment - Standard_SStream aSStream; - aDF.DumpWarnings(aSStream); -} -const TopoDS_Shape& aResult = aDF.Shape(); // Result shape -~~~~ - -Use the API history methods to track the history of a shape: -~~~~ -// Obtain modification of the shape -const TopTools_ListOfShape& BRepAlgoAPI_Defeaturing::Modified(const TopoDS_Shape& theS); - -// Obtain shapes generated from the shape -const TopTools_ListOfShape& BRepAlgoAPI_Defeaturing::Generated(const TopoDS_Shape& theS); - -// Check if the shape is removed or not -Standard_Boolean BRepAlgoAPI_Defeaturing::IsDeleted(const TopoDS_Shape& theS); -~~~~ - -The command removefeatures allows using the Defeaturing algorithm on the Draw level. - -The @ref occt_draw_hist "standard history commands" can be used to track the history of shape modification during Defeaturing. - -For more details on commands above, refer to the @ref occt_draw_defeaturing "Defeaturing commands" of the Draw test harness user guide. - -@subsection occt_modalg_defeaturing_examples Examples - -Here are the examples of defeaturing of the ANC101 model: - -@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im004.png,"ANC101 model",220} - - - - - - - - - - - - - - - - - - - - - - - - - - -
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im005.png,"Removing the cylindrical protrusion",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im006.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im007.png,"Removing the cylindrical holes",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im008.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im009.png,"Removing the cylindrical holes",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im010.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im011.png,"Removing the small gaps in the front",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im012.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im013.png,"Removing the gaps in the front completely",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im014.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im015.png,"Removing the cylindrical protrusion",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im016.png,"Result",220}
- -Here are the few examples of defeaturing of the model containing boxes with blends: - -@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im017.png,"Box blend model",220} - - - - - - - - - - - - - - - - - - - - - - - - - - -
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im018.png,"Removing the blend",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im019.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im020.png,"Removing the blend",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im021.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im022.png,"Removing the blend",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im023.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im024.png,"Removing the blend",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im025.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im026.png,"Removing the blend",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im027.png,"Result",220}
@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im028.png,"Removing the blend",220}@figure{/user_guides/modeling_algos/images/modeling_algos_rf_im029.png,"Result",220}
- - -@section occt_modalg_makeperiodic 3D Model Periodicity - -Open CASCADE Technology provides tools for making an arbitrary 3D model (or just shape) periodic in 3D space in the specified directions. - -Periodicity of the shape means that the shape can be repeated in any periodic direction any number of times without creation of the new geometry or splits. -The idea of this algorithm is to make the shape look similarly on the opposite sides or on the period bounds of periodic directions. -It does not mean that the opposite sides of the shape will be mirrored. It just means that the opposite sides of the shape should be split by each other and obtain the same geometry on opposite sides. -Such approach will allow repeating the shape, i.e. translating the copy of a shape on the period, without creation of new geometry because there will be no coinciding parts of different dimension. - -For better understanding of what periodicity means lets create a simple prism and make it periodic. -The following draw script creates the L-shape prism with extensions 10x5x10: -~~~~ -polyline p 0 0 0 0 0 10 5 0 10 5 0 5 10 0 5 10 0 0 0 0 0 -mkplane f p -prism s f 0 5 0 -~~~~ -@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im001.png,"Shape to make periodic",220} - -Making this shape periodic in X, Y and Z directions with the periods matching the shape's extensions should make the splits of negative X and Z sides of the shape. The shape is already similar on opposite sides of Y directions, thus no new splits is expected. -Here is the shape after making it periodic: -@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im002.png,"Periodic shape",220} -And here is the repetition of the shape once in X and Z directions: -@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im003.png,"Repeated shape",220} - -The OCCT Shape Periodicity tools also allows making the shape periodic with the period not matching the shape's extensions. Let's make the shape periodic with 11, 6 and 11 for X, Y, Z periods accordingly. -Such values of periods mean that there will be a gap between repeated shapes, and since during repetition the opposite sides do not touch the shape will not be split at all. -Here is the repetition of the shape once in X and Z directions: -@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im004.png,"Repeated shape",220} -As expected, the shape is not split and the repeated elements do not touch. - -If necessary the algorithm will trim the shape to fit into the requested period by splitting it with the planes limiting the shape's requested periods. -E.g. let's make the L-shape periodic only in X direction with the period 2 starting at X parameter 4: -@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im005.png,"Periodic trimmed shape",220} - -@subsection occt_modalg_makeperiodic_how_it_works How the shape is made periodic - -For making the shape periodic in certain direction the algorithm performs the following steps: -* Creates the copy of the shape and moves it on the period into negative side of the requested direction; -* Splits the negative side of the shape by the moved copy, ensuring copying of the geometry from positive side to negative; -* Creates the copy of the shape (with already split negative side) and moves it on the period into the positive side of the requested direction; -* Splits the positive side of the shape by the moved copy, ensuring copying of the geometry from negative side to positive. - -Repeated copying of the geometry ensures that the corner edges of the periodic shape will have the same geometry on opposite sides of all periodic directions. - -Thus, in the periodic shape the geometry from positive side of the shape is always copied on the negative side of periodic directions. - -@subsection occt_modalg_makeperiodic_association Opposite shapes association - -The algorithm also associates the identical (or twin) shapes located on the opposite sides of the periodic shape. By the construction, the twin shapes should always have the same geometry and distanced from each other on the period. -It is possible that the shape does not have any twins. It means that when repeating this shape will not touch the opposite side of the shape. In the example when the periods of the shape are grater than its extensions, non of the sub-shapes has a twin. - -@subsection occt_modalg_makeperiodic_repetition Periodic shape repetition - -The algorithm also provides the methods to repeat the periodic shape in periodic directions. To repeat shape the algorithm makes the requested number of copies of the shape and translates them one by one on the time * period value. -After all copies are made and translated they are glued to have valid shape. -The subsequent repetitions are performed on the repeated shape, thus e.g. repeating the shape two times in any periodic direction will create result containing three shapes (original plus two copies). -Single subsequent repetition in any direction will result already in 6 shapes. - -The repetitions can be cleared and started over. - -@subsection occt_modalg_makeperiodic_history History support - -The algorithm supports the history of shapes modifications, thus it is possible to track how the shapes have been changed to make it periodic and what new shapes have been created during repetitions. -Both split history and history of periodic shape repetition are available here. Note, that all repeated shapes are stored as generated into the history. - - -*BRepTools_History* is used for history support. - -@subsection occt_modalg_makeperiodic_errors Errors/Warnings - -The algorithm supports the Error/Warning reporting system which allows obtaining the extended overview of the errors and warning occurred during the operation. -As soon as any error appears the algorithm stops working. The warnings allow continuing the job, informing the user that something went wrong. -The algorithm returns the following alerts: -* *BOPAlgo_AlertNoPeriodicityRequired* - Error alert is given if no periodicity has been requested in any direction; -* *BOPAlgo_AlertUnableToTrim* - Error alert is given if the trimming of the shape for fitting it into requested period has failed; -* *BOPAlgo_AlertUnableToMakeIdentical* - Error alert is given if splitting of the shape by its moved copies has failed; -* *BOPAlgo_AlertUnableToRepeat* - Warning alert is given if the gluing of the repeated shapes has failed. - -For more information on the error/warning reporting system please see the chapter @ref specification__boolean_ers "Errors and warnings reporting system" of Boolean operations user guide. - -@subsection occt_modalg_makeperiodic_usage Usage - -The algorithm is implemented in the class *BOPAlgo_MakePeriodic*. -Here is the example of its usage on the API level: -~~~~ -TopoDS_Shape aShape = ...; // The shape to make periodic -Standard_Boolean bMakeXPeriodic = ...; // Flag for making or not the shape periodic in X direction -Standard_Real aXPeriod = ...; // X period for the shape -Standard_Boolean isXTrimmed = ...; // Flag defining whether it is necessary to trimming - // the shape to fit to X period -Standard_Real aXFirst = ...; // Start of the X period - // (really necessary only if the trimming is requested) -Standard_Boolean bRunParallel = ...; // Parallel processing mode or single - -BOPAlgo_MakePeriodic aPeriodicityMaker; // Periodicity maker -aPeriodicityMaker.SetShape(aShape); // Set the shape -aPeriodicityMaker.MakeXPeriodic(bMakePeriodic, aXPeriod); // Making the shape periodic in X direction -aPeriodicityMaker.SetTrimmed(isXTrimmed, aXFirst); // Trim the shape to fit X period -aPeriodicityMaker.SetRunParallel(bRunParallel); // Set the parallel processing mode -aPeriodicityMaker.Perform(); // Performing the operation - -if (aPeriodicityMaker.HasErrors()) // Check for the errors -{ - // errors treatment - Standard_SStream aSStream; - aPeriodicityMaker.DumpErrors(aSStream); - return; -} -if (aPeriodicityMaker.HasWarnings()) // Check for the warnings -{ - // warnings treatment - Standard_SStream aSStream; - aPeriodicityMaker.DumpWarnings(aSStream); -} -const TopoDS_Shape& aPeriodicShape = aPeriodicityMaker.Shape(); // Result periodic shape - -aPeriodicityMaker.XRepeat(2); // Making repetitions -const TopoDS_Shape& aRepeat = aPeriodicityMaker.RepeatedShape(); // Getting the repeated shape -aPeriodicityMaker.ClearRepetitions(); // Clearing the repetitions -~~~~ - -Please note, that the class is based on the options class *BOPAlgo_Options*, which provides the following options for the algorithm: -* Error/Warning reporting system; -* Parallel processing mode. -The other options of the base class are not supported here and will have no effect. - -All the history information obtained during the operation is stored into *BRepTools_History* object and available through *History()* method: -~~~~ -// Get the history object -const Handle(BRepTools_History)& BOPAlgo_MakePeriodic::History(); -~~~~ - -For the usage of the MakePeriodic algorithm on the Draw level the following commands have been implemented: -* **makeperiodic** -* **repeatshape** -* **periodictwins** -* **clearrepetitions** - -For more details on the periodicity commands please refer the @ref occt_draw_makeperiodic "Periodicity commands" of the Draw test harness user guide. - -To track the history of a shape modification during MakePeriodic operation the @ref occt_draw_hist "standard history commands" can be used. - -To have possibility to access the error/warning shapes of the operation use the *bdrawwarnshapes* command before running the algorithm (see command usage in the @ref specification__boolean_ers "Errors and warnings reporting system" of Boolean operations user guide). - -@subsection occt_modalg_makeperiodic_examples Examples - -Imagine that you need to make the drills in the plate on the same distance from each other. To model this process it is necessary to make a lot of cylinders (simulating the drills) and cut these cylinders from the plate. -With the periodicity tool, the process looks very simple: -~~~~ -# create plate 100 x 100 -box plate -50 -50 0 100 100 1 -# create a single drill with radius 1 -pcylinder drill 1 1 -# locate the drill in the left corner -ttranslate drill -48 -48 0 -# make the drill periodic with 4 as X and Y periods, so the distance between drills will be 2 -makeperiodic drill drill -x 4 -trim -50 -y 4 -trim -50 -# repeat the drill to fill the plate, in result we get net of 25 x 25 drills -repeatshape drills -x 24 -y 24 -# cut the drills from the plate -bcut result plate drills -~~~~ -@figure{/user_guides/modeling_algos/images/modeling_algos_mkperiodic_im006.png,"Plate with drills",220} @section occt_modalg_makeconnected Making touching shapes connected diff --git a/dox/user_guides/modeling_data/images/modeling_data_image003.png b/dox/user_guides/modeling_data/images/modeling_data_image003.png index df9682b596..593342d591 100644 Binary files a/dox/user_guides/modeling_data/images/modeling_data_image003.png and b/dox/user_guides/modeling_data/images/modeling_data_image003.png differ diff --git a/dox/user_guides/modeling_data/images/modeling_data_image014.png b/dox/user_guides/modeling_data/images/modeling_data_image014.png index 48cfa12d3d..801244f8e0 100644 Binary files a/dox/user_guides/modeling_data/images/modeling_data_image014.png and b/dox/user_guides/modeling_data/images/modeling_data_image014.png differ diff --git a/dox/user_guides/modeling_data/images/modeling_data_image015.png b/dox/user_guides/modeling_data/images/modeling_data_image015.png index 277cbb6ffa..6f98d72fe3 100644 Binary files a/dox/user_guides/modeling_data/images/modeling_data_image015.png and b/dox/user_guides/modeling_data/images/modeling_data_image015.png differ diff --git a/dox/user_guides/modeling_data/modeling_data.md b/dox/user_guides/modeling_data/modeling_data.md index 0de514e7d0..c8cd9d965c 100644 --- a/dox/user_guides/modeling_data/modeling_data.md +++ b/dox/user_guides/modeling_data/modeling_data.md @@ -7,7 +7,7 @@ Modeling Data {#occt_user_guides__modeling_data} Modeling Data supplies data structures to represent 2D and 3D geometric models. -This manual explains how to use Modeling Data. For advanced information on modeling data, see our E-learning & Training offerings. +This manual explains how to use Modeling Data. @section occt_modat_1 Geometry Utilities @@ -548,181 +548,6 @@ However, the Geom package essentially provides data structures, not algorithms. You can refer to the GC package to find more evolved construction algorithms for Geom objects. -@section occt_modat_4 Properties of Shapes - -@subsection occt_modat_4_1 Local Properties of Shapes - -BRepLProp package provides the Local Properties of Shapes component, -which contains algorithms computing various local properties on edges and faces in a BRep model. - -The local properties which may be queried are: - - * for a point of parameter u on a curve which supports an edge : - * the point, - * the derivative vectors, up to the third degree, - * the tangent vector, - * the normal, - * the curvature, and the center of curvature; - * for a point of parameter (u, v) on a surface which supports a face : - * the point, - * the derivative vectors, up to the second degree, - * the tangent vectors to the u and v isoparametric curves, - * the normal vector, - * the minimum or maximum curvature, and the corresponding directions of curvature; - * the degree of continuity of a curve which supports an edge, built by the concatenation of two other edges, at their junction point. - -Analyzed edges and faces are described as BRepAdaptor curves and surfaces, -which provide shapes with an interface for the description of their geometric support. -The base point for local properties is defined by its u parameter value on a curve, or its (u, v) parameter values on a surface. - -@subsection occt_modat_4_2 Local Properties of Curves and Surfaces - -The "Local Properties of Curves and Surfaces" component provides algorithms for computing various local properties on a Geom curve (in 2D or 3D space) or a surface. It is composed of: - - * Geom2dLProp package, which allows computing Derivative and Tangent vectors (normal and curvature) of a parametric point on a 2D curve; - * GeomLProp package, which provides local properties on 3D curves and surfaces - * LProp package, which provides an enumeration used to characterize a particular point on a 2D curve. - -Curves are either Geom_Curve curves (in 3D space) or Geom2d_Curve curves (in the plane). -Surfaces are Geom_Surface surfaces. The point on which local properties are calculated -is defined by its u parameter value on a curve, and its (u,v) parameter values on a surface. - -It is possible to query the same local properties for points as mentioned above, and additionally for 2D curves: - - * the points corresponding to a minimum or a maximum of curvature; - * the inflection points. - - -#### Example: How to check the surface concavity - -To check the concavity of a surface, proceed as follows: - - 1. Sample the surface and compute at each point the Gaussian curvature. - 2. If the value of the curvature changes of sign, the surface is concave or convex depending on the point of view. - 3. To compute a Gaussian curvature, use the class SLprops from GeomLProp, which instantiates the generic class SLProps from LProp and use the method GaussianCurvature. - -@subsection occt_modat_4_2a Continuity of Curves and Surfaces - -Types of supported continuities for curves and surfaces are described in *GeomAbs_Shape* enumeration. - -In respect of curves, the following types of continuity are supported (see the figure below): - * C0 (*GeomAbs_C0*) - parametric continuity. It is the same as G0 (geometric continuity), so the last one is not represented by separate variable. - * G1 (*GeomAbs_G1*) - tangent vectors on left and on right are parallel. - * C1 (*GeomAbs_C1*) - indicates the continuity of the first derivative. - * G2 (*GeomAbs_G2*) - in addition to G1 continuity, the centers of curvature on left and on right are the same. - * C2 (*GeomAbs_C2*) - continuity of all derivatives till the second order. - * C3 (*GeomAbs_C3*) - continuity of all derivatives till the third order. - * CN (*GeomAbs_CN*) - continuity of all derivatives till the N-th order (infinite order of continuity). - -*Note:* Geometric continuity (G1, G2) means that the curve can be reparametrized to have parametric (C1, C2) continuity. - -@figure{/user_guides/modeling_data/images/modeling_data_continuity_curves.svg,"Continuity of Curves",420} - -The following types of surface continuity are supported: - * C0 (*GeomAbs_C0*) - parametric continuity (the surface has no points or curves of discontinuity). - * G1 (*GeomAbs_G1*) - surface has single tangent plane in each point. - * C1 (*GeomAbs_C1*) - indicates the continuity of the first derivatives. - * G2 (*GeomAbs_G2*) - in addition to G1 continuity, principal curvatures and directions are continuous. - * C2 (*GeomAbs_C2*) - continuity of all derivatives till the second order. - * C3 (*GeomAbs_C3*) - continuity of all derivatives till the third order. - * CN (*GeomAbs_CN*) - continuity of all derivatives till the N-th order (infinite order of continuity). - -@figure{/user_guides/modeling_data/images/modeling_data_continuity_surfaces.svg,"Continuity of Surfaces",420} - -Against single surface, the connection of two surfaces (see the figure above) defines its continuity in each intersection point only. Smoothness of connection is a minimal value of continuities on the intersection curve. - - -@subsection occt_modat_4_2b Regularity of Shared Edges - -Regularity of an edge is a smoothness of connection of two faces sharing this edge. In other words, regularity is a minimal continuity between connected faces in each point on edge. - -Edge's regularity can be set by *BRep_Builder::Continuity* method. To get the regularity use *BRep_Tool::Continuity* method. - -Some algorithms like @ref occt_modalg_6 "Fillet" set regularity of produced edges by their own algorithms. On the other hand, some other algorithms (like @ref specification__boolean_operations "Boolean Operations", @ref occt_user_guides__shape_healing "Shape Healing", etc.) do not set regularity. If the regularity is needed to be set correctly on a shape, the method *BRepLib::EncodeRegularity* can be used. It calculates and sets correct values for all edges of the shape. - -The regularity flag is extensively used by the following high level algorithms: @ref occt_modalg_6_1_2 "Chamfer", @ref occt_modalg_7_3 "Draft Angle", @ref occt_modalg_10 "Hidden Line Removal", @ref occt_modalg_9_2_3 "Gluer". - - -@subsection occt_modat_4_3 Global Properties of Shapes - -The Global Properties of Shapes component provides algorithms for computing the global -properties of a composite geometric system in 3D space, and frameworks to query the computed results. - -The global properties computed for a system are : - * mass, - * mass center, - * matrix of inertia, - * moment about an axis, - * radius of gyration about an axis, - * principal properties of inertia such as principal axis, principal moments, and principal radius of gyration. - -Geometric systems are generally defined as shapes. Depending on the way they are analyzed, these shapes will give properties of: - - * lines induced from the edges of the shape, - * surfaces induced from the faces of the shape, or - * volumes induced from the solid bounded by the shape. - -The global properties of several systems may be brought together to give the global properties of the system composed of the sum of all individual systems. - -The Global Properties of Shapes component is composed of: -* seven functions for computing global properties of a shape: one function for lines, two functions for surfaces and four functions for volumes. The choice of functions depends on input parameters and algorithms used for computation (BRepGProp global functions), -* a framework for computing global properties for a set of points (GProp_PGProps), -* a general framework to bring together the global properties retained by several more elementary frameworks, and provide a general programming interface to consult computed global properties. - -Packages *GeomLProp* and *Geom2dLProp* provide algorithms calculating the local properties of curves and surfaces - -A curve (for one parameter) has the following local properties: -- Point -- Derivative -- Tangent -- Normal -- Curvature -- Center of curvature. - -A surface (for two parameters U and V) has the following local properties: -- point -- derivative for U and V) -- tangent line (for U and V) -- normal -- max curvature -- min curvature -- main directions of curvature -- mean curvature -- Gaussian curvature - -The following methods are available: -* *CLProps* -- calculates the local properties of a curve (tangency, curvature,normal); -* *CurAndInf2d* -- calculates the maximum and minimum curvatures and the inflection points of 2d curves; -* *SLProps* -- calculates the local properties of a surface (tangency, the normal and curvature). -* *Continuity* -- calculates regularity at the junction of two curves. - -Note that the B-spline curve and surface are accepted but they are not cut into pieces of the desired continuity. It is the global continuity, which is seen. - -@subsection occt_modat_4_4 Adaptors for Curves and Surfaces - -Some Open CASCADE Technology general algorithms may work theoretically on numerous types of curves or surfaces. - -To do this, they simply get the services required of the analyzed curve or surface through an interface so as to a single API, whatever the type of curve or surface. These interfaces are called adaptors. - -For example, Adaptor3d_Curve is the abstract class which provides the required services by an algorithm which uses any 3d curve. - - GeomAdaptor package provides interfaces: - * On a Geom curve; - * On a curve lying on a Geom surface; - * On a Geom surface; - - Geom2dAdaptor package provides interfaces : - * On a Geom2d curve. - - BRepAdaptor package provides interfaces: - * On a Face - * On an Edge - -When you write an algorithm which operates on geometric objects, use Adaptor3d (or Adaptor2d) objects. - -As a result, you can use the algorithm with any kind of object, if you provide for this object an interface derived from *Adaptor3d* or *Adaptor2d*. -These interfaces are easy to use: simply create an adapted curve or surface from a *Geom2d* curve, and then use this adapted curve as an argument for the algorithm? which requires it. - @section occt_modat_5 Topology @@ -763,39 +588,9 @@ Three additional packages provide tools to access and manipulate this abstract t * TopTools package provides basic tools to use on topological data structures. * TopExp package provides classes to explore and manipulate the topological data structures described in the TopoDS package. * BRepTools package provides classes to explore, manipulate, read and write BRep data structures. These more complex data structures combine topological descriptions with additional geometric information, and include rules for evaluating equivalence of different possible representations of the same object, for example, a point. + -@subsection occt_modat_5_1 Shape Location - -A local coordinate system can be viewed as either of the following: -- A right-handed trihedron with an origin and three orthonormal vectors. The *gp_Ax2* package corresponds to this definition. -- A transformation of a +1 determinant, allowing the transformation of coordinates between local and global references frames. This corresponds to the *gp_Trsf*. - -*TopLoc* package distinguishes two notions: -- *TopLoc_Datum3D* class provides the elementary reference coordinate, represented by a right-handed orthonormal system of axes or by a right-handed unitary transformation. -- *TopLoc_Location* class provides the composite reference coordinate made from elementary ones. It is a marker composed of a chain of references to elementary markers. The resulting cumulative transformation is stored in order to avoid recalculating the sum of the transformations for the whole list. - -@figure{/user_guides/modeling_data/images/modeling_data_image005.png,"Structure of TopLoc_Location",420} - -Two reference coordinates are equal if they are made up of the same elementary coordinates in the same order. There is no numerical comparison. Two coordinates can thus correspond to the same transformation without being equal if they were not built from the same elementary coordinates. - -For example, consider three elementary coordinates: -R1, R2, R3 -The composite coordinates are: -C1 = R1 * R2, -C2 = R2 * R3 -C3 = C1 * R3 -C4 = R1 * C2 - -**NOTE** C3 and C4 are equal because they are both R1 * R2 * R3. - -The *TopLoc* package is chiefly targeted at the topological data structure, but it can be used for other purposes. - -Change of coordinates ---------------------- - -*TopLoc_Datum3D* class represents a change of elementary coordinates. Such changes must be shared so this class inherits from *Standard_Transient*. The coordinate is represented by a transformation *gp_Trsfpackage*. This transformation has no scaling factor. - -@subsection occt_modat_5_2 Naming shapes, sub-shapes, their orientation and state +@subsection occt_modat_5_2 Shape content The **TopAbs** package provides general enumerations describing the basic concepts of topology and methods to handle these enumerations. It contains no classes. This package has been separated from the rest of the topology because the notions it contains are sufficiently general to be used by all topological tools. This avoids redefinition of enumerations by remaining independent of modeling resources. The TopAbs package defines three notions: - **Type** *TopAbs_ShapeEnum*; @@ -879,6 +674,37 @@ The State enumeration can also be used to specify various parts of an object. Th @figure{/user_guides/modeling_data/images/modeling_data_image010.png,"State specifies the parts of an edge intersecting a face",420} +@subsubsection occt_modat_5_1 Shape Location + +A local coordinate system can be viewed as either of the following: +- A right-handed trihedron with an origin and three orthonormal vectors. The *gp_Ax2* package corresponds to this definition. +- A transformation of a +1 determinant, allowing the transformation of coordinates between local and global references frames. This corresponds to the *gp_Trsf*. + +*TopLoc* package distinguishes two notions: +- *TopLoc_Datum3D* class provides the elementary reference coordinate, represented by a right-handed orthonormal system of axes or by a right-handed unitary transformation. +- *TopLoc_Location* class provides the composite reference coordinate made from elementary ones. It is a marker composed of a chain of references to elementary markers. The resulting cumulative transformation is stored in order to avoid recalculating the sum of the transformations for the whole list. + +@figure{/user_guides/modeling_data/images/modeling_data_image005.png,"Structure of TopLoc_Location",420} + +Two reference coordinates are equal if they are made up of the same elementary coordinates in the same order. There is no numerical comparison. Two coordinates can thus correspond to the same transformation without being equal if they were not built from the same elementary coordinates. + +For example, consider three elementary coordinates: +R1, R2, R3 +The composite coordinates are: +C1 = R1 * R2, +C2 = R2 * R3 +C3 = C1 * R3 +C4 = R1 * C2 + +**NOTE** C3 and C4 are equal because they are both R1 * R2 * R3. + +The *TopLoc* package is chiefly targeted at the topological data structure, but it can be used for other purposes. + +Change of coordinates +--------------------- + +*TopLoc_Datum3D* class represents a change of elementary coordinates. Such changes must be shared so this class inherits from *Standard_Transient*. The coordinate is represented by a transformation *gp_Trsfpackage*. This transformation has no scaling factor. + @subsection occt_modat_5_3 Manipulating shapes and sub-shapes The *TopoDS* package describes the topological data structure with the following characteristics: @@ -1106,7 +932,7 @@ The following steps are performed: } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -@subsection occt_modat_5_5 Lists and Maps of Shapes +@subsubsection occt_modat_5_5 Lists and Maps of Shapes **TopTools** package contains tools for exploiting the *TopoDS* data structure. It is an instantiation of the tools from *TCollection* package with the Shape classes of *TopoDS*. @@ -1257,7 +1083,7 @@ Below is the auxiliary function, which copies the element of rank *i* from the m } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -@subsubsection occt_modat_5_5_1 Wire Explorer +**Wire Explorer** *BRepTools_WireExplorer* class can access edges of a wire in their order of connection. @@ -1277,22 +1103,180 @@ For example, in the wire in the image we want to recuperate the edges in the ord } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -@subsection occt_modat_5_6 Storage of shapes +@section occt_modat_4 Properties of Shapes -*BRepTools* and *BinTools* packages contain methods *Read* and *Write* allowing to read and write a Shape to/from a stream or a file. -The methods provided by *BRepTools* package use ASCII storage format; *BinTools* package uses binary format. -Each of these methods has two arguments: -- a *TopoDS_Shape* object to be read/written; -- a stream object or a file name to read from/write to. +@subsection occt_modat_4_1 Local Properties of Shapes -The following sample code reads a shape from ASCII file and writes it to a binary one: +BRepLProp package provides the Local Properties of Shapes component, +which contains algorithms computing various local properties on edges and faces in a BRep model. -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.cpp} - TopoDS_Shape aShape; - if (BRepTools::Read (aShape, "source_file.txt")) { - BinTools::Write (aShape, "result_file.bin"); - } -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +The local properties which may be queried are: + + * for a point of parameter u on a curve which supports an edge : + * the point, + * the derivative vectors, up to the third degree, + * the tangent vector, + * the normal, + * the curvature, and the center of curvature; + * for a point of parameter (u, v) on a surface which supports a face : + * the point, + * the derivative vectors, up to the second degree, + * the tangent vectors to the u and v isoparametric curves, + * the normal vector, + * the minimum or maximum curvature, and the corresponding directions of curvature; + * the degree of continuity of a curve which supports an edge, built by the concatenation of two other edges, at their junction point. + +Analyzed edges and faces are described as BRepAdaptor curves and surfaces, +which provide shapes with an interface for the description of their geometric support. +The base point for local properties is defined by its u parameter value on a curve, or its (u, v) parameter values on a surface. + +@subsection occt_modat_4_2 Local Properties of Curves and Surfaces + +The "Local Properties of Curves and Surfaces" component provides algorithms for computing various local properties on a Geom curve (in 2D or 3D space) or a surface. It is composed of: + + * Geom2dLProp package, which allows computing Derivative and Tangent vectors (normal and curvature) of a parametric point on a 2D curve; + * GeomLProp package, which provides local properties on 3D curves and surfaces + * LProp package, which provides an enumeration used to characterize a particular point on a 2D curve. + +Curves are either Geom_Curve curves (in 3D space) or Geom2d_Curve curves (in the plane). +Surfaces are Geom_Surface surfaces. The point on which local properties are calculated +is defined by its u parameter value on a curve, and its (u,v) parameter values on a surface. + +It is possible to query the same local properties for points as mentioned above, and additionally for 2D curves: + + * the points corresponding to a minimum or a maximum of curvature; + * the inflection points. + + +#### Example: How to check the surface concavity + +To check the concavity of a surface, proceed as follows: + + 1. Sample the surface and compute at each point the Gaussian curvature. + 2. If the value of the curvature changes of sign, the surface is concave or convex depending on the point of view. + 3. To compute a Gaussian curvature, use the class SLprops from GeomLProp, which instantiates the generic class SLProps from LProp and use the method GaussianCurvature. + +@subsection occt_modat_4_2a Continuity of Curves and Surfaces + +Types of supported continuities for curves and surfaces are described in *GeomAbs_Shape* enumeration. + +In respect of curves, the following types of continuity are supported (see the figure below): + * C0 (*GeomAbs_C0*) - parametric continuity. It is the same as G0 (geometric continuity), so the last one is not represented by separate variable. + * G1 (*GeomAbs_G1*) - tangent vectors on left and on right are parallel. + * C1 (*GeomAbs_C1*) - indicates the continuity of the first derivative. + * G2 (*GeomAbs_G2*) - in addition to G1 continuity, the centers of curvature on left and on right are the same. + * C2 (*GeomAbs_C2*) - continuity of all derivatives till the second order. + * C3 (*GeomAbs_C3*) - continuity of all derivatives till the third order. + * CN (*GeomAbs_CN*) - continuity of all derivatives till the N-th order (infinite order of continuity). + +*Note:* Geometric continuity (G1, G2) means that the curve can be reparametrized to have parametric (C1, C2) continuity. + +@figure{/user_guides/modeling_data/images/modeling_data_continuity_curves.svg,"Continuity of Curves",420} + +The following types of surface continuity are supported: + * C0 (*GeomAbs_C0*) - parametric continuity (the surface has no points or curves of discontinuity). + * G1 (*GeomAbs_G1*) - surface has single tangent plane in each point. + * C1 (*GeomAbs_C1*) - indicates the continuity of the first derivatives. + * G2 (*GeomAbs_G2*) - in addition to G1 continuity, principal curvatures and directions are continuous. + * C2 (*GeomAbs_C2*) - continuity of all derivatives till the second order. + * C3 (*GeomAbs_C3*) - continuity of all derivatives till the third order. + * CN (*GeomAbs_CN*) - continuity of all derivatives till the N-th order (infinite order of continuity). + +@figure{/user_guides/modeling_data/images/modeling_data_continuity_surfaces.svg,"Continuity of Surfaces",420} + +Against single surface, the connection of two surfaces (see the figure above) defines its continuity in each intersection point only. Smoothness of connection is a minimal value of continuities on the intersection curve. + + +@subsection occt_modat_4_2b Regularity of Shared Edges + +Regularity of an edge is a smoothness of connection of two faces sharing this edge. In other words, regularity is a minimal continuity between connected faces in each point on edge. + +Edge's regularity can be set by *BRep_Builder::Continuity* method. To get the regularity use *BRep_Tool::Continuity* method. + +Some algorithms like @ref occt_modalg_6 "Fillet" set regularity of produced edges by their own algorithms. On the other hand, some other algorithms (like @ref specification__boolean_operations "Boolean Operations", @ref occt_user_guides__shape_healing "Shape Healing", etc.) do not set regularity. If the regularity is needed to be set correctly on a shape, the method *BRepLib::EncodeRegularity* can be used. It calculates and sets correct values for all edges of the shape. + +The regularity flag is extensively used by the following high level algorithms: @ref occt_modalg_6_1_2 "Chamfer", @ref occt_modalg_7_3 "Draft Angle", @ref occt_modalg_10 "Hidden Line Removal", @ref occt_modalg_9_2 "Gluer". + + +@subsection occt_modat_4_3 Global Properties of Shapes + +The Global Properties of Shapes component provides algorithms for computing the global +properties of a composite geometric system in 3D space, and frameworks to query the computed results. + +The global properties computed for a system are : + * mass, + * mass center, + * matrix of inertia, + * moment about an axis, + * radius of gyration about an axis, + * principal properties of inertia such as principal axis, principal moments, and principal radius of gyration. + +Geometric systems are generally defined as shapes. Depending on the way they are analyzed, these shapes will give properties of: + + * lines induced from the edges of the shape, + * surfaces induced from the faces of the shape, or + * volumes induced from the solid bounded by the shape. + +The global properties of several systems may be brought together to give the global properties of the system composed of the sum of all individual systems. + +The Global Properties of Shapes component is composed of: +* seven functions for computing global properties of a shape: one function for lines, two functions for surfaces and four functions for volumes. The choice of functions depends on input parameters and algorithms used for computation (BRepGProp global functions), +* a framework for computing global properties for a set of points (GProp_PGProps), +* a general framework to bring together the global properties retained by several more elementary frameworks, and provide a general programming interface to consult computed global properties. + +Packages *GeomLProp* and *Geom2dLProp* provide algorithms calculating the local properties of curves and surfaces + +A curve (for one parameter) has the following local properties: +- Point +- Derivative +- Tangent +- Normal +- Curvature +- Center of curvature. + +A surface (for two parameters U and V) has the following local properties: +- point +- derivative for U and V) +- tangent line (for U and V) +- normal +- max curvature +- min curvature +- main directions of curvature +- mean curvature +- Gaussian curvature + +The following methods are available: +* *CLProps* -- calculates the local properties of a curve (tangency, curvature,normal); +* *CurAndInf2d* -- calculates the maximum and minimum curvatures and the inflection points of 2d curves; +* *SLProps* -- calculates the local properties of a surface (tangency, the normal and curvature). +* *Continuity* -- calculates regularity at the junction of two curves. + +Note that the B-spline curve and surface are accepted but they are not cut into pieces of the desired continuity. It is the global continuity, which is seen. + +@subsection occt_modat_4_4 Adaptors for Curves and Surfaces + +Some Open CASCADE Technology general algorithms may work theoretically on numerous types of curves or surfaces. + +To do this, they simply get the services required of the analyzed curve or surface through an interface so as to a single API, whatever the type of curve or surface. These interfaces are called adaptors. + +For example, Adaptor3d_Curve is the abstract class which provides the required services by an algorithm which uses any 3d curve. + + GeomAdaptor package provides interfaces: + * On a Geom curve; + * On a curve lying on a Geom surface; + * On a Geom surface; + + Geom2dAdaptor package provides interfaces : + * On a Geom2d curve. + + BRepAdaptor package provides interfaces: + * On a Face + * On an Edge + +When you write an algorithm which operates on geometric objects, use Adaptor3d (or Adaptor2d) objects. + +As a result, you can use the algorithm with any kind of object, if you provide for this object an interface derived from *Adaptor3d* or *Adaptor2d*. +These interfaces are easy to use: simply create an adapted curve or surface from a *Geom2d* curve, and then use this adapted curve as an argument for the algorithm? which requires it. @section occt_modat_6 Bounding boxes diff --git a/dox/user_guides/tobj/images/tobj_image003.png b/dox/user_guides/ocaf/images/tobj_image003.png similarity index 100% rename from dox/user_guides/tobj/images/tobj_image003.png rename to dox/user_guides/ocaf/images/tobj_image003.png diff --git a/dox/user_guides/tobj/images/tobj_image004.png b/dox/user_guides/ocaf/images/tobj_image004.png similarity index 100% rename from dox/user_guides/tobj/images/tobj_image004.png rename to dox/user_guides/ocaf/images/tobj_image004.png diff --git a/dox/user_guides/tobj/images/tobj_image005.png b/dox/user_guides/ocaf/images/tobj_image005.png similarity index 100% rename from dox/user_guides/tobj/images/tobj_image005.png rename to dox/user_guides/ocaf/images/tobj_image005.png diff --git a/dox/user_guides/tobj/images/tobj_image006.png b/dox/user_guides/ocaf/images/tobj_image006.png similarity index 100% rename from dox/user_guides/tobj/images/tobj_image006.png rename to dox/user_guides/ocaf/images/tobj_image006.png diff --git a/dox/user_guides/tobj/images/tobj_image007.png b/dox/user_guides/ocaf/images/tobj_image007.png similarity index 100% rename from dox/user_guides/tobj/images/tobj_image007.png rename to dox/user_guides/ocaf/images/tobj_image007.png diff --git a/dox/user_guides/tobj/images/tobj_image008.png b/dox/user_guides/ocaf/images/tobj_image008.png similarity index 100% rename from dox/user_guides/tobj/images/tobj_image008.png rename to dox/user_guides/ocaf/images/tobj_image008.png diff --git a/dox/user_guides/ocaf/ocaf.md b/dox/user_guides/ocaf/ocaf.md index e5694279e3..80dc90e74f 100644 --- a/dox/user_guides/ocaf/ocaf.md +++ b/dox/user_guides/ocaf/ocaf.md @@ -6,8 +6,7 @@ OCAF {#occt_user_guides__ocaf} @section occt_ocaf_1 Introduction This manual explains how to use the Open CASCADE Application Framework (OCAF). -It provides basic documentation on using OCAF. For advanced information on OCAF -and its applications, see our E-learning & Training offerings. +It provides basic documentation on using OCAF. @subsection occt_ocaf_1_1 Purpose of OCAF @@ -512,7 +511,7 @@ Choosing the alternative way of implementation of new data types allows to forge Let’s study the implementation of the same data type in both ways by the example of transformation represented by *gp_Trsf* class. The class *gp_Trsf* defines the transformation according to the type (*gp_TrsfForm*) and a set of parameters of the particular type of transformation (two points or a vector for translation, an axis and an angle for rotation, and so on). -1. The first way: creation of a new attribute. The implementation of the transformation by creation of a new attribute is represented in the @ref occt_ocaf_11 "Samples". +1. The first way: creation of a new attribute. The implementation of the transformation by creation of a new attribute is represented in the @ref samples__ocaf "Samples". 2. The second way: creation of a new data type by means of combination of standard attributes. Depending on the type of transformation it may be kept in data framework by different standard attributes. For example, a translation is defined by two points. Therefore the data tree for translation looks like this: * Type of transformation (gp_Translation) as *TDataStd_Integer*; @@ -1820,6 +1819,912 @@ Both the XML format and the XML OCAF persistence code are extensible in the sens * Add (in the new *DocumentStorageDriver*) the *targetNamespace* accompanied with its prefix, using method *XmlDrivers_DocumentStorageDriver::AddNamespace*. The same is done for all namespaces objects which are used by the new persistence, with the exception of the "ocaf" namespace. * Pass (in every OCAF attribute driver) the namespace prefix of the *targetNamespace* to the constructor of *XmlMDF_ADriver*. +@section occt_tobj TObj Package + +@subsection occt_tobj_1 Introduction + +This document describes the package TObj, which is an add-on +to the Open CASCADE Application Framework (OCAF). + +This package provides a set of classes and auxiliary tools facilitating +the creation of object-oriented data models on top of low-level OCAF data structures. +This includes: + + * Definition of classes representing data objects. Data objects store their data using primitive OCAF attributes, taking advantage of OCAF mechanisms for Undo/Redo and persistence. At the same time they provide a higher level abstraction over the pure OCAF document structure (labels / attributes). + * Organization of the data model as a hierarchical (tree-like) structure of objects. + * Support of cross-references between objects within one model or among different models. In case of cross-model references the models should depend hierarchically. + * Persistence mechanism for storing *TObj* objects in OCAF files, which allows storing and retrieving objects of derived types without writing additional code to support persistence. + +This document describes basic principles of logical and physical organization +of TObj-based data models and typical approaches to implementation of classes representing model objects. + +@subsubsection occt_tobj_1_1 Applicability + +The main purpose of the *TObj* data model is rapid development +of the object-oriented data models for applications, using the existing +functionality provided by OCAF (Undo/Redo and persistence) +without the necessity to redevelop such functionality from scratch. + +As opposed to using bare OCAF (at the level of labels and attributes), +TObj facilitates dealing with higher level abstracts, which are closer +to the application domain. It works best when the application data are naturally +organized in hierarchical structures, and is especially useful for complex data +models with dependencies between objects belonging to different parts of the model. + +It should be noted that *TObj* is efficient for representing data structures containing +a limited number of objects at each level of the data structure (typically less than 1000). +A greater number of objects causes performance problems due to list-based organization of OCAF documents. Therefore, other methods of storage, such as arrays, are advisable for data models or their sub-parts containing a great number of uniform objects. However, these methods +can be combined with the usage of *TObj* to represent the high-level structure of the model. + +@subsection occt_tobj_2 TObj Model + +@subsubsection occt_tobj_2_1 TObj Model structure + +In the *TObj* data model the data are separated from the interfaces that manage them. + +It should be emphasized that *TObj* package defines only the interfaces and the basic structure of the model and objects, while the actual contents and structure of the model of a particular application are defined by its specific classes inherited from *TObj* classes. The implementation can add its own features or even change the default behaviour and the data layout, though this is not recommended. + +Logically the *TObj* data model is represented as a tree of model objects, with upper-level objects typically being collections of other objects (called *partitions*, represented by the class *TObj_Partition*). The root object of the model is called the *Main partition* and is maintained by the model itself. This partition contains a list of sub-objects called its *children* each sub-object may contain its own children (according to its type), etc. + +@figure{/user_guides/ocaf/images/tobj_image003.png,"TObj Data Model",240} + +As the *TObj* Data Model is based on OCAF (Open CASCADE Application Framework) technology, +it stores its data in the underlying OCAF document. The OCAF document consists of a tree of +items called *labels*. Each label has some data attached to it in the form of *attributes*, +and may contain an arbitrary number of sub-labels. Each sub-label is identified by its sequential +number called the *tag*. The complete sequence of tag numbers of the label +and its parents starting from the document root constitutes the complete *entry* +of the label, which uniquely identifies its position in the document. + +Generally the structure of the OCAF tree of the *TObj* data +model corresponds to the logical structure of the model and can be presented as in the following picture: + +@figure{/user_guides/ocaf/images/tobj_image004.png,"TObj Data Model mapped on OCAF document",360} + +All data of the model are stored in the root label (0:1) of the OCAF document. +An attribute *TObj_TModel* is located in this root label. It +stores the object of type *TObj_Model*. This object serves as a main interface tool +to access all data and functionalities of the data model. + +In simple cases all data needed by the application may be +contained in a single data model. Moreover, *TObj* gives the possibility to +distribute the data between several interconnected data models. This can be +especially useful for the applications dealing with great amounts of data. because +only the data required for the current operation is loaded in the memory at one time. +It is presumed that the models have a hierarchical (tree-like) structure, +where the objects of the child models can refer to the objects of the parent +models, not vice-versa. Provided that the correct order of loading and closing +of the models is ensured, the *TObj* classes will maintain references between the objects automatically. + +@subsubsection occt_tobj_2_2 Data Model basic features + +The class *TObj_Model* describing the data model provides the following functionalities: + + * Loading and saving of the model from or in a file (methods *Load* and *Save*) + * Closing and removal of the model from memory (method *Close*) + * Definition of the full file name of the persistence storage for this model (method *GetFile*) + * Tools to organize data objects in partitions and iterate on objects (methods *GetObjects*, *GetMainPartition*, *GetChildren*, *getPartition*, *getElementPartition*) + * Mechanism to give unique names to model objects + * Copy (*clone*) of the model (methods *NewEmpty* and *Paste*) + * Support of earlier model formats for proper conversion of a model loaded from a file written by a previous version of the application (methods *GetFormatVersion* and *SetFormatVersion*) + * Interface to check and update the model if necessary (method *Update*) + * Support of several data models in one application. For this feature use OCAF multi-transaction manager, unique names and GUIDs of the data model (methods *GetModelName*, *GetGUID*) + +@subsubsection occt_tobj_2_3 Model Persistence + +The persistent representation of any OCAF model is contained in an XML or a binary file, +which is defined by the format string returned by the method *GetFormat*. +The default implementation works with a binary OCAF document format (*BinOcaf*). +The other available format is *XmlOcaf*. The class **TObj_Model** declares and provides a default +implementation of two virtual methods: + +~~~~~{.cpp} + virtual Standard_Boolean Load (const char* theFile); + virtual Standard_Boolean SaveAs (const char* theFile); +~~~~~ + +which retrieve and store the model from or +in the OCAF file. The descendants +should define the following protected method to support Load and Save operations: + +~~~~~{.cpp} + virtual Standard_Boolean initNewModel (const Standard_Boolean IsNew); +~~~~~ + +This method is called by *Load* after creation of a new model +or after its loading from the file; its purpose is to perform +the necessary initialization of the model (such as creation of necessary top-level +partitions, model update due to version changes etc.). Note that if +the specified file does not exist, method *Load* will create +a new document and call *initNewModel* with the argument **True**. +If the file has been normally loaded, the argument **False** is passed. +Thus, a new empty *TObj* model is created by calling *Load* with an empty +string or the path to a nonexistent file as argument. + +The method *Load* returns **True** if the model has been retrieved successfully +(or created a new), or **False** if the model could not be loaded. +If no errors have been detected during initialization (model retrieval or creation), +the virtual method *AfterRetrieval* is invoked for all objects of the model. +This method initializes or updates the objects immediately after the model initialization. +It could be useful when some object data should be imported from an OCAF attribute into transient +fields which could be changed outside of the OCAF transaction mechanism. +Such fields can be stored into OCAF attributes for saving into persistent storage during the save operation. + +To avoid memory leaks, the *TObj_Model* class destructor invokes *Close* method +which clears the OCAF document and removes all data from memory before the model is destroyed. + +For XML and binary persistence of the *TObj* data model the corresponding drivers are implemented +in *BinLDrivers*, *BinMObj* and *XmlLDrivers*, *XmlMObj* packages. +These packages contain retrieval and storage drivers for the model, model objects and custom attributes +from the *TObj* package. The schemas support persistence for the standard OCAF and *TObj* attributes. +This is sufficient for the implementation of simple data models, but +in some cases it can be reasonable to add specific OCAF attributes to +facilitate the storage of the data specific to the application. +In this case the schema should be extended using the standard OCAF mechanism. + +@subsubsection occt_tobj_2_4 Access to the objects in the model + +All objects in the model are stored in the main partition and accessed by iterators. +To access all model objects use: + +~~~~~{.cpp} + virtual Handle(TObj_ObjectIterator) GetObjects () const; +~~~~~ + +This method returns a recursive iterator on all objects stored in the model. + +~~~~~{.cpp} + virtual Handle(TObj_ObjectIterator) GetChildren () const; +~~~~~ + +This method returns an iterator on child objects of the main partition. +Use the following method to get the main partition: + +~~~~~{.cpp} + Handle(TObj_Partition) GetMainPartition() const; +~~~~~ + +To receive the iterator on objects of a specific type *AType* use the following call: + +~~~~~{.cpp} + GetMainPartition()->GetChildren(STANDARD_TYPE(AType) ); +~~~~~ + +The set of protected methods is provided for descendant classes to deal with partitions: + +~~~~~{.cpp} + virtual Handle(TObj_Partition) getPartition (const TDF_Label, const Standard_Boolean theHidden) const; +~~~~~ + +This method returns (creating if necessary) a partition in the specified label of the document. +The partition can be created as hidden (*TObj_HiddenPartition* class). +A hidden partition can be useful to distinguish the data that +should not be visible to the user when browsing the model in the application. + +The following two methods allow getting (creating) a partition +in the sub-label of the specified label in the document +(the label of the main partition for the second method) and with the given name: + +~~~~~{.cpp} + virtual Handle(TObj_Partition) getPartition (const TDF_Label, const Standard_Integer theIndex, const TCollection_ExtendedString& theName, const Standard_Boolean theHidden) const; + virtual Handle(TObj_Partition) getPartition (const Standard_Integer theIndex, const TCollection_ExtendedString& theName, const Standard_Boolean theHidden) const; +~~~~~ + +If the default object naming and the name register mechanism +is turned on, the object can be found in the model by its unique name: + +~~~~~{.cpp} + Handle(TObj_Object) FindObject (const Handle(TCollection_HExtendedString)& theName, const Handle(TObj_TNameContainer)& theDictionary) const; +~~~~~ + +@subsubsection occt_tobj_2_5 Own model data + +The model object can store its own data in the Data label +of its main partition, however, there is no standard API for +setting and getting these data types. The descendants can add +their own data using standard OCAF methods. The enumeration DataTag is defined +in *TObj_Model* to avoid conflict of data labels used by this class +and its descendants, similarly to objects (see below). + +@subsubsection occt_tobj_2_6 Object naming + +The basic implementation of *TObj_Model* provides the default +naming mechanism: all objects must have unique names, +which are registered automatically in the data model dictionary. +The dictionary is a *TObj_TNameContainer* +attribute whose instance is located in the model root label. +If necessary, the developer can add several dictionaries into +the specific partitions, providing the name registration in the +correct name dictionary and restoring the name map after document is loaded from file. +To ignore name registering it is necessary to redefine the methods *SetName*, +*AfterRetrieval* of the *TObj_Object* class and skip the registration of the object name. +Use the following methods for the naming mechanism: + +~~~~~{.cpp} + Standard_Boolean IsRegisteredName (const Handle(TCollection_HExtendedString)& theName, const Handle(TObj_TNameContainer)& theDictionary ) const; +~~~~~ + +Returns **True** if the object name is already registered in the indicated (or model) dictionary. + +~~~~~{.cpp} + void RegisterName (const Handle(TCollection_HExtendedString)& theName, const TDF_Label& theLabel, const Handle(TObj_TNameContainer)& theDictionary ) const; +~~~~~ + +Registers the object name with the indicated label where the object +is located in the OCAF document. Note that the default implementation +of the method *SetName* of the object registers the new name automatically +(if the name is not yet registered for any other object) + +~~~~~{.cpp} + void UnRegisterName (const Handle(TCollection_HExtendedString)& theName, const Handle(TObj_TNameContainer)& theDictionary ) const; +~~~~~ + +Unregisters the name from the dictionary. Ther names of *TObj* model +objects are removed from the dictionary when the objects are deleted from the model. + +~~~~~{.cpp} + Handle(TObj_TNameContainer) GetDictionary() const; +~~~~~ + +Returns a default instance of the model dictionary (located at the model root label). +The default implementation works only with one dictionary. +If there are a necessity to have more than one dictionary for the model objects, +it is recommended to redefine the corresponding virtual method of TObj_Object +that returns the dictionary where names of objects should be registered. + +@subsubsection occt_tobj_2_7 API for transaction mechanism + +Class *TObj_Model* provides the API for transaction mechanism (supported by OCAF): + +~~~~~{.cpp} + Standard_Boolean HasOpenCommand() const; +~~~~~ + +Returns True if a Command transaction is open + +~~~~~{.cpp} + void OpenCommand() const; +~~~~~ + +Opens a new command transaction. + +~~~~~{.cpp} + void CommitCommand() const; +~~~~~ + +Commits the Command transaction. Does nothing If there is no open Command transaction. + +~~~~~{.cpp} + void AbortCommand() const; +~~~~~ + +Aborts the Command transaction. Does nothing if there is no open Command transaction. + +~~~~~{.cpp} + Standard_Boolean IsModified() const; +~~~~~ + +Returns True if the model document has a modified status (has changes after the last save) + +~~~~~{.cpp} + void SetModified( const Standard_Boolean ); +~~~~~ + +Changes the modified status by force. For synchronization of transactions +within several *TObj_Model* documents use class *TDocStd_MultiTransactionManager*. + +@subsubsection occt_tobj_28 Model format and version + +Class *TObj_Model* provides the descendant classes with a means to control +the format of the persistent file by choosing the schema used to store or retrieve operations. + +~~~~~{.cpp} + virtual TCollection_ExtendedString GetFormat () const; +~~~~~ + +Returns the string *TObjBin* or *TObjXml* indicating +the current persistent mechanism. The default value is *TObjBin*. +Due to the evolution of functionality of the developed application, +the contents and the structure of its data model vary from version to version. +*TObj* package provides a basic mechanism supporting backward versions compatibility, +which means that newer versions of the application will be able to read +Data Model files created by previous versions (but not vice-versa) with a minimum loss of data. +For each type of Data Model, all known versions of the data format +should be enumerated in increasing order, incremented with every change +of the model format. The current version of the model +format is stored in the model file and can be checked upon retrieval. + +~~~~~{.cpp} + Standard_Integer GetFormatVersion() const; +~~~~~ + +Returns the format version stored in the model file + +~~~~~{.cpp} + void SetFormatVersion(const Standard_Integer theVersion); +~~~~~ + +Defines the format version used for save. + +Upon loading a model, the method *initNewModel()*, called immediately +after opening a model from disk (on the level of the OCAF document), +provides a specific code that checks the format version stored in that model. +If it is older than the current version of the application, the data update can be performed. +Each model can have its own specific conversion code +that performs the necessary data conversion to make them compliant with the current version. + +When the conversion ends the user is advised of that by the messenger interface +provided by the model (see messaging chapter for more details), +and the model version is updated. If the version of data model is not supported +(it is newer than the current or too old), the load operation should fail. +The program updating the model after version change can be implemented as static +methods directly in C++ files of the corresponding Data Model classes, +not exposing it to the other parts of the application. +These codes can use direct access to the model and objects data (attributes) +not using objects interfaces, because the data model API and object classes +could have already been changed. + +Note that this mechanism has been designed to maintain version compatibility +for the changes of data stored in the model, not for the changes of +low-level format of data files (such as the storage format of a specific OCAF attribute). +If the format of data files changes, a specific treatment on a case-by-case basis will be required. + +@subsubsection occt_tobj_2_9 Model update + +The following methods are used for model update to ensure its consistency +with respect to the other models in case of cross-model dependencies: + +~~~~~{.cpp} + virtual Standard_Boolean Update(); +~~~~~ + +This method is usually called after loading of the model. +The default implementation does nothing and returns **True**. + +~~~~~{.cpp} + virtual Standard_Boolean initNewModel( const Standard_Boolean IsNew); +~~~~~ + +This method performs model initialization, check and updates (as described above). + +~~~~~{.cpp} + virtual void updateBackReferences( const Handle(TObj_Object)& theObj); +~~~~~ + +This method is called from the previous method to update back references +of the indicated object after the retrieval of the model from file +(see data model - object relationship chapter for more details) + +@subsubsection occt_tobj_2_10 Model copying + +To copy the model between OCAF documents use the following methods: + +~~~~~{.cpp} + virtual Standard_Boolean Paste (Handle(TObj_Model) theModel, Handle(TDF_RelocationTable) theRelocTable = 0 ); +~~~~~ + +Pastes the current model to the new model. The relocation table +ensures correct copying of the sub-data shared by several parts of the model. +It stores a map of processed original objects of relevant types in their copies. + +~~~~~{.cpp} + virtual Handle(TObj_Model) NewEmpty() = 0; +~~~~~ + +Redefines a pure virtual method to create a new empty instance of the model. + +~~~~~{.cpp} + void CopyReferences ( const Handle(TObj_Model)& theTarget, const Handle(TDF_RelocationTable)& theRelocTable); +~~~~~ + +Copies the references from the current model to the target model. + +@subsubsection occt_tobj_2_11 Messaging + +The messaging is organised using Open CASCADE Messenger from the package Message. +The messenger is stored as the field of the model instance +and can be set and retrieved by the following methods: + +~~~~~{.cpp} + void SetMessenger( const Handle(Message_Messenger)& ); + Handle(Message_Messenger) Messenger() const; +~~~~~ + +A developer should create his own instance of the Messenger +bound to the application user interface, and attribute it to the model +for future usage. In particular the messenger is used for reporting +errors and warnings in the persistence mechanism. +Each message has a unique string identifier (key). +All message keys are stored in a special resource file TObj.msg. +This file should be loaded at the start of the application +by call to the appropriate method of the class *Message_MsgFile*. + +@subsection occt_tobj_3 Model object + +Class *TObj_Object* provides basic interface and default implementation +of important features of *TObj* model objects. This implementation defines +basic approaches that are recommended for all descendants, +and provides tools to facilitate their usage. + +@figure{/user_guides/ocaf/images/tobj_image005.png,"TObj objects hierarchy",170} + +@subsubsection occt_tobj_3_1 Separation of data and interface + +In the *TObj* data model, the data are separated from the interfaces that manage them. +The data belonging to a model object are stored in its root label and sub-labels +in the form of standard OCAF attributes. This allows using standard OCAF mechanisms +for work with these data, and eases the implementation of the persistence mechanism. + +The instance of the interface which serves as an API for managing object data +(e.g. represents the model object) is stored in the root label of the object, +and typically does not bring its own data. The interface classes are organized in a hierarchy +corresponding to the natural hierarchy of the model objects according to the application. + +In the text below the term 'object' is used to denote either the instance +of the interface class or the object itself (both interface and data stored in OCAF). + +The special type of attribute *TObj_TObject* is used for storing instances of objects interfaces +in the OCAF tree. *TObj_TObject* is a simple container for the object of type *TObj_Object*. +All objects (interfaces) of the data model inherit this class. + +@figure{/user_guides/ocaf/images/tobj_image006.png,"TObj object stored on OCAF label",360} + + +@subsubsection occt_tobj_3_2 Basic features + +The *TObj_Object* class provides some basic features that can be inherited (or, if necessary, redefined) by the descendants: + + * Gives access to the model to which the object belongs (method *GetModel*) and to the OCAF label in which the object is stored (method *GetLabel*). + * Supports references (and back references) to other objects in the same or in another model (methods *getReference*, *setReference*, *addReference*, *GetReferences*, *GetBackReferences*, *AddBackReference*, *RemoveBackReference*, *ReplaceReference*) + * Provides the ability to contain child objects, as it is actual for partition objects (methods *GetChildren*, *GetFatherObject*) + * Organizes its data in the OCAF structure by separating the sub-labels of the main label intended for various kinds of data and providing tools to organize these data (see below). The kinds of data stored separately are: + * Child objects stored in the label returned by the method *GetChildLabel* + * References to other objects stored in the label returned by the method *GetReferenceLabel* + * Other data, both common to all objects and specific for each subtype of the model object, are stored in the label returned by the method *GetDataLabel* + * Provides unique names of all objects in the model (methods *GetDictionary*, *GetName*, *SetName*) + * Provides unified means to maintain persistence (implemented in descendants with the help of macros *DECLARE_TOBJOCAF_PERSISTENCE* and *IMPLEMENT_TOBJOCAF_PERSISTENCE*) + * Allows an object to remove itself from the OCAF document and check the depending objects can be deleted according to the back references (method *Detach*) + * Implements methods for identification and versioning of objects + * Manages the object interaction with OCAF Undo/Redo mechanism (method *IsAlive*, *AfterRetrieval*, *BeforeStoring*) + * Allows make a clone (methods *Clone*, *CopyReferences*, *CopyChildren*, *copyData*) + * Contains additional word of bit flags (methods *GetFlags*, *SetFlags*, *TestFlags*, *ClearFlags*) + * Defines the interface to sort the objects by rank (methods *GetOrder*, *SetOrder*) + * Provides a number of auxiliary methods for descendants to set/get the standard attribute values, such as int, double, string, arrays etc. + +An object can be received from the model by the following methods: + +~~~~~{.cpp} + static Standard_Boolean GetObj ( const TDF_Label& theLabel, Handle(TObj_Object)& theResObject, const Standard_Boolean isSuper = Standard_False ); +~~~~~ + +Returns *True* if the object has been found in the indicated label (or in the upper level label if *isSuper* is *True*). + +~~~~~{.cpp} + Handle(TObj_Object) GetFatherObject ( const Handle(Standard_Type)& theType = NULL ) const; +~~~~~ + +Returns the father object of the indicated type +for the current object (the direct father object if the type is NULL). + +@subsubsection occt_tobj_3_3 Data layout and inheritance + +As far as the data objects are separated from the interfaces and stored in the OCAF tree, +the functionality to support inheritance is required. Each object has its own data +and references stored in the labels in the OCAF tree. All data are stored in the sub-tree +of the main object label. If it is necessary to inherit a class from the base class, +the descendant class should use different labels for data and references than its ancestor. + +Therefore each *TObj* class can reserve the range of tags in each of +*Data*, *References*, and *Child* sub-labels. +The reserved range is declared by the enumeration defined +in the class scope (called DataTag, RefTag, and ChildTag, respectively). +The item *First* of the enumeration of each type is defined via the *Last* item +of the corresponding enumeration of the parent class, thus ensuring that the tag numbers +do not overlap. The item *Last* of the enumeration defines the last tag reserved by this class. +Other items of the enumeration define the tags used for storing particular data items of the object. +See the declaration of the TObj_Partition class for the example. + +*TObj_Object* class provides a set of auxiliary methods for descendants +to access the data stored in sub-labels by their tag numbers: + +~~~~~{.cpp} + TDF_Label getDataLabel (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; + TDF_Label getReferenceLabel (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; +~~~~~ + +Returns the label in *Data* or *References* sub-labels at a given tag number (theRank1). +The second argument, theRank2, allows accessing the next level of hierarchy +(theRank2-th sub-label of theRank1-th data label). +This is useful when the data to be stored are represented by multiple OCAF attributes +of the same type (e.g. sequences of homogeneous data or references). + +The get/set methods allow easily accessing the data located in the specified data label +for the most widely used data types (*Standard_Real*, *Standard_Integer*, *TCollection_HExtendedString*, + *TColStd_HArray1OfReal*, *TColStd_HArray1OfInteger*, *TColStd_HArray1OfExtendedString*). +For instance, methods provided for real numbers are: + +~~~~~{.cpp} + Standard_Real getReal (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; + Standard_Boolean setReal (const Standard_Real theValue, const Standard_Integer theRank1, const Standard_Integer theRank2 = 0, const Standard_Real theTolerance = 0.) const; +~~~~~ + +Similar methods are provided to access references to other objects: + +~~~~~{.cpp} + Handle(TObj_Object) getReference (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; + Standard_Boolean setReference (const Handle(TObj_Object) &theObject, const Standard_Integer theRank1, const Standard_Integer theRank2 = 0); +~~~~~ + +The method *addReference* gives an easy way to store a sequence of homogeneous references in one label. + +~~~~~{.cpp} + TDF_Label addReference (const Standard_Integer theRank1, const Handle(TObj_Object) &theObject); +~~~~~ + +Note that while references to other objects should be defined by descendant classes +individually according to the type of object, *TObj_Object* provides methods +to manipulate (check, remove, iterate) the existing references in the uniform way, as described below. + +@subsubsection occt_tobj_3_4 Persistence + +The persistence of the *TObj* Data Model is implemented with the help +of standard OCAF mechanisms (a schema defining necessary plugins, drivers, etc.). +This implies the possibility to store/retrieve all data that are stored +as standard OCAF attributes., The corresponding handlers are added +to the drivers for *TObj*-specific attributes. + +The special tool is provided for classes inheriting from *TObj_Object* +to add the new types of persistence without regeneration of the OCAF schema. +The class *TObj_Persistence* provides basic means for that: + + * automatic run-time registration of object types + * creation of a new object of the specified type (one of the registered types) + +Two macros defined in the file TObj_Persistence.hxx have to be included in the definition +of each model object class inheriting TObj_Object to activate the persistence mechanism: + +~~~~~{.cpp} + DECLARE_TOBJOCAF_PERSISTENCE (classname, ancestorname) +~~~~~ + +Should be included in the private section of declaration of each class inheriting +*TObj_Object* (hxx file). This macro adds an additional constructor to the object class, +and declares an auxiliary (private) class inheriting *TObj_Persistence* +that provides a tool to create a new object of the proper type. + +~~~~~{.cpp} + IMPLEMENT_TOBJOCAF_PERSISTENCE (classname) +~~~~~ + +Should be included in .cxx file of each object class that should be saved and restored. +This is not needed for abstract types of objects. This macro implements the functions +declared by the previous macro and creates a static member +that automatically registers that type for persistence. + +When the attribute *TObj_TObject* that contains the interface object is saved, +its persistence handler stores the runtime type of the object class. +When the type is restored the handler dynamically recognizes the type +and creates the corresponding object using mechanisms provided by *TObj_Persistence*. + +@subsubsection occt_tobj_3_5 Names of objects + +All *TObj* model objects have names by which the user can refer to the object. +Upon creation, each object receives a default name, constructed +from the prefix corresponding to the object type (more precisely, the prefix is defined +by the partition to which the object belongs), and the index of the object in the current partition. +The user has the possibility to change this name. The uniqueness of the name in the model is ensured +by the naming mechanism (if the name is already used, it cannot be attributed to another object). +This default implementation of *TObj* package works with a single instance of the name container (dictionary) +for name registration of objects and it is enough in most simple projects. +If necessary, it is easy to redefine a couple of object methods +(for instance *GetDictionary*()) and to take care of construction and initialization of containers. + +This functionality is provided by the following methods: + +~~~~~{.cpp} + virtual Handle(TObj_TNameContainer) GetDictionary() const; +~~~~~ + +Returns the name container where the name of object should be registered. +The default implementation returns the model name container. + +~~~~~{.cpp} + Handle(TCollection_HExtendedString) GetName() const; + Standard_Boolean GetName( TCollection_ExtendedString& theName ) const; + Standard_Boolean GetName( TCollection_AsciiString& theName ) const; +~~~~~ + +Returns the object name. The methods with in / out argument return False if the object name is not defined. + +~~~~~{.cpp} + virtual Standard_Boolean SetName ( const Handle(TCollection_HExtendedString)& theName ) const; + Standard_Boolean SetName ( const Handle(TCollection_HAsciiString)& theName ) const; + Standard_Boolean SetName ( const Standard_CString theName ) const; +~~~~~ + +Attributes a new name to the object and returns **True** if the name has been attributed successfully. +Returns False if the name has been already attributed to another object. +The last two methods are short-cuts to the first one. + +@subsubsection occt_tobj_3_6 References between objects + +Class *TObj_Object* allows creating references to other objects in the model. +Such references describe relations among objects which are not adequately reflected +by the hierarchical objects structure in the model (parent-child relationship). + +The references are stored internally using the attribute TObj_TReference. +This attribute is located in the sub-label of the referring object (called *master*) +and keeps reference to the main label of the referred object. +At the same time the referred object can maintain the back reference to the master object. + +@figure{/user_guides/ocaf/images/tobj_image007.png,"Objects relationship",360} + + + +The back references are stored not in the OCAF document but as a transient field +of the object; they are created when the model is restored from file, +and updated automatically when the references are manipulated. +The class *TObj_TReference* allows storing references between objects +from different *TObj* models, facilitating the construction of complex relations between objects. + +The most used methods for work with references are: + +~~~~~{.cpp} + virtual Standard_Boolean HasReference( const Handle(TObj_Object)& theObject) const; +~~~~~ + +Returns True if the current object refers to the indicated object. + +~~~~~{.cpp} + virtual Handle(TObj_ObjectIterator) GetReferences ( const Handle(Standard_Type)& theType = NULL ) const; +~~~~~ + +Returns an iterator on the object references. The optional argument *theType* +restricts the types of referred objects, or does not if it is NULL. + +~~~~~{.cpp} + virtual void RemoveAllReferences(); +~~~~~ + +Removes all references from the current object. + +~~~~~{.cpp} + virtual void RemoveReference( const Handle(TObj_Object)& theObject ); +~~~~~ + +Removes the reference to the indicated object. + +~~~~~{.cpp} + virtual Handle(TObj_ObjectIterator) GetBackReferences ( const Handle(Standard_Type)& theType = NULL ) const; +~~~~~ + +Returns an iterator on the object back references. +The argument theType restricts the types of master objects, or does not if it is NULL. + +~~~~~{.cpp} + virtual void ReplaceReference ( const Handle(TObj_Object)& theOldObject, const Handle(TObj_Object)& theNewObject ); +~~~~~ + +Replaces the reference to theOldObject by the reference to *theNewObject*. +The handle theNewObject may be NULL to remove the reference. + +~~~~~{.cpp} + virtual Standard_Boolean RelocateReferences ( const TDF_Label& theFromRoot, const TDF_Label& theToRoot, const Standard_Boolean theUpdateackRefs = Standard_True ); +~~~~~ + +Replaces all references to a descendant label of *theFromRoot* +by the references to an equivalent label under *theToRoot*. +Returns **False** if the resulting reference does not point at a *TObj_Object*. +Updates back references if theUpdateackRefs is **True**. + +~~~~~{.cpp} + virtual Standard_Boolean CanRemoveReference ( const Handle(TObj_Object)& theObj) const; +~~~~~ + +Returns **True** if the reference can be removed and the master object +will remain valid (*weak* reference). +Returns **False** if the master object cannot be valid without the referred object (*strong* reference). +This affects the behaviour of objects removal from the model -- if the reference cannot be removed, +either the referred object will not be removed, or both the referred +and the master objects will be removed (depends on the deletion mode in the method **Detach**) + +@subsubsection occt_tobj_3_7 Creation and deletion of objects + +It is recommended that all objects inheriting from *TObj_Object* + should implement the same approach to creation and deletion. + +The object of the *TObj* data model cannot be created independently +of the model instance, as far as it stores the object data in OCAF data structures. +Therefore an object class cannot be created directly as its constructor is protected. + +Instead, each object should provide a static method *Create*(), which accepts the model, +with the label, which stores the object and other type-dependent parameters +necessary for proper definition of the object. This method creates a new object with its data +(a set of OCAF attributes) in the specified label, and returns a handle to the object's interface. + +The method *Detach*() is provided for deletion of objects from OCAF model. +Object data are deleted from the corresponding OCAF label; however, +the handle on object remains valid. The only operation available after object deletion +is the method *IsAlive*() checking whether the object has been deleted or not, +which returns False if the object has been deleted. + +When the object is deleted from the data model, the method checks +whether there are any alive references to the object. +Iterating on references the object asks each referring (master) object +whether the reference can be removed. If the master object can be unlinked, +the reference is removed, otherwise the master object will be removed too +or the referred object will be kept alive. This check is performed by the method *Detach* , +but the behavior depends on the deletion mode *TObj_DeletingMode*: + + * **TObj_FreeOnly** -- the object will be destroyed only if it is free, i.e. there are no references to it from other objects + * **TObj_KeepDepending** -- the object will be destroyed if there are no strong references to it from master objects (all references can be unlinked) + * **TObj_Force** -- the object and all depending master objects that have strong references to it will be destroyed. + +The most used methods for object removing are: + +~~~~~{.cpp} + virtual Standard_Boolean CanDetachObject (const TObj_DeletingMode theMode = TObj_FreeOnly ); +~~~~~ + +Returns **True** if the object can be deleted with the indicated deletion mode. + +~~~~~{.cpp} + virtual Standard_Boolean Detach ( const TObj_DeletingMode theMode = TObj_FreeOnly ); +~~~~~ + +Removes the object from the document if possible +(according to the indicated deletion mode). +Unlinks references from removed objects. +Returns **True** if the objects have been successfully deleted. + +@subsubsection occt_tobj_3_8 Transformation and replication of object data + +*TObj_Object* provides a number of special virtual methods to support replications of objects. These methods should be redefined by descendants when necessary. + +~~~~~{.cpp} + virtual Handle(TObj_Object) Clone (const TDF_Label& theTargetLabel, Handle(TDF_RelocationTable) theRelocTable = 0); +~~~~~ + +Copies the object to theTargetLabel. The new object will have all references of its original. +Returns a handle to the new object (null handle if fail). The data are copied directly, +but the name is changed by adding the postfix *_copy*. +To assign different names to the copies redefine the method: + +~~~~~{.cpp} + virtual Handle(TCollection_HExtendedString) GetNameForClone ( const Handle(TObj_Object)& ) const; +~~~~~ + +Returns the name for a new object copy. It could be useful to return the same object name +if the copy will be in the other model or in the other partition with its own dictionary. +The method *Clone* uses the following public methods for object data replications: + +~~~~~{.cpp} + virtual void CopyReferences (const const Handle(TObj_Object)& theTargetObject, const Handle(TDF_RelocationTable) theRelocTable); +~~~~~ + +Adds to the copy of the original object its references. + +~~~~~{.cpp} + virtual void CopyChildren (TDF_Label& theTargetLabel, const Handle(TDF_RelocationTable) theRelocTable); +~~~~~ + +Copies the children of an object to the target child label. + +@subsubsection occt_tobj_3_9 Object flags + +Each instance of *TObj_Object* stores a set of bit flags, +which facilitate the storage of auxiliary logical information assigned to the objects +(object state). Several typical state flags are defined in the enumeration *ObjectState*: + + * *ObjectState_Hidden* -- the object is marked as hidden + * *ObjectState_Saved* -- the object has (or should have) the corresponding saved file on disk + * *ObjectState_Imported* -- the object is imported from somewhere + * *ObjectState_ImportedByFile* -- the object has been imported from file and should be updated to have correct relations with other objects + * *ObjectState_Ordered* -- the partition contains objects that can be ordered. + +The user (developer) can define any new flags in descendant classes. +To set/get an object, the flags use the following methods: + +~~~~~{.cpp} + Standard_Integer GetFlags() const; + void SetFlags( const Standard_Integer theMask ); + Stadnard_Boolean TestFlags( const Standard_Integer theMask ) const; + void ClearFlags( const Standard_Integer theMask = 0 ); +~~~~~ + +In addition, the generic virtual interface stores the logical properties +of the object class in the form of a set of bit flags. +Type flags can be received by the method: + +~~~~~{.cpp} + virtual Standard_Integer GetTypeFlags() const; +~~~~~ + +The default implementation returns the flag **Visible** +defined in the enumeration *TypeFlags*. This flag is used to define visibility +of the object for the user browsing the model (see class *TObj_HiddenPartition*). +Other flags can be added by the applications. + +@subsubsection occt_tobj_310 Partitions + +The special kind of objects defined by the class *TObj_Partition* +(and its descendant *TObj_HiddenPartition*) is provided for partitioning +the model into a hierarchical structure. This object represents the container +of other objects. Each *TObj* model contains the main partition that is placed +in the same OCAF label as the model object, and serves as a root of the object's tree. +A hidden partition is a simple partition with a predefined hidden flag. + +The main partition object methods: + +~~~~~{.cpp} + TDF_Label NewLabel() const; +~~~~~ + +Allocates and returns a new label for creation of a new child object. + +~~~~~{.cpp} + void SetNamePrefix ( const Handle(TCollection_HExtendedString)& thePrefix); +~~~~~ + +Defines the prefix for automatic generation of names of the newly created objects. + +~~~~~{.cpp} + Handle(TCollection_HExtendedString) GetNamePrefix() const; +~~~~~ + +Returns the current name prefix. + +~~~~~{.cpp} + Handle(TCollection_HExtendedString) GetNewName ( const Standard_Boolean theIsToChangeCount) const; +~~~~~ + +Generates the new name and increases the internal counter of child objects if theIsToChangeCount is **True**. + +~~~~~{.cpp} + Standard_Integer GetLastIndex() const; +~~~~~ + +Returns the last reserved child index. + +~~~~~{.cpp} + void SetLastIndex( const Standard_Integer theIndex ); +~~~~~ + +Sets the last reserved index. + +@subsection occt_tobj_4 Auxiliary classes + +Apart from the model and the object, package *TObj* provides a set of auxiliary classes: + + * *TObj_Application* -- defines OCAF application supporting existence and operation with *TObj* documents. + * *TObj_Assistant* -- class provides an interface to the static data to be used during save and load operations on models. In particular, in case of cross-model dependencies it allows passing information on the parent model to the OCAF loader to correctly resolve the references when loading a dependent model. + * *TObj_TReference* -- OCAF attribute describes the references between objects in the *TObj* model(s). This attribute stores the label of the referred model object, and provides transparent cross-model references. At runtime, these references are simple Handles; in persistence mode, the cross-model references are automatically detected and processed by the persistence mechanism of *TObj_TReference* attribute. + * Other classes starting with *TObj_T...* -- define OCAF attributes used to store TObj-specific classes and some types of data on OCAF labels. + * Iterators -- a set of classes implementing *TObj_ObjectIterator* interface, used for iterations on *TObj* objects: + * *TObj_ObjectIterator* -- a basic abstract class for other *TObj* iterators. Iterates on *TObj_Object* instances. + * *TObj_LabelIterator* -- iterates on object labels in the *TObj* model document + * *TObj_ModelIterator* -- iterates on all objects in the model. Works with sequences of other iterators. + * *TObj_OcafObjectIterator* -- Iterates on *TObj* data model objects. Can iterate on objects of a specific type. + * *TObj_ReferenceIterator* -- iterates on object references. + * *TObj_SequenceIterator* -- iterates on a sequence of *TObj* objects. + * *TObj_CheckModel* -- a tool that checks the internal consistency of the model. The basic implementation checks only the consistency of references between objects. + +The structure of *TObj* iterators hierarchy is presented below: + +@figure{/user_guides/ocaf/images/tobj_image008.png,"Hierarchy of iterators",420} + + +@subsection occt_tobj_5 Packaging + +The *TObj* sources are distributed in the following packages: + + * *TObj* -- defines basic classes that implement *TObj* interfaces for OCAF-based modelers. + * *BinLDrivers, XmlLDrivers* -- binary and XML driver of *TObj* package + * *BinLPlugin, XmlLPlugin* -- plug-in for binary and XML persistence + * *BinMObj, XmlMObj* -- binary and XML drivers to store and retrieve specific *TObj* data to or from OCAF document + * *TKBinL, TKXmlL* -- toolkits of binary and XML persistence + + @section occt_ocaf_10 GLOSSARY * **Application** -- a document container holding all documents containing all application data. @@ -1868,506 +2773,3 @@ In C++, the application behavior is implemented in virtual functions redefined i * **Topological naming** -- systematic referencing of topological entities so that these entities can still be identified after the models they belong to have gone through several steps in modeling. In other words, topological naming allows you to track entities through the steps in the modeling process. This referencing is needed when a model is edited and regenerated, and can be seen as a mapping of labels and name attributes of the entities in the old version of a model to those of the corresponding entities in its new version. Note that if the topology of a model changes during the modeling, this mapping may not fully coincide. A Boolean operation, for example, may split edges. * **Topological tracking** -- following a topological entity in a model through the steps taken to edit and regenerate that model. * **Valid label** -- in a data framework, this is a label, which is already recomputed in the scope of regeneration sequence and includes the label containing a feature which is to be recalculated. Consider the case of a box to which you first add a fillet, then a protrusion feature. For recalculation purposes, only valid labels of each construction stage are used. In recalculating a fillet, they are only those of the box and the fillet, not the protrusion feature which was added afterwards. - -@section occt_ocaf_11 Samples - -@subsection occt_ocaf_11_a Getting Started - - At the beginning of your development, you first define an application class by inheriting from the Application abstract class. - You only have to create and determine the resources of the application - for specifying the format of your documents (you generally use the standard one) and their file extension. - - Then, you design the application data model by organizing attributes you choose among those provided with OCAF. - You can specialize these attributes using the User attribute. For example, if you need a reflection coefficient, - you aggregate a User attribute identified as a reflection coefficient - with a Real attribute containing the value of the coefficient (as such, you don't define a new class). - - If you need application specific data not provided with OCAF, for example, - to incorporate a finite element model in the data structure, - you define a new attribute class containing the mesh, - and you include its persistent homologue in a new file format. - - Once you have implemented the commands which create and modify the data structure - according to your specification, OCAF provides you, without any additional programming: - - * Persistent reference to any data, including geometric elements — several documents can be linked with such reference; - * Document-View association; - * Ready-to-use functions such as : - * Undo-redo; - * Save and open application data. - - Finally, you develop the application's graphical user interface using the toolkit of your choice, for example: - * KDE Qt or GNOME GTK+ on Linux; - * Microsoft Foundation Classes (MFC) on Windows Motif on Sun; - * Other commercial products such as Ilog Views. - - You can also implement the user interface in the Java language using - the Swing-based Java Application Desktop component (JAD) provided with OCAF. - -@subsection occt_ocaf_11_1 Implementation of Attribute Transformation in a HXX file - -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.cpp} -#include - -#include -#include -#include -#include - -// This attribute implements a transformation data container -class MyPackage_Transformation : public TDF_Attribute -{ -public: - //!@ name Static methods - - //! The method returns a unique GUID of this attribute. - //! By means of this GUID this attribute may be identified - //! among other attributes attached to the same label. - Standard_EXPORT static const Standard_GUID& GetID (); - - //! Finds or creates the attribute attached to . - //! The found or created attribute is returned. - Standard_EXPORT static Handle(MyPackage_Transformation) Set (const TDF_Label theLabel); - - //!@ name Methods for access to the attribute data - - //! The method returns the transformation. - Standard_EXPORT gp_Trsf Get () const; - - //!@ name Methods for setting the data of transformation - - //! The method defines a rotation type of transformation. - Standard_EXPORT void SetRotation (const gp_Ax1& theAxis, Standard_Real theAngle); - - //! The method defines a translation type of transformation. - Standard_EXPORT void SetTranslation (const gp_Vec& theVector); - - //! The method defines a point mirror type of transformation (point symmetry). - Standard_EXPORT void SetMirror (const gp_Pnt& thePoint); - - //! The method defines an axis mirror type of transformation (axial symmetry). - Standard_EXPORT void SetMirror (const gp_Ax1& theAxis); - - //! The method defines a point mirror type of transformation (planar symmetry). - Standard_EXPORT void SetMirror (const gp_Ax2& thePlane); - - //! The method defines a scale type of transformation. - Standard_EXPORT void SetScale (const gp_Pnt& thePoint, Standard_Real theScale); - - //! The method defines a complex type of transformation from one co-ordinate system to another. - Standard_EXPORT void SetTransformation (const gp_Ax3& theCoordinateSystem1, const gp_Ax3& theCoordinateSystem2); - - //!@ name Overridden methods from TDF_Attribute - - //! The method returns a unique GUID of the attribute. - //! By means of this GUID this attribute may be identified among other attributes attached to the same label. - Standard_EXPORT const Standard_GUID& ID () const; - - //! The method is called on Undo / Redo. - //! It copies the content of theAttribute into this attribute (copies the fields). - Standard_EXPORT void Restore (const Handle(TDF_Attribute)& theAttribute); - - //! It creates a new instance of this attribute. - //! It is called on Copy / Paste, Undo / Redo. - Standard_EXPORT Handle(TDF_Attribute) NewEmpty () const; - - //! The method is called on Copy / Paste. - //! It copies the content of this attribute into theAttribute (copies the fields). - Standard_EXPORT void Paste (const Handle(TDF_Attribute)& theAttribute, const Handle(TDF_RelocationTable)& theRelocationTable); - - //! Prints the content of this attribute into the stream. - Standard_EXPORT Standard_OStream& Dump(Standard_OStream& theOS); - - //!@ name Constructor - - //! The C++ constructor of this atribute class. - //! Usually it is never called outside this class. - Standard_EXPORT MyPackage_Transformation(); - -private: - gp_TrsfForm myType; - - // Axes (Ax1, Ax2, Ax3) - gp_Ax1 myAx1; - gp_Ax2 myAx2; - gp_Ax3 myFirstAx3; - gp_Ax3 mySecondAx3; - - // Scalar values - Standard_Real myAngle; - Standard_Real myScale; - - // Points - gp_Pnt myFirstPoint; - gp_Pnt mySecondPoint; -}; -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - -@subsection occt_ocaf_11_2 Implementation of Attribute Transformation in a CPP file - -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.cpp} -#include - -//======================================================================= -//function : GetID -//purpose : The method returns a unique GUID of this attribute. -// By means of this GUID this attribute may be identified -// among other attributes attached to the same label. -//======================================================================= -const Standard_GUID& MyPackage_Transformation::GetID() -{ - static Standard_GUID ID("4443368E-C808-4468-984D-B26906BA8573"); - return ID; -} - -//======================================================================= -//function : Set -//purpose : Finds or creates the attribute attached to . -// The found or created attribute is returned. -//======================================================================= -Handle(MyPackage_Transformation) MyPackage_Transformation::Set(const TDF_Label& theLabel) -{ - Handle(MyPackage_Transformation) T; - if (!theLabel.FindAttribute(MyPackage_Transformation::GetID(), T)) - { - T = new MyPackage_Transformation(); - theLabel.AddAttribute(T); - } - return T; -} - -//======================================================================= -//function : Get -//purpose : The method returns the transformation. -//======================================================================= -gp_Trsf MyPackage_Transformation::Get() const -{ - gp_Trsf transformation; - switch (myType) - { - case gp_Identity: - { - break; - } - case gp_Rotation: - { - transformation.SetRotation(myAx1, myAngle); - break; - } - case gp_Translation: - { - transformation.SetTranslation(myFirstPoint, mySecondPoint); - break; - } - case gp_PntMirror: - { - transformation.SetMirror(myFirstPoint); - break; - } - case gp_Ax1Mirror: - { - transformation.SetMirror(myAx1); - break; - } - case gp_Ax2Mirror: - { - transformation.SetMirror(myAx2); - break; - } - case gp_Scale: - { - transformation.SetScale(myFirstPoint, myScale); - break; - } - case gp_CompoundTrsf: - { - transformation.SetTransformation(myFirstAx3, mySecondAx3); - break; - } - case gp_Other: - { - break; - } - } - return transformation; -} - -//======================================================================= -//function : SetRotation -//purpose : The method defines a rotation type of transformation. -//======================================================================= -void MyPackage_Transformation::SetRotation(const gp_Ax1& theAxis, const Standard_Real theAngle) -{ - Backup(); - myType = gp_Rotation; - myAx1 = theAxis; - myAngle = theAngle; -} - -//======================================================================= -//function : SetTranslation -//purpose : The method defines a translation type of transformation. -//======================================================================= -void MyPackage_Transformation::SetTranslation(const gp_Vec& theVector) -{ - Backup(); - myType = gp_Translation; - myFirstPoint.SetCoord(0, 0, 0); - mySecondPoint.SetCoord(theVector.X(), theVector.Y(), theVector.Z()); -} - -//======================================================================= -//function : SetMirror -//purpose : The method defines a point mirror type of transformation -// (point symmetry). -//======================================================================= -void MyPackage_Transformation::SetMirror(const gp_Pnt& thePoint) -{ - Backup(); - myType = gp_PntMirror; - myFirstPoint = thePoint; -} - -//======================================================================= -//function : SetMirror -//purpose : The method defines an axis mirror type of transformation -// (axial symmetry). -//======================================================================= -void MyPackage_Transformation::SetMirror(const gp_Ax1& theAxis) -{ - Backup(); - myType = gp_Ax1Mirror; - myAx1 = theAxis; -} - -//======================================================================= -//function : SetMirror -//purpose : The method defines a point mirror type of transformation -// (planar symmetry). -//======================================================================= -void MyPackage_Transformation::SetMirror(const gp_Ax2& thePlane) -{ - Backup(); - myType = gp_Ax2Mirror; - myAx2 = thePlane; -} - -//======================================================================= -//function : SetScale -//purpose : The method defines a scale type of transformation. -//======================================================================= -void MyPackage_Transformation::SetScale(const gp_Pnt& thePoint, const Standard_Real theScale) -{ - Backup(); - myType = gp_Scale; - myFirstPoint = thePoint; - myScale = theScale; -} - -//======================================================================= -//function : SetTransformation -//purpose : The method defines a complex type of transformation -// from one co-ordinate system to another. -//======================================================================= -void MyPackage_Transformation::SetTransformation(const gp_Ax3& theCoordinateSystem1, - const gp_Ax3& theCoordinateSystem2) -{ - Backup(); - myFirstAx3 = theCoordinateSystem1; - mySecondAx3 = theCoordinateSystem2; -} - -//======================================================================= -//function : ID -//purpose : The method returns a unique GUID of the attribute. -// By means of this GUID this attribute may be identified -// among other attributes attached to the same label. -//======================================================================= -const Standard_GUID& MyPackage_Transformation::ID() const -{ - return GetID(); -} - -//======================================================================= -//function : Restore -//purpose : The method is called on Undo / Redo. -// It copies the content of -// into this attribute (copies the fields). -//======================================================================= -void MyPackage_Transformation::Restore(const Handle(TDF_Attribute)& theAttribute) -{ - Handle(MyPackage_Transformation) theTransformation = Handle(MyPackage_Transformation)::DownCast(theAttribute); - myType = theTransformation->myType; - myAx1 = theTransformation->myAx1; - myAx2 = theTransformation->myAx2; - myFirstAx3 = theTransformation->myFirstAx3; - mySecondAx3 = theTransformation->mySecondAx3; - myAngle = theTransformation->myAngle; - myScale = theTransformation->myScale; - myFirstPoint = theTransformation->myFirstPoint; - mySecondPoint = theTransformation->mySecondPoint; -} - -//======================================================================= -//function : NewEmpty -//purpose : It creates a new instance of this attribute. -// It is called on Copy / Paste, Undo / Redo. -//======================================================================= -Handle(TDF_Attribute) MyPackage_Transformation::NewEmpty() const -{ - return new MyPackage_Transformation(); -} - -//======================================================================= -//function : Paste -//purpose : The method is called on Copy / Paste. -// It copies the content of this attribute into -// (copies the fields). -//======================================================================= -void MyPackage_Transformation::Paste(const Handle(TDF_Attribute)& theAttribute, - const Handle(TDF_RelocationTable)& ) const -{ - Handle(MyPackage_Transformation) theTransformation = Handle(MyPackage_Transformation)::DownCast(theAttribute); - theTransformation->myType = myType; - theTransformation->myAx1 = myAx1; - theTransformation->myAx2 = myAx2; - theTransformation->myFirstAx3 = myFirstAx3; - theTransformation->mySecondAx3 = mySecondAx3; - theTransformation->myAngle = myAngle; - theTransformation->myScale = myScale; - theTransformation->myFirstPoint = myFirstPoint; - theTransformation->mySecondPoint = mySecondPoint; -} - -//======================================================================= -//function : Dump -//purpose : Prints the content of this attribute into the stream. -//======================================================================= -Standard_OStream& MyPackage_Transformation::Dump(Standard_OStream& anOS) const -{ - anOS = "Transformation: "; - switch (myType) - { - case gp_Identity: - { - anOS = "gp_Identity"; - break; - } - case gp_Rotation: - { - anOS = "gp_Rotation"; - break; - } - case gp_Translation: - { - anOS = "gp_Translation"; - break; - } - case gp_PntMirror: - { - anOS = "gp_PntMirror"; - break; - } - case gp_Ax1Mirror: - { - anOS = "gp_Ax1Mirror"; - break; - } - case gp_Ax2Mirror: - { - anOS = "gp_Ax2Mirror"; - break; - } - case gp_Scale: - { - anOS = "gp_Scale"; - break; - } - case gp_CompoundTrsf: - { - anOS = "gp_CompoundTrsf"; - break; - } - case gp_Other: - { - anOS = "gp_Other"; - break; - } - } - return anOS; -} - -//======================================================================= -//function : MyPackage_Transformation -//purpose : A constructor. -//======================================================================= -MyPackage_Transformation::MyPackage_Transformation():myType(gp_Identity){ - -} -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - -@subsection occt_ocaf_11_3 Implementation of typical actions with standard OCAF attributes. - -There are four sample files provided in the directory 'OpenCasCade/ros/samples/ocafsamples'. They present typical actions with OCAF services (mainly for newcomers). -The method *Sample()* of each file is not dedicated for execution 'as is', it is rather a set of logical actions using some OCAF services. - -### TDataStd_Sample.cxx -This sample contains templates for typical actions with the following standard OCAF attributes: -- Starting with data framework; -- TDataStd_Integer attribute management; -- TDataStd_RealArray attribute management; -- TDataStd_Comment attribute management; -- TDataStd_Name attribute management; -- TDataStd_UAttribute attribute management; -- TDF_Reference attribute management; -- TDataXtd_Point attribute management; -- TDataXtd_Plane attribute management; -- TDataXtd_Axis attribute management; -- TDataXtd_Geometry attribute management; -- TDataXtd_Constraint attribute management; -- TDataStd_Directory attribute management; -- TDataStd_TreeNode attribute management. - -### TDocStd_Sample.cxx -This sample contains template for the following typical actions: -- creating application; -- creating the new document (document contains a framework); -- retrieving the document from a label of its framework; -- filling a document with data; -- saving a document in the file; -- closing a document; -- opening the document stored in the file; -- copying content of a document to another document with possibility to update the copy in the future. - -### TPrsStd_Sample.cxx -This sample contains template for the following typical actions: -- starting with data framework; -- setting the TPrsStd_AISViewer in the framework; -- initialization of aViewer; -- finding TPrsStd_AISViewer attribute in the DataFramework; -- getting AIS_InteractiveContext from TPrsStd_AISViewer; -- adding driver to the map of drivers; -- getting driver from the map of drivers; -- setting TNaming_NamedShape to \; -- setting the new TPrsStd_AISPresentation to \; -- displaying; -- erasing; -- updating and displaying presentation of the attribute to be displayed; -- setting a color to the displayed attribute; -- getting transparency of the displayed attribute; -- modify attribute; -- updating presentation of the attribute in viewer. - -### TNaming_Sample.cxx -This sample contains template for typical actions with OCAF Topological Naming services. -The following scenario is used: -- data framework initialization; -- creating Box1 and pushing it as PRIMITIVE in DF; -- creating Box2 and pushing it as PRIMITIVE in DF; -- moving Box2 (applying a transformation); -- pushing the selected edges of the top face of Box1 in DF; -- creating a Fillet (using the selected edges) and pushing the result as a modification of Box1; -- creating a Cut (Box1, Box2) as a modification of Box1 and push it in DF; -- recovering the result from DF. - - diff --git a/dox/user_guides/step/step.md b/dox/user_guides/step/step.md index e65953f7a1..8328a914fb 100644 --- a/dox/user_guides/step/step.md +++ b/dox/user_guides/step/step.md @@ -1,4 +1,4 @@ -STEP processor {#occt_user_guides__step} +STEP Translator {#occt_user_guides__step} ======================== @tableofcontents @@ -22,9 +22,7 @@ File translation is performed in the programming mode, via C++ calls. @ref occt_user_guides__shape_healing "Shape Healing" toolkit provides tools to heal various problems, which may be encountered in translated shapes, and to make them valid in Open CASCADE. The Shape Healing is smoothly connected to STEP translator using the same API, only the names of API packages change. -For testing the STEP component in DRAW Test Harness, a set of commands for reading and writing STEP files and analysis of relevant data are provided by the *TKXSDRAW* plugin. - -See also our E-learning & Training offerings. +For testing the STEP component in DRAW Test Harness, a set of commands for reading and writing STEP files and analysis of relevant data are provided by the *TKXSDRAW* plugin. @subsection occt_step_1_1 STEP Exchanges in Open Cascade technology diff --git a/dox/user_guides/tobj/tobj.md b/dox/user_guides/tobj/tobj.md deleted file mode 100644 index 155091b738..0000000000 --- a/dox/user_guides/tobj/tobj.md +++ /dev/null @@ -1,910 +0,0 @@ -TObj Package {#occt_user_guides__tobj} -================== - -@tableofcontents - -@section occt_tobj_1 Introduction - -This document describes the package TObj, which is an add-on -to the Open CASCADE Application Framework (OCAF). - -This package provides a set of classes and auxiliary tools facilitating -the creation of object-oriented data models on top of low-level OCAF data structures. -This includes: - - * Definition of classes representing data objects. Data objects store their data using primitive OCAF attributes, taking advantage of OCAF mechanisms for Undo/Redo and persistence. At the same time they provide a higher level abstraction over the pure OCAF document structure (labels / attributes). - * Organization of the data model as a hierarchical (tree-like) structure of objects. - * Support of cross-references between objects within one model or among different models. In case of cross-model references the models should depend hierarchically. - * Persistence mechanism for storing *TObj* objects in OCAF files, which allows storing and retrieving objects of derived types without writing additional code to support persistence. - -This document describes basic principles of logical and physical organization -of TObj-based data models and typical approaches to implementation of classes representing model objects. - -@subsection occt_tobj_1_1 Applicability - -The main purpose of the *TObj* data model is rapid development -of the object-oriented data models for applications, using the existing -functionality provided by OCAF (Undo/Redo and persistence) -without the necessity to redevelop such functionality from scratch. - -As opposed to using bare OCAF (at the level of labels and attributes), -TObj facilitates dealing with higher level abstracts, which are closer -to the application domain. It works best when the application data are naturally -organized in hierarchical structures, and is especially useful for complex data -models with dependencies between objects belonging to different parts of the model. - -It should be noted that *TObj* is efficient for representing data structures containing -a limited number of objects at each level of the data structure (typically less than 1000). -A greater number of objects causes performance problems due to list-based organization of OCAF documents. Therefore, other methods of storage, such as arrays, are advisable for data models or their sub-parts containing a great number of uniform objects. However, these methods -can be combined with the usage of *TObj* to represent the high-level structure of the model. - -@section occt_tobj_2 TObj Model - -@subsection occt_tobj_2_1 TObj Model structure - -In the *TObj* data model the data are separated from the interfaces that manage them. - -It should be emphasized that *TObj* package defines only the interfaces and the basic structure of the model and objects, while the actual contents and structure of the model of a particular application are defined by its specific classes inherited from *TObj* classes. The implementation can add its own features or even change the default behaviour and the data layout, though this is not recommended. - -Logically the *TObj* data model is represented as a tree of model objects, with upper-level objects typically being collections of other objects (called *partitions*, represented by the class *TObj_Partition*). The root object of the model is called the *Main partition* and is maintained by the model itself. This partition contains a list of sub-objects called its *children* each sub-object may contain its own children (according to its type), etc. - -@figure{/user_guides/tobj/images/tobj_image003.png,"TObj Data Model",240} - -As the *TObj* Data Model is based on OCAF (Open CASCADE Application Framework) technology, -it stores its data in the underlying OCAF document. The OCAF document consists of a tree of -items called *labels*. Each label has some data attached to it in the form of *attributes*, -and may contain an arbitrary number of sub-labels. Each sub-label is identified by its sequential -number called the *tag*. The complete sequence of tag numbers of the label -and its parents starting from the document root constitutes the complete *entry* -of the label, which uniquely identifies its position in the document. - -Generally the structure of the OCAF tree of the *TObj* data -model corresponds to the logical structure of the model and can be presented as in the following picture: - -@figure{/user_guides/tobj/images/tobj_image004.png,"TObj Data Model mapped on OCAF document",360} - -All data of the model are stored in the root label (0:1) of the OCAF document. -An attribute *TObj_TModel* is located in this root label. It -stores the object of type *TObj_Model*. This object serves as a main interface tool -to access all data and functionalities of the data model. - -In simple cases all data needed by the application may be -contained in a single data model. Moreover, *TObj* gives the possibility to -distribute the data between several interconnected data models. This can be -especially useful for the applications dealing with great amounts of data. because -only the data required for the current operation is loaded in the memory at one time. -It is presumed that the models have a hierarchical (tree-like) structure, -where the objects of the child models can refer to the objects of the parent -models, not vice-versa. Provided that the correct order of loading and closing -of the models is ensured, the *TObj* classes will maintain references between the objects automatically. - -@subsection occt_tobj_2_2 Data Model basic features - -The class *TObj_Model* describing the data model provides the following functionalities: - - * Loading and saving of the model from or in a file (methods *Load* and *Save*) - * Closing and removal of the model from memory (method *Close*) - * Definition of the full file name of the persistence storage for this model (method *GetFile*) - * Tools to organize data objects in partitions and iterate on objects (methods *GetObjects*, *GetMainPartition*, *GetChildren*, *getPartition*, *getElementPartition*) - * Mechanism to give unique names to model objects - * Copy (*clone*) of the model (methods *NewEmpty* and *Paste*) - * Support of earlier model formats for proper conversion of a model loaded from a file written by a previous version of the application (methods *GetFormatVersion* and *SetFormatVersion*) - * Interface to check and update the model if necessary (method *Update*) - * Support of several data models in one application. For this feature use OCAF multi-transaction manager, unique names and GUIDs of the data model (methods *GetModelName*, *GetGUID*) - -@subsection occt_tobj_2_3 Model Persistence - -The persistent representation of any OCAF model is contained in an XML or a binary file, -which is defined by the format string returned by the method *GetFormat*. -The default implementation works with a binary OCAF document format (*BinOcaf*). -The other available format is *XmlOcaf*. The class **TObj_Model** declares and provides a default -implementation of two virtual methods: - -~~~~~{.cpp} - virtual Standard_Boolean Load (const char* theFile); - virtual Standard_Boolean SaveAs (const char* theFile); -~~~~~ - -which retrieve and store the model from or -in the OCAF file. The descendants -should define the following protected method to support Load and Save operations: - -~~~~~{.cpp} - virtual Standard_Boolean initNewModel (const Standard_Boolean IsNew); -~~~~~ - -This method is called by *Load* after creation of a new model -or after its loading from the file; its purpose is to perform -the necessary initialization of the model (such as creation of necessary top-level -partitions, model update due to version changes etc.). Note that if -the specified file does not exist, method *Load* will create -a new document and call *initNewModel* with the argument **True**. -If the file has been normally loaded, the argument **False** is passed. -Thus, a new empty *TObj* model is created by calling *Load* with an empty -string or the path to a nonexistent file as argument. - -The method *Load* returns **True** if the model has been retrieved successfully -(or created a new), or **False** if the model could not be loaded. -If no errors have been detected during initialization (model retrieval or creation), -the virtual method *AfterRetrieval* is invoked for all objects of the model. -This method initializes or updates the objects immediately after the model initialization. -It could be useful when some object data should be imported from an OCAF attribute into transient -fields which could be changed outside of the OCAF transaction mechanism. -Such fields can be stored into OCAF attributes for saving into persistent storage during the save operation. - -To avoid memory leaks, the *TObj_Model* class destructor invokes *Close* method -which clears the OCAF document and removes all data from memory before the model is destroyed. - -For XML and binary persistence of the *TObj* data model the corresponding drivers are implemented -in *BinLDrivers*, *BinMObj* and *XmlLDrivers*, *XmlMObj* packages. -These packages contain retrieval and storage drivers for the model, model objects and custom attributes -from the *TObj* package. The schemas support persistence for the standard OCAF and *TObj* attributes. -This is sufficient for the implementation of simple data models, but -in some cases it can be reasonable to add specific OCAF attributes to -facilitate the storage of the data specific to the application. -In this case the schema should be extended using the standard OCAF mechanism. - -@subsection occt_tobj_2_4 Access to the objects in the model - -All objects in the model are stored in the main partition and accessed by iterators. -To access all model objects use: - -~~~~~{.cpp} - virtual Handle(TObj_ObjectIterator) GetObjects () const; -~~~~~ - -This method returns a recursive iterator on all objects stored in the model. - -~~~~~{.cpp} - virtual Handle(TObj_ObjectIterator) GetChildren () const; -~~~~~ - -This method returns an iterator on child objects of the main partition. -Use the following method to get the main partition: - -~~~~~{.cpp} - Handle(TObj_Partition) GetMainPartition() const; -~~~~~ - -To receive the iterator on objects of a specific type *AType* use the following call: - -~~~~~{.cpp} - GetMainPartition()->GetChildren(STANDARD_TYPE(AType) ); -~~~~~ - -The set of protected methods is provided for descendant classes to deal with partitions: - -~~~~~{.cpp} - virtual Handle(TObj_Partition) getPartition (const TDF_Label, const Standard_Boolean theHidden) const; -~~~~~ - -This method returns (creating if necessary) a partition in the specified label of the document. -The partition can be created as hidden (*TObj_HiddenPartition* class). -A hidden partition can be useful to distinguish the data that -should not be visible to the user when browsing the model in the application. - -The following two methods allow getting (creating) a partition -in the sub-label of the specified label in the document -(the label of the main partition for the second method) and with the given name: - -~~~~~{.cpp} - virtual Handle(TObj_Partition) getPartition (const TDF_Label, const Standard_Integer theIndex, const TCollection_ExtendedString& theName, const Standard_Boolean theHidden) const; - virtual Handle(TObj_Partition) getPartition (const Standard_Integer theIndex, const TCollection_ExtendedString& theName, const Standard_Boolean theHidden) const; -~~~~~ - -If the default object naming and the name register mechanism -is turned on, the object can be found in the model by its unique name: - -~~~~~{.cpp} - Handle(TObj_Object) FindObject (const Handle(TCollection_HExtendedString)& theName, const Handle(TObj_TNameContainer)& theDictionary) const; -~~~~~ - -@subsection occt_tobj_2_5 Own model data - -The model object can store its own data in the Data label -of its main partition, however, there is no standard API for -setting and getting these data types. The descendants can add -their own data using standard OCAF methods. The enumeration DataTag is defined -in *TObj_Model* to avoid conflict of data labels used by this class -and its descendants, similarly to objects (see below). - -@subsection occt_tobj_2_6 Object naming - -The basic implementation of *TObj_Model* provides the default -naming mechanism: all objects must have unique names, -which are registered automatically in the data model dictionary. -The dictionary is a *TObj_TNameContainer* -attribute whose instance is located in the model root label. -If necessary, the developer can add several dictionaries into -the specific partitions, providing the name registration in the -correct name dictionary and restoring the name map after document is loaded from file. -To ignore name registering it is necessary to redefine the methods *SetName*, -*AfterRetrieval* of the *TObj_Object* class and skip the registration of the object name. -Use the following methods for the naming mechanism: - -~~~~~{.cpp} - Standard_Boolean IsRegisteredName (const Handle(TCollection_HExtendedString)& theName, const Handle(TObj_TNameContainer)& theDictionary ) const; -~~~~~ - -Returns **True** if the object name is already registered in the indicated (or model) dictionary. - -~~~~~{.cpp} - void RegisterName (const Handle(TCollection_HExtendedString)& theName, const TDF_Label& theLabel, const Handle(TObj_TNameContainer)& theDictionary ) const; -~~~~~ - -Registers the object name with the indicated label where the object -is located in the OCAF document. Note that the default implementation -of the method *SetName* of the object registers the new name automatically -(if the name is not yet registered for any other object) - -~~~~~{.cpp} - void UnRegisterName (const Handle(TCollection_HExtendedString)& theName, const Handle(TObj_TNameContainer)& theDictionary ) const; -~~~~~ - -Unregisters the name from the dictionary. Ther names of *TObj* model -objects are removed from the dictionary when the objects are deleted from the model. - -~~~~~{.cpp} - Handle(TObj_TNameContainer) GetDictionary() const; -~~~~~ - -Returns a default instance of the model dictionary (located at the model root label). -The default implementation works only with one dictionary. -If there are a necessity to have more than one dictionary for the model objects, -it is recommended to redefine the corresponding virtual method of TObj_Object -that returns the dictionary where names of objects should be registered. - -@subsection occt_tobj_2_7 API for transaction mechanism - -Class *TObj_Model* provides the API for transaction mechanism (supported by OCAF): - -~~~~~{.cpp} - Standard_Boolean HasOpenCommand() const; -~~~~~ - -Returns True if a Command transaction is open - -~~~~~{.cpp} - void OpenCommand() const; -~~~~~ - -Opens a new command transaction. - -~~~~~{.cpp} - void CommitCommand() const; -~~~~~ - -Commits the Command transaction. Does nothing If there is no open Command transaction. - -~~~~~{.cpp} - void AbortCommand() const; -~~~~~ - -Aborts the Command transaction. Does nothing if there is no open Command transaction. - -~~~~~{.cpp} - Standard_Boolean IsModified() const; -~~~~~ - -Returns True if the model document has a modified status (has changes after the last save) - -~~~~~{.cpp} - void SetModified( const Standard_Boolean ); -~~~~~ - -Changes the modified status by force. For synchronization of transactions -within several *TObj_Model* documents use class *TDocStd_MultiTransactionManager*. - -@subsection occt_tobj_28 Model format and version - -Class *TObj_Model* provides the descendant classes with a means to control -the format of the persistent file by choosing the schema used to store or retrieve operations. - -~~~~~{.cpp} - virtual TCollection_ExtendedString GetFormat () const; -~~~~~ - -Returns the string *TObjBin* or *TObjXml* indicating -the current persistent mechanism. The default value is *TObjBin*. -Due to the evolution of functionality of the developed application, -the contents and the structure of its data model vary from version to version. -*TObj* package provides a basic mechanism supporting backward versions compatibility, -which means that newer versions of the application will be able to read -Data Model files created by previous versions (but not vice-versa) with a minimum loss of data. -For each type of Data Model, all known versions of the data format -should be enumerated in increasing order, incremented with every change -of the model format. The current version of the model -format is stored in the model file and can be checked upon retrieval. - -~~~~~{.cpp} - Standard_Integer GetFormatVersion() const; -~~~~~ - -Returns the format version stored in the model file - -~~~~~{.cpp} - void SetFormatVersion(const Standard_Integer theVersion); -~~~~~ - -Defines the format version used for save. - -Upon loading a model, the method *initNewModel()*, called immediately -after opening a model from disk (on the level of the OCAF document), -provides a specific code that checks the format version stored in that model. -If it is older than the current version of the application, the data update can be performed. -Each model can have its own specific conversion code -that performs the necessary data conversion to make them compliant with the current version. - -When the conversion ends the user is advised of that by the messenger interface -provided by the model (see messaging chapter for more details), -and the model version is updated. If the version of data model is not supported -(it is newer than the current or too old), the load operation should fail. -The program updating the model after version change can be implemented as static -methods directly in C++ files of the corresponding Data Model classes, -not exposing it to the other parts of the application. -These codes can use direct access to the model and objects data (attributes) -not using objects interfaces, because the data model API and object classes -could have already been changed. - -Note that this mechanism has been designed to maintain version compatibility -for the changes of data stored in the model, not for the changes of -low-level format of data files (such as the storage format of a specific OCAF attribute). -If the format of data files changes, a specific treatment on a case-by-case basis will be required. - -@subsection occt_tobj_2_9 Model update - -The following methods are used for model update to ensure its consistency -with respect to the other models in case of cross-model dependencies: - -~~~~~{.cpp} - virtual Standard_Boolean Update(); -~~~~~ - -This method is usually called after loading of the model. -The default implementation does nothing and returns **True**. - -~~~~~{.cpp} - virtual Standard_Boolean initNewModel( const Standard_Boolean IsNew); -~~~~~ - -This method performs model initialization, check and updates (as described above). - -~~~~~{.cpp} - virtual void updateBackReferences( const Handle(TObj_Object)& theObj); -~~~~~ - -This method is called from the previous method to update back references -of the indicated object after the retrieval of the model from file -(see data model - object relationship chapter for more details) - -@subsection occt_tobj_2_10 Model copying - -To copy the model between OCAF documents use the following methods: - -~~~~~{.cpp} - virtual Standard_Boolean Paste (Handle(TObj_Model) theModel, Handle(TDF_RelocationTable) theRelocTable = 0 ); -~~~~~ - -Pastes the current model to the new model. The relocation table -ensures correct copying of the sub-data shared by several parts of the model. -It stores a map of processed original objects of relevant types in their copies. - -~~~~~{.cpp} - virtual Handle(TObj_Model) NewEmpty() = 0; -~~~~~ - -Redefines a pure virtual method to create a new empty instance of the model. - -~~~~~{.cpp} - void CopyReferences ( const Handle(TObj_Model)& theTarget, const Handle(TDF_RelocationTable)& theRelocTable); -~~~~~ - -Copies the references from the current model to the target model. - -@subsection occt_tobj_2_11 Messaging - -The messaging is organised using Open CASCADE Messenger from the package Message. -The messenger is stored as the field of the model instance -and can be set and retrieved by the following methods: - -~~~~~{.cpp} - void SetMessenger( const Handle(Message_Messenger)& ); - Handle(Message_Messenger) Messenger() const; -~~~~~ - -A developer should create his own instance of the Messenger -bound to the application user interface, and attribute it to the model -for future usage. In particular the messenger is used for reporting -errors and warnings in the persistence mechanism. -Each message has a unique string identifier (key). -All message keys are stored in a special resource file TObj.msg. -This file should be loaded at the start of the application -by call to the appropriate method of the class *Message_MsgFile*. - -@section occt_tobj_3 Model object - -Class *TObj_Object* provides basic interface and default implementation -of important features of *TObj* model objects. This implementation defines -basic approaches that are recommended for all descendants, -and provides tools to facilitate their usage. - -@figure{/user_guides/tobj/images/tobj_image005.png,"TObj objects hierarchy",170} - -@subsection occt_tobj_3_1 Separation of data and interface - -In the *TObj* data model, the data are separated from the interfaces that manage them. -The data belonging to a model object are stored in its root label and sub-labels -in the form of standard OCAF attributes. This allows using standard OCAF mechanisms -for work with these data, and eases the implementation of the persistence mechanism. - -The instance of the interface which serves as an API for managing object data -(e.g. represents the model object) is stored in the root label of the object, -and typically does not bring its own data. The interface classes are organized in a hierarchy -corresponding to the natural hierarchy of the model objects according to the application. - -In the text below the term 'object' is used to denote either the instance -of the interface class or the object itself (both interface and data stored in OCAF). - -The special type of attribute *TObj_TObject* is used for storing instances of objects interfaces -in the OCAF tree. *TObj_TObject* is a simple container for the object of type *TObj_Object*. -All objects (interfaces) of the data model inherit this class. - -@figure{/user_guides/tobj/images/tobj_image006.png,"TObj object stored on OCAF label",360} - - -@subsection occt_tobj_3_2 Basic features - -The *TObj_Object* class provides some basic features that can be inherited (or, if necessary, redefined) by the descendants: - - * Gives access to the model to which the object belongs (method *GetModel*) and to the OCAF label in which the object is stored (method *GetLabel*). - * Supports references (and back references) to other objects in the same or in another model (methods *getReference*, *setReference*, *addReference*, *GetReferences*, *GetBackReferences*, *AddBackReference*, *RemoveBackReference*, *ReplaceReference*) - * Provides the ability to contain child objects, as it is actual for partition objects (methods *GetChildren*, *GetFatherObject*) - * Organizes its data in the OCAF structure by separating the sub-labels of the main label intended for various kinds of data and providing tools to organize these data (see below). The kinds of data stored separately are: - * Child objects stored in the label returned by the method *GetChildLabel* - * References to other objects stored in the label returned by the method *GetReferenceLabel* - * Other data, both common to all objects and specific for each subtype of the model object, are stored in the label returned by the method *GetDataLabel* - * Provides unique names of all objects in the model (methods *GetDictionary*, *GetName*, *SetName*) - * Provides unified means to maintain persistence (implemented in descendants with the help of macros *DECLARE_TOBJOCAF_PERSISTENCE* and *IMPLEMENT_TOBJOCAF_PERSISTENCE*) - * Allows an object to remove itself from the OCAF document and check the depending objects can be deleted according to the back references (method *Detach*) - * Implements methods for identification and versioning of objects - * Manages the object interaction with OCAF Undo/Redo mechanism (method *IsAlive*, *AfterRetrieval*, *BeforeStoring*) - * Allows make a clone (methods *Clone*, *CopyReferences*, *CopyChildren*, *copyData*) - * Contains additional word of bit flags (methods *GetFlags*, *SetFlags*, *TestFlags*, *ClearFlags*) - * Defines the interface to sort the objects by rank (methods *GetOrder*, *SetOrder*) - * Provides a number of auxiliary methods for descendants to set/get the standard attribute values, such as int, double, string, arrays etc. - -An object can be received from the model by the following methods: - -~~~~~{.cpp} - static Standard_Boolean GetObj ( const TDF_Label& theLabel, Handle(TObj_Object)& theResObject, const Standard_Boolean isSuper = Standard_False ); -~~~~~ - -Returns *True* if the object has been found in the indicated label (or in the upper level label if *isSuper* is *True*). - -~~~~~{.cpp} - Handle(TObj_Object) GetFatherObject ( const Handle(Standard_Type)& theType = NULL ) const; -~~~~~ - -Returns the father object of the indicated type -for the current object (the direct father object if the type is NULL). - -@subsection occt_tobj_3_3 Data layout and inheritance - -As far as the data objects are separated from the interfaces and stored in the OCAF tree, -the functionality to support inheritance is required. Each object has its own data -and references stored in the labels in the OCAF tree. All data are stored in the sub-tree -of the main object label. If it is necessary to inherit a class from the base class, -the descendant class should use different labels for data and references than its ancestor. - -Therefore each *TObj* class can reserve the range of tags in each of -*Data*, *References*, and *Child* sub-labels. -The reserved range is declared by the enumeration defined -in the class scope (called DataTag, RefTag, and ChildTag, respectively). -The item *First* of the enumeration of each type is defined via the *Last* item -of the corresponding enumeration of the parent class, thus ensuring that the tag numbers -do not overlap. The item *Last* of the enumeration defines the last tag reserved by this class. -Other items of the enumeration define the tags used for storing particular data items of the object. -See the declaration of the TObj_Partition class for the example. - -*TObj_Object* class provides a set of auxiliary methods for descendants -to access the data stored in sub-labels by their tag numbers: - -~~~~~{.cpp} - TDF_Label getDataLabel (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; - TDF_Label getReferenceLabel (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; -~~~~~ - -Returns the label in *Data* or *References* sub-labels at a given tag number (theRank1). -The second argument, theRank2, allows accessing the next level of hierarchy -(theRank2-th sub-label of theRank1-th data label). -This is useful when the data to be stored are represented by multiple OCAF attributes -of the same type (e.g. sequences of homogeneous data or references). - -The get/set methods allow easily accessing the data located in the specified data label -for the most widely used data types (*Standard_Real*, *Standard_Integer*, *TCollection_HExtendedString*, - *TColStd_HArray1OfReal*, *TColStd_HArray1OfInteger*, *TColStd_HArray1OfExtendedString*). -For instance, methods provided for real numbers are: - -~~~~~{.cpp} - Standard_Real getReal (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; - Standard_Boolean setReal (const Standard_Real theValue, const Standard_Integer theRank1, const Standard_Integer theRank2 = 0, const Standard_Real theTolerance = 0.) const; -~~~~~ - -Similar methods are provided to access references to other objects: - -~~~~~{.cpp} - Handle(TObj_Object) getReference (const Standard_Integer theRank1, const Standard_Integer theRank2 = 0) const; - Standard_Boolean setReference (const Handle(TObj_Object) &theObject, const Standard_Integer theRank1, const Standard_Integer theRank2 = 0); -~~~~~ - -The method *addReference* gives an easy way to store a sequence of homogeneous references in one label. - -~~~~~{.cpp} - TDF_Label addReference (const Standard_Integer theRank1, const Handle(TObj_Object) &theObject); -~~~~~ - -Note that while references to other objects should be defined by descendant classes -individually according to the type of object, *TObj_Object* provides methods -to manipulate (check, remove, iterate) the existing references in the uniform way, as described below. - -@subsection occt_tobj_3_4 Persistence - -The persistence of the *TObj* Data Model is implemented with the help -of standard OCAF mechanisms (a schema defining necessary plugins, drivers, etc.). -This implies the possibility to store/retrieve all data that are stored -as standard OCAF attributes., The corresponding handlers are added -to the drivers for *TObj*-specific attributes. - -The special tool is provided for classes inheriting from *TObj_Object* -to add the new types of persistence without regeneration of the OCAF schema. -The class *TObj_Persistence* provides basic means for that: - - * automatic run-time registration of object types - * creation of a new object of the specified type (one of the registered types) - -Two macros defined in the file TObj_Persistence.hxx have to be included in the definition -of each model object class inheriting TObj_Object to activate the persistence mechanism: - -~~~~~{.cpp} - DECLARE_TOBJOCAF_PERSISTENCE (classname, ancestorname) -~~~~~ - -Should be included in the private section of declaration of each class inheriting -*TObj_Object* (hxx file). This macro adds an additional constructor to the object class, -and declares an auxiliary (private) class inheriting *TObj_Persistence* -that provides a tool to create a new object of the proper type. - -~~~~~{.cpp} - IMPLEMENT_TOBJOCAF_PERSISTENCE (classname) -~~~~~ - -Should be included in .cxx file of each object class that should be saved and restored. -This is not needed for abstract types of objects. This macro implements the functions -declared by the previous macro and creates a static member -that automatically registers that type for persistence. - -When the attribute *TObj_TObject* that contains the interface object is saved, -its persistence handler stores the runtime type of the object class. -When the type is restored the handler dynamically recognizes the type -and creates the corresponding object using mechanisms provided by *TObj_Persistence*. - -@subsection occt_tobj_3_5 Names of objects - -All *TObj* model objects have names by which the user can refer to the object. -Upon creation, each object receives a default name, constructed -from the prefix corresponding to the object type (more precisely, the prefix is defined -by the partition to which the object belongs), and the index of the object in the current partition. -The user has the possibility to change this name. The uniqueness of the name in the model is ensured -by the naming mechanism (if the name is already used, it cannot be attributed to another object). -This default implementation of *TObj* package works with a single instance of the name container (dictionary) -for name registration of objects and it is enough in most simple projects. -If necessary, it is easy to redefine a couple of object methods -(for instance *GetDictionary*()) and to take care of construction and initialization of containers. - -This functionality is provided by the following methods: - -~~~~~{.cpp} - virtual Handle(TObj_TNameContainer) GetDictionary() const; -~~~~~ - -Returns the name container where the name of object should be registered. -The default implementation returns the model name container. - -~~~~~{.cpp} - Handle(TCollection_HExtendedString) GetName() const; - Standard_Boolean GetName( TCollection_ExtendedString& theName ) const; - Standard_Boolean GetName( TCollection_AsciiString& theName ) const; -~~~~~ - -Returns the object name. The methods with in / out argument return False if the object name is not defined. - -~~~~~{.cpp} - virtual Standard_Boolean SetName ( const Handle(TCollection_HExtendedString)& theName ) const; - Standard_Boolean SetName ( const Handle(TCollection_HAsciiString)& theName ) const; - Standard_Boolean SetName ( const Standard_CString theName ) const; -~~~~~ - -Attributes a new name to the object and returns **True** if the name has been attributed successfully. -Returns False if the name has been already attributed to another object. -The last two methods are short-cuts to the first one. - -@subsection occt_tobj_3_6 References between objects - -Class *TObj_Object* allows creating references to other objects in the model. -Such references describe relations among objects which are not adequately reflected -by the hierarchical objects structure in the model (parent-child relationship). - -The references are stored internally using the attribute TObj_TReference. -This attribute is located in the sub-label of the referring object (called *master*) -and keeps reference to the main label of the referred object. -At the same time the referred object can maintain the back reference to the master object. - -@figure{/user_guides/tobj/images/tobj_image007.png,"Objects relationship",360} - - - -The back references are stored not in the OCAF document but as a transient field -of the object; they are created when the model is restored from file, -and updated automatically when the references are manipulated. -The class *TObj_TReference* allows storing references between objects -from different *TObj* models, facilitating the construction of complex relations between objects. - -The most used methods for work with references are: - -~~~~~{.cpp} - virtual Standard_Boolean HasReference( const Handle(TObj_Object)& theObject) const; -~~~~~ - -Returns True if the current object refers to the indicated object. - -~~~~~{.cpp} - virtual Handle(TObj_ObjectIterator) GetReferences ( const Handle(Standard_Type)& theType = NULL ) const; -~~~~~ - -Returns an iterator on the object references. The optional argument *theType* -restricts the types of referred objects, or does not if it is NULL. - -~~~~~{.cpp} - virtual void RemoveAllReferences(); -~~~~~ - -Removes all references from the current object. - -~~~~~{.cpp} - virtual void RemoveReference( const Handle(TObj_Object)& theObject ); -~~~~~ - -Removes the reference to the indicated object. - -~~~~~{.cpp} - virtual Handle(TObj_ObjectIterator) GetBackReferences ( const Handle(Standard_Type)& theType = NULL ) const; -~~~~~ - -Returns an iterator on the object back references. -The argument theType restricts the types of master objects, or does not if it is NULL. - -~~~~~{.cpp} - virtual void ReplaceReference ( const Handle(TObj_Object)& theOldObject, const Handle(TObj_Object)& theNewObject ); -~~~~~ - -Replaces the reference to theOldObject by the reference to *theNewObject*. -The handle theNewObject may be NULL to remove the reference. - -~~~~~{.cpp} - virtual Standard_Boolean RelocateReferences ( const TDF_Label& theFromRoot, const TDF_Label& theToRoot, const Standard_Boolean theUpdateackRefs = Standard_True ); -~~~~~ - -Replaces all references to a descendant label of *theFromRoot* -by the references to an equivalent label under *theToRoot*. -Returns **False** if the resulting reference does not point at a *TObj_Object*. -Updates back references if theUpdateackRefs is **True**. - -~~~~~{.cpp} - virtual Standard_Boolean CanRemoveReference ( const Handle(TObj_Object)& theObj) const; -~~~~~ - -Returns **True** if the reference can be removed and the master object -will remain valid (*weak* reference). -Returns **False** if the master object cannot be valid without the referred object (*strong* reference). -This affects the behaviour of objects removal from the model -- if the reference cannot be removed, -either the referred object will not be removed, or both the referred -and the master objects will be removed (depends on the deletion mode in the method **Detach**) - -@subsection occt_tobj_3_7 Creation and deletion of objects - -It is recommended that all objects inheriting from *TObj_Object* - should implement the same approach to creation and deletion. - -The object of the *TObj* data model cannot be created independently -of the model instance, as far as it stores the object data in OCAF data structures. -Therefore an object class cannot be created directly as its constructor is protected. - -Instead, each object should provide a static method *Create*(), which accepts the model, -with the label, which stores the object and other type-dependent parameters -necessary for proper definition of the object. This method creates a new object with its data -(a set of OCAF attributes) in the specified label, and returns a handle to the object's interface. - -The method *Detach*() is provided for deletion of objects from OCAF model. -Object data are deleted from the corresponding OCAF label; however, -the handle on object remains valid. The only operation available after object deletion -is the method *IsAlive*() checking whether the object has been deleted or not, -which returns False if the object has been deleted. - -When the object is deleted from the data model, the method checks -whether there are any alive references to the object. -Iterating on references the object asks each referring (master) object -whether the reference can be removed. If the master object can be unlinked, -the reference is removed, otherwise the master object will be removed too -or the referred object will be kept alive. This check is performed by the method *Detach* , -but the behavior depends on the deletion mode *TObj_DeletingMode*: - - * **TObj_FreeOnly** -- the object will be destroyed only if it is free, i.e. there are no references to it from other objects - * **TObj_KeepDepending** -- the object will be destroyed if there are no strong references to it from master objects (all references can be unlinked) - * **TObj_Force** -- the object and all depending master objects that have strong references to it will be destroyed. - -The most used methods for object removing are: - -~~~~~{.cpp} - virtual Standard_Boolean CanDetachObject (const TObj_DeletingMode theMode = TObj_FreeOnly ); -~~~~~ - -Returns **True** if the object can be deleted with the indicated deletion mode. - -~~~~~{.cpp} - virtual Standard_Boolean Detach ( const TObj_DeletingMode theMode = TObj_FreeOnly ); -~~~~~ - -Removes the object from the document if possible -(according to the indicated deletion mode). -Unlinks references from removed objects. -Returns **True** if the objects have been successfully deleted. - -@subsection occt_tobj_3_8 Transformation and replication of object data - -*TObj_Object* provides a number of special virtual methods to support replications of objects. These methods should be redefined by descendants when necessary. - -~~~~~{.cpp} - virtual Handle(TObj_Object) Clone (const TDF_Label& theTargetLabel, Handle(TDF_RelocationTable) theRelocTable = 0); -~~~~~ - -Copies the object to theTargetLabel. The new object will have all references of its original. -Returns a handle to the new object (null handle if fail). The data are copied directly, -but the name is changed by adding the postfix *_copy*. -To assign different names to the copies redefine the method: - -~~~~~{.cpp} - virtual Handle(TCollection_HExtendedString) GetNameForClone ( const Handle(TObj_Object)& ) const; -~~~~~ - -Returns the name for a new object copy. It could be useful to return the same object name -if the copy will be in the other model or in the other partition with its own dictionary. -The method *Clone* uses the following public methods for object data replications: - -~~~~~{.cpp} - virtual void CopyReferences (const const Handle(TObj_Object)& theTargetObject, const Handle(TDF_RelocationTable) theRelocTable); -~~~~~ - -Adds to the copy of the original object its references. - -~~~~~{.cpp} - virtual void CopyChildren (TDF_Label& theTargetLabel, const Handle(TDF_RelocationTable) theRelocTable); -~~~~~ - -Copies the children of an object to the target child label. - -@subsection occt_tobj_3_9 Object flags - -Each instance of *TObj_Object* stores a set of bit flags, -which facilitate the storage of auxiliary logical information assigned to the objects -(object state). Several typical state flags are defined in the enumeration *ObjectState*: - - * *ObjectState_Hidden* -- the object is marked as hidden - * *ObjectState_Saved* -- the object has (or should have) the corresponding saved file on disk - * *ObjectState_Imported* -- the object is imported from somewhere - * *ObjectState_ImportedByFile* -- the object has been imported from file and should be updated to have correct relations with other objects - * *ObjectState_Ordered* -- the partition contains objects that can be ordered. - -The user (developer) can define any new flags in descendant classes. -To set/get an object, the flags use the following methods: - -~~~~~{.cpp} - Standard_Integer GetFlags() const; - void SetFlags( const Standard_Integer theMask ); - Stadnard_Boolean TestFlags( const Standard_Integer theMask ) const; - void ClearFlags( const Standard_Integer theMask = 0 ); -~~~~~ - -In addition, the generic virtual interface stores the logical properties -of the object class in the form of a set of bit flags. -Type flags can be received by the method: - -~~~~~{.cpp} - virtual Standard_Integer GetTypeFlags() const; -~~~~~ - -The default implementation returns the flag **Visible** -defined in the enumeration *TypeFlags*. This flag is used to define visibility -of the object for the user browsing the model (see class *TObj_HiddenPartition*). -Other flags can be added by the applications. - -@subsection occt_tobj_310 Partitions - -The special kind of objects defined by the class *TObj_Partition* -(and its descendant *TObj_HiddenPartition*) is provided for partitioning -the model into a hierarchical structure. This object represents the container -of other objects. Each *TObj* model contains the main partition that is placed -in the same OCAF label as the model object, and serves as a root of the object's tree. -A hidden partition is a simple partition with a predefined hidden flag. - -The main partition object methods: - -~~~~~{.cpp} - TDF_Label NewLabel() const; -~~~~~ - -Allocates and returns a new label for creation of a new child object. - -~~~~~{.cpp} - void SetNamePrefix ( const Handle(TCollection_HExtendedString)& thePrefix); -~~~~~ - -Defines the prefix for automatic generation of names of the newly created objects. - -~~~~~{.cpp} - Handle(TCollection_HExtendedString) GetNamePrefix() const; -~~~~~ - -Returns the current name prefix. - -~~~~~{.cpp} - Handle(TCollection_HExtendedString) GetNewName ( const Standard_Boolean theIsToChangeCount) const; -~~~~~ - -Generates the new name and increases the internal counter of child objects if theIsToChangeCount is **True**. - -~~~~~{.cpp} - Standard_Integer GetLastIndex() const; -~~~~~ - -Returns the last reserved child index. - -~~~~~{.cpp} - void SetLastIndex( const Standard_Integer theIndex ); -~~~~~ - -Sets the last reserved index. - -@section occt_tobj_4 Auxiliary classes - -Apart from the model and the object, package *TObj* provides a set of auxiliary classes: - - * *TObj_Application* -- defines OCAF application supporting existence and operation with *TObj* documents. - * *TObj_Assistant* -- class provides an interface to the static data to be used during save and load operations on models. In particular, in case of cross-model dependencies it allows passing information on the parent model to the OCAF loader to correctly resolve the references when loading a dependent model. - * *TObj_TReference* -- OCAF attribute describes the references between objects in the *TObj* model(s). This attribute stores the label of the referred model object, and provides transparent cross-model references. At runtime, these references are simple Handles; in persistence mode, the cross-model references are automatically detected and processed by the persistence mechanism of *TObj_TReference* attribute. - * Other classes starting with *TObj_T...* -- define OCAF attributes used to store TObj-specific classes and some types of data on OCAF labels. - * Iterators -- a set of classes implementing *TObj_ObjectIterator* interface, used for iterations on *TObj* objects: - * *TObj_ObjectIterator* -- a basic abstract class for other *TObj* iterators. Iterates on *TObj_Object* instances. - * *TObj_LabelIterator* -- iterates on object labels in the *TObj* model document - * *TObj_ModelIterator* -- iterates on all objects in the model. Works with sequences of other iterators. - * *TObj_OcafObjectIterator* -- Iterates on *TObj* data model objects. Can iterate on objects of a specific type. - * *TObj_ReferenceIterator* -- iterates on object references. - * *TObj_SequenceIterator* -- iterates on a sequence of *TObj* objects. - * *TObj_CheckModel* -- a tool that checks the internal consistency of the model. The basic implementation checks only the consistency of references between objects. - -The structure of *TObj* iterators hierarchy is presented below: - -@figure{/user_guides/tobj/images/tobj_image008.png,"Hierarchy of iterators",420} - - -@section occt_tobj_5 Packaging - -The *TObj* sources are distributed in the following packages: - - * *TObj* -- defines basic classes that implement *TObj* interfaces for OCAF-based modelers. - * *BinLDrivers, XmlLDrivers* -- binary and XML driver of *TObj* package - * *BinLPlugin, XmlLPlugin* -- plug-in for binary and XML persistence - * *BinMObj, XmlMObj* -- binary and XML drivers to store and retrieve specific *TObj* data to or from OCAF document - * *TKBinL, TKXmlL* -- toolkits of binary and XML persistence - - - diff --git a/dox/user_guides/user_guides.md b/dox/user_guides/user_guides.md index 57d88f2e9e..bf8192f0b7 100644 --- a/dox/user_guides/user_guides.md +++ b/dox/user_guides/user_guides.md @@ -6,14 +6,13 @@ OCCT User Guides are organized by OCCT modules: * @subpage occt_user_guides__foundation_classes "Foundation Classes" * @subpage occt_user_guides__modeling_data "Modeling Data" * @subpage occt_user_guides__modeling_algos "Modeling Algorithms" - * @subpage occt_user_guides__shape_healing "Shape Healing" +* @subpage occt_user_guides__mesh "Mesh" +* @subpage occt_user_guides__shape_healing "Shape Healing" * @subpage occt_user_guides__visualization "Visualization" - * @subpage occt_user_guides__vis "VTK Integration Services" -* Data Exchange - * @subpage occt_user_guides__iges "IGES translator" - * @subpage occt_user_guides__step "STEP translator" - * @subpage occt_user_guides__xde "Extended Data Exchange (XDE)" +* @subpage occt_user_guides__vis "VTK Integration Services" +* @subpage occt_user_guides__iges "IGES Translator" +* @subpage occt_user_guides__step "STEP Translator" +* @subpage occt_user_guides__xde "Extended Data Exchange (XDE)" * @subpage occt_user_guides__ocaf "Open CASCADE Application Framework (OCAF)" - * @subpage occt_user_guides__tobj "TObj package" * @subpage occt_user_guides__test_harness "DRAW Test Harness" * @subpage occt_user_guides__inspector "Inspector" diff --git a/dox/user_guides/visualization/visualization.md b/dox/user_guides/visualization/visualization.md index fdb948d807..df6545eed3 100644 --- a/dox/user_guides/visualization/visualization.md +++ b/dox/user_guides/visualization/visualization.md @@ -42,8 +42,6 @@ To answer different needs of CASCADE users, this User's Guide offers the followi chapter 2 @ref occt_visu_2 "Fundamental Concepts", chapter 3 @ref occt_visu_3 "AIS: Application Interactive Services", and 4 @ref occt_visu_4 "3D Presentations". You may want to begin with the chapter presenting AIS. -For advanced information on visualization algorithms, see our E-learning & Training offerings. - @section occt_visu_2 Fundamental Concepts @subsection occt_visu_2_1 Presentation @@ -1545,28 +1543,34 @@ aViewer->SetDefaultBackgroundColor (Quantity_NOC_DARKVIOLET); // Create a structure in this Viewer Handle(Graphic3d_Structure) aStruct = new Graphic3d_Structure (aViewer->StructureManager()); aStruct->SetVisual (Graphic3d_TOS_SHADING); // Type of structure + // Create a group of primitives in this structure Handle(Graphic3d_Group) aPrsGroup = aStruct->NewGroup(); + // Fill this group with one quad of size 100 Handle(Graphic3d_ArrayOfTriangleStrips) aTriangles = new Graphic3d_ArrayOfTriangleStrips (4); aTriangles->AddVertex (-100./2., -100./2., 0.0); aTriangles->AddVertex (-100./2., 100./2., 0.0); aTriangles->AddVertex ( 100./2., -100./2., 0.0); aTriangles->AddVertex ( 100./2., 100./2., 0.0); + Handle(Graphic3d_AspectFillArea3d) anAspects = new Graphic3d_AspectFillArea3d (Aspect_IS_SOLID, Quantity_NOC_RED, Quantity_NOC_RED, Aspect_TOL_SOLID, 1.0f, Graphic3d_NOM_GOLD, Graphic3d_NOM_GOLD); aPrsGroup->SetGroupPrimitivesAspect (anAspects); aPrsGroup->AddPrimitiveArray (aTriangles); + // Create Ambient and Infinite Lights in this Viewer Handle(V3d_AmbientLight) aLight1 = new V3d_AmbientLight (Quantity_NOC_GRAY50); Handle(V3d_DirectionalLight) aLight2 = new V3d_DirectionalLight (V3d_Zneg, Quantity_NOC_WHITE, true); aViewer->AddLight (aLight1); aViewer->AddLight (aLight2); aViewer->SetLightOn(); + // Create a 3D quality Window with the same DisplayConnection Handle(Xw_Window) aWindow = new Xw_Window (aDispConnection, "Test V3d", 100, 100, 500, 500); aWindow->Map(); // Map this Window to this screen + // Create a Perspective View in this Viewer Handle(V3d_View) aView = new V3d_View (aViewer); aView->Camera()->SetProjectionType (Graphic3d_Camera::Projection_Perspective); @@ -1622,7 +1626,7 @@ aView->Update(); // update the Visualization in this View @subsubsection occt_visu_4_4_5 Perspective Projection -**Field of view (FOVy)** -- defines the field of camera view by y axis in degrees (45 is default). +**Field of view (FOVy)** -- defines the field of camera view by y axis in degrees (45° is default). @figure{camera_perspective.png,"Perspective frustum",420} @@ -1643,7 +1647,7 @@ There are two types of IOD: * _Graphic3d_Camera::IODType_Absolute_ : Intraocular distance is defined as an absolute value. * _Graphic3d_Camera::IODType_Relative_ : Intraocular distance is defined relative to the camera focal length (as its coefficient). -**Field of view (FOV)** -- defines the field of camera view by y axis in degrees (45 is default). +**Field of view (FOV)** -- defines the field of camera view by y axis in degrees (45° is default). **ZFocus** -- defines the distance to the point of stereographic focus. diff --git a/dox/user_guides/xde/xde.md b/dox/user_guides/xde/xde.md index e2a92615a9..04a4389153 100644 --- a/dox/user_guides/xde/xde.md +++ b/dox/user_guides/xde/xde.md @@ -5,7 +5,7 @@ @section occt_xde_1 Introduction -This manual explains how to use the Extended Data Exchange (XDE). It provides basic documentation on setting up and using XDE. For advanced information on XDE and its applications, see our E-learning & Training offerings. +This manual explains how to use the Extended Data Exchange (XDE). It provides basic documentation on setting up and using XDE. The Extended Data Exchange (XDE) module allows extending the scope of exchange by translating additional data attached to geometric BREP data, thereby improving the interoperability with external software.