File indexing completed on 2025-01-18 10:05:37
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016 #ifndef _XSDRAWSTL_DataSource_HeaderFile
0017 #define _XSDRAWSTL_DataSource_HeaderFile
0018
0019 #include <Standard.hxx>
0020
0021 #include <TColStd_HArray2OfInteger.hxx>
0022 #include <TColStd_HArray2OfReal.hxx>
0023 #include <MeshVS_DataSource.hxx>
0024 #include <Standard_Integer.hxx>
0025 #include <TColStd_Array1OfReal.hxx>
0026 #include <MeshVS_EntityType.hxx>
0027 #include <TColStd_Array1OfInteger.hxx>
0028 #include <Poly_Triangulation.hxx>
0029
0030
0031 class XSDRAWSTL_DataSource;
0032 DEFINE_STANDARD_HANDLE(XSDRAWSTL_DataSource, MeshVS_DataSource)
0033
0034
0035 class XSDRAWSTL_DataSource : public MeshVS_DataSource
0036 {
0037
0038 public:
0039
0040
0041
0042 Standard_EXPORT XSDRAWSTL_DataSource(const Handle(Poly_Triangulation)& aMesh);
0043
0044
0045
0046
0047
0048 Standard_EXPORT Standard_Boolean GetGeom (const Standard_Integer ID, const Standard_Boolean IsElement, TColStd_Array1OfReal& Coords, Standard_Integer& NbNodes, MeshVS_EntityType& Type) const Standard_OVERRIDE;
0049
0050
0051
0052 Standard_EXPORT Standard_Boolean GetGeomType (const Standard_Integer ID, const Standard_Boolean IsElement, MeshVS_EntityType& Type) const Standard_OVERRIDE;
0053
0054
0055 Standard_EXPORT Standard_Address GetAddr (const Standard_Integer ID, const Standard_Boolean IsElement) const Standard_OVERRIDE;
0056
0057
0058 Standard_EXPORT virtual Standard_Boolean GetNodesByElement (const Standard_Integer ID, TColStd_Array1OfInteger& NodeIDs, Standard_Integer& NbNodes) const Standard_OVERRIDE;
0059
0060
0061 Standard_EXPORT const TColStd_PackedMapOfInteger& GetAllNodes() const Standard_OVERRIDE;
0062
0063
0064 Standard_EXPORT const TColStd_PackedMapOfInteger& GetAllElements() const Standard_OVERRIDE;
0065
0066
0067
0068 Standard_EXPORT virtual Standard_Boolean GetNormal (const Standard_Integer Id, const Standard_Integer Max, Standard_Real& nx, Standard_Real& ny, Standard_Real& nz) const Standard_OVERRIDE;
0069
0070
0071
0072
0073 DEFINE_STANDARD_RTTIEXT(XSDRAWSTL_DataSource,MeshVS_DataSource)
0074
0075 protected:
0076
0077
0078
0079
0080 private:
0081
0082
0083 Handle(Poly_Triangulation) myMesh;
0084 TColStd_PackedMapOfInteger myNodes;
0085 TColStd_PackedMapOfInteger myElements;
0086 Handle(TColStd_HArray2OfInteger) myElemNodes;
0087 Handle(TColStd_HArray2OfReal) myNodeCoords;
0088 Handle(TColStd_HArray2OfReal) myElemNormals;
0089
0090
0091 };
0092
0093
0094
0095
0096
0097
0098
0099 #endif