1 // Created on: 2016-07-07
2 // Copyright (c) 2016 OPEN CASCADE SAS
3 // Created by: Oleg AGASHIN
5 // This file is part of Open CASCADE Technology software library.
7 // This library is free software; you can redistribute it and/or modify it under
8 // the terms of the GNU Lesser General Public License version 2.1 as published
9 // by the Free Software Foundation, with special exception defined in the file
10 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
11 // distribution for complete text of the license and disclaimer of any warranty.
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
16 #ifndef _IMeshTools_MeshAlgoFactory_HeaderFile
17 #define _IMeshTools_MeshAlgoFactory_HeaderFile
19 #include <Standard_Transient.hxx>
20 #include <Standard_Type.hxx>
21 #include <GeomAbs_SurfaceType.hxx>
22 #include <IMeshTools_MeshAlgo.hxx>
24 struct IMeshTools_Parameters;
26 //! Base interface for factories producing instances of triangulation
27 //! algorithms taking into account type of surface of target face.
28 class IMeshTools_MeshAlgoFactory : public Standard_Transient
33 Standard_EXPORT virtual ~IMeshTools_MeshAlgoFactory()
37 //! Creates instance of meshing algorithm for the given type of surface.
38 Standard_EXPORT virtual Handle(IMeshTools_MeshAlgo) GetAlgo(
39 const GeomAbs_SurfaceType theSurfaceType,
40 const IMeshTools_Parameters& theParameters) const = 0;
42 DEFINE_STANDARD_RTTI_INLINE(IMeshTools_MeshAlgoFactory, Standard_Transient)
47 Standard_EXPORT IMeshTools_MeshAlgoFactory()