0025113: Mesh - Progress indication and user break functionality for BRepMesh component
[occt.git] / src / BRepMesh / BRepMesh_IncrementalMesh.cxx
1 // Created on: 1995-06-20
2 // Created by: Stagiaire Alain JOURDAIN
3 // Copyright (c) 1995-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #include <BRepMesh_IncrementalMesh.hxx>
18 #include <BRepMesh_Context.hxx>
19 #include <BRepMesh_PluginMacro.hxx>
20 #include <IMeshData_Status.hxx>
21 #include <IMeshData_Face.hxx>
22 #include <IMeshData_Wire.hxx>
23 #include <IMeshTools_MeshBuilder.hxx>
24
25 namespace
26 {
27   //! Default flag to control parallelization for BRepMesh_IncrementalMesh
28   //! tool returned for Mesh Factory
29   static Standard_Boolean IS_IN_PARALLEL = Standard_False;
30 }
31
32 //=======================================================================
33 //function : Default constructor
34 //purpose  : 
35 //=======================================================================
36 BRepMesh_IncrementalMesh::BRepMesh_IncrementalMesh()
37 : myModified(Standard_False),
38   myStatus(IMeshData_NoError)
39 {
40 }
41
42 //=======================================================================
43 //function : Constructor
44 //purpose  : 
45 //=======================================================================
46 BRepMesh_IncrementalMesh::BRepMesh_IncrementalMesh( const TopoDS_Shape&    theShape,
47                                                     const Standard_Real    theLinDeflection,
48                                                     const Standard_Boolean isRelative,
49                                                     const Standard_Real    theAngDeflection,
50                                                     const Standard_Boolean isInParallel)
51 : myModified(Standard_False),
52   myStatus(IMeshData_NoError)
53 {
54   myParameters.Deflection = theLinDeflection;
55   myParameters.Angle      = theAngDeflection;
56   myParameters.Relative   = isRelative;
57   myParameters.InParallel = isInParallel;
58
59   myShape = theShape;
60   Perform();
61 }
62
63 //=======================================================================
64 //function : Constructor
65 //purpose  : 
66 //=======================================================================
67 BRepMesh_IncrementalMesh::BRepMesh_IncrementalMesh(
68   const TopoDS_Shape&          theShape,
69   const IMeshTools_Parameters& theParameters,
70   const Message_ProgressRange& theRange)
71   : myParameters(theParameters)
72 {
73   myShape = theShape;
74   Perform(theRange);
75 }
76
77 //=======================================================================
78 //function : Destructor
79 //purpose  : 
80 //=======================================================================
81 BRepMesh_IncrementalMesh::~BRepMesh_IncrementalMesh()
82 {
83 }
84
85 //=======================================================================
86 //function : Perform
87 //purpose  : 
88 //=======================================================================
89 void BRepMesh_IncrementalMesh::Perform(const Message_ProgressRange& theRange)
90 {
91   Handle(BRepMesh_Context) aContext = new BRepMesh_Context;
92   Perform (aContext, theRange);
93 }
94
95 //=======================================================================
96 //function : Perform
97 //purpose  : 
98 //=======================================================================
99 void BRepMesh_IncrementalMesh::Perform(const Handle(IMeshTools_Context)& theContext, const Message_ProgressRange& theRange)
100 {
101   initParameters();
102
103   theContext->SetShape(Shape());
104   theContext->ChangeParameters()            = myParameters;
105   theContext->ChangeParameters().CleanModel = Standard_False;
106
107   Message_ProgressScope aPS(theRange, "Perform incmesh", 10);
108   IMeshTools_MeshBuilder aIncMesh(theContext);
109   aIncMesh.Perform(aPS.Next(9));
110   if (!aPS.More())
111   {
112     myStatus = IMeshData_UserBreak;
113     return;
114   }
115   myStatus = IMeshData_NoError;
116   const Handle(IMeshData_Model)& aModel = theContext->GetModel();
117   if (!aModel.IsNull())
118   {
119     for (Standard_Integer aFaceIt = 0; aFaceIt < aModel->FacesNb(); ++aFaceIt)
120     {
121       const IMeshData::IFaceHandle& aDFace = aModel->GetFace(aFaceIt);
122       myStatus |= aDFace->GetStatusMask();
123
124       for (Standard_Integer aWireIt = 0; aWireIt < aDFace->WiresNb(); ++aWireIt)
125       {
126         const IMeshData::IWireHandle& aDWire = aDFace->GetWire(aWireIt);
127         myStatus |= aDWire->GetStatusMask();
128       }
129     }
130   }
131   aPS.Next(1);
132   setDone();
133 }
134
135 //=======================================================================
136 //function : Discret
137 //purpose  :
138 //=======================================================================
139 Standard_Integer BRepMesh_IncrementalMesh::Discret(
140   const TopoDS_Shape&    theShape,
141   const Standard_Real    theDeflection,
142   const Standard_Real    theAngle,
143   BRepMesh_DiscretRoot* &theAlgo)
144 {
145   BRepMesh_IncrementalMesh* anAlgo = new BRepMesh_IncrementalMesh();
146   anAlgo->ChangeParameters().Deflection = theDeflection;
147   anAlgo->ChangeParameters().Angle      = theAngle;
148   anAlgo->ChangeParameters().InParallel = IS_IN_PARALLEL;
149   anAlgo->SetShape (theShape);
150   theAlgo = anAlgo;
151   return 0; // no error
152 }
153
154 //=======================================================================
155 //function : IsParallelDefault
156 //purpose  :
157 //=======================================================================
158 Standard_Boolean BRepMesh_IncrementalMesh::IsParallelDefault()
159 {
160   return IS_IN_PARALLEL;
161 }
162
163 //=======================================================================
164 //function : Discret
165 //purpose  :
166 //=======================================================================
167 void BRepMesh_IncrementalMesh::SetParallelDefault(
168   const Standard_Boolean theInParallel)
169 {
170   IS_IN_PARALLEL = theInParallel;
171 }
172
173 //! Export Mesh Plugin entry function
174 DISCRETPLUGIN(BRepMesh_IncrementalMesh)