X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FStdMeshers%2FStdMeshers_QuadToTriaAdaptor.hxx;h=79017c20d2420ae19524c08c52b6cd3592b3b28f;hb=9357f5c87098aff2b95b754d69f66c76d2df9c24;hp=af818549f264005607c7621b80d2eff1d107b3dd;hpb=0635c9fc80f67d1e5dc0e94ec85f487286a92070;p=modules%2Fsmesh.git diff --git a/src/StdMeshers/StdMeshers_QuadToTriaAdaptor.hxx b/src/StdMeshers/StdMeshers_QuadToTriaAdaptor.hxx index af818549f..79017c20d 100644 --- a/src/StdMeshers/StdMeshers_QuadToTriaAdaptor.hxx +++ b/src/StdMeshers/StdMeshers_QuadToTriaAdaptor.hxx @@ -1,7 +1,4 @@ -// Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE -// -// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, -// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS +// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -19,6 +16,7 @@ // // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // + // SMESH SMESH : implementaion of SMESH idl descriptions // File : StdMeshers_QuadToTriaAdaptor.hxx // Module : SMESH @@ -26,11 +24,18 @@ #ifndef _SMESH_QuadToTriaAdaptor_HXX_ #define _SMESH_QuadToTriaAdaptor_HXX_ -#include -#include -#include -#include -#include +#include "SMESH_StdMeshers.hxx" +#include "SMDS_FaceOfNodes.hxx" + +class SMESH_Mesh; +class SMDS_MeshElement; +class SMDS_MeshNode; +class Handle(TColgp_HArray1OfPnt); +class Handle(TColgp_HArray1OfVec); +class TopoDS_Shape; +class gp_Pnt; +class gp_Vec; + #include #include @@ -40,25 +45,24 @@ class STDMESHERS_EXPORT StdMeshers_QuadToTriaAdaptor { public: - StdMeshers_QuadToTriaAdaptor(); - ~StdMeshers_QuadToTriaAdaptor(); bool Compute(SMESH_Mesh& aMesh, const TopoDS_Shape& aShape); bool Compute(SMESH_Mesh& aMesh); - std::list GetTriangles(const SMDS_MeshElement* aFace); + const std::list* GetTriangles(const SMDS_MeshElement* aFace); protected: //bool CheckDegenerate(const SMDS_MeshElement* aFace); int Preparation(const SMDS_MeshElement* face, - Handle(TColgp_HArray1OfPnt) PN, - Handle(TColgp_HArray1OfVec) VN, + Handle(TColgp_HArray1OfPnt)& PN, + Handle(TColgp_HArray1OfVec)& VN, std::vector& FNodes, - gp_Pnt& PC, gp_Vec& VNorm); + gp_Pnt& PC, gp_Vec& VNorm, + const SMDS_MeshElement** volumes=0); bool CheckIntersection(const gp_Pnt& P, const gp_Pnt& PC, gp_Pnt& Pint, SMESH_Mesh& aMesh, @@ -67,8 +71,13 @@ protected: bool Compute2ndPart(SMESH_Mesh& aMesh); - std::map< const SMDS_MeshElement*, std::list > myResMap; - std::map< const SMDS_MeshElement*, const SMDS_MeshElement* > myMapFPyram; + typedef std::list TTriaList; + typedef std::multimap TQuad2Trias; + typedef std::map TPyram2Trias; + + TQuad2Trias myResMap; + TPyram2Trias myPyram2Trias; + std::list< const SMDS_MeshNode* > myDegNodes; };