/*========================================================================= Program: GDCM (Grassroots DICOM). A DICOM library Copyright (c) 2006-2011 Mathieu Malaterre All rights reserved. See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ #ifndef GDCMSURFACE_H #define GDCMSURFACE_H #include #include #include #include "gdcmSegmentHelper.h" // for BasicCodedEntry namespace gdcm { /** * \brief This class defines a SURFACE IE. * \details This members are taken from required surface mesh module attributes. * * \see PS 3.3 A.1.2.18 , A.57 and C.27 */ class GDCM_EXPORT Surface : public Object { public: typedef enum { NO = 0, YES, UNKNOWN, STATES_END } STATES; static const char * GetSTATESString(STATES state); static STATES GetSTATES(const char * state); /** * \brief Enumeration for Recommended Presentation Type * * \see Tag(0x0066, 0x000D) and PS 3.3 C.27.1.1.3 */ typedef enum { SURFACE = 0, WIREFRAME, POINTS, VIEWType_END } VIEWType; static const char * GetVIEWTypeString(VIEWType type); static VIEWType GetVIEWType(const char * type); Surface(); ~Surface() override; //** Common getters/setters **// unsigned long GetSurfaceNumber() const; void SetSurfaceNumber(const unsigned long nb); const char * GetSurfaceComments() const; void SetSurfaceComments(const char * comment); bool GetSurfaceProcessing() const; void SetSurfaceProcessing(bool b); float GetSurfaceProcessingRatio() const; void SetSurfaceProcessingRatio(const float ratio); const char * GetSurfaceProcessingDescription() const; void SetSurfaceProcessingDescription(const char * description); SegmentHelper::BasicCodedEntry const & GetProcessingAlgorithm() const; SegmentHelper::BasicCodedEntry & GetProcessingAlgorithm(); void SetProcessingAlgorithm(SegmentHelper::BasicCodedEntry const & BSE); unsigned short GetRecommendedDisplayGrayscaleValue() const; void SetRecommendedDisplayGrayscaleValue(const unsigned short vl); const unsigned short * GetRecommendedDisplayCIELabValue() const; unsigned short GetRecommendedDisplayCIELabValue(const unsigned int idx) const; void SetRecommendedDisplayCIELabValue(const unsigned short vl[3]); void SetRecommendedDisplayCIELabValue(const unsigned short vl, const unsigned int idx = 0); void SetRecommendedDisplayCIELabValue(const std::vector< unsigned short > & vl); float GetRecommendedPresentationOpacity() const; void SetRecommendedPresentationOpacity(const float opacity); VIEWType GetRecommendedPresentationType() const; void SetRecommendedPresentationType(VIEWType type); STATES GetFiniteVolume() const; void SetFiniteVolume(STATES state); STATES GetManifold() const; void SetManifold(STATES state); SegmentHelper::BasicCodedEntry const & GetAlgorithmFamily() const; SegmentHelper::BasicCodedEntry & GetAlgorithmFamily(); void SetAlgorithmFamily(SegmentHelper::BasicCodedEntry const & BSE); const char * GetAlgorithmVersion() const; void SetAlgorithmVersion(const char * str); const char * GetAlgorithmName() const; void SetAlgorithmName(const char * str); //** Points getters/setters **// unsigned long GetNumberOfSurfacePoints() const; void SetNumberOfSurfacePoints(const unsigned long nb); const DataElement & GetPointCoordinatesData() const; DataElement & GetPointCoordinatesData(); void SetPointCoordinatesData(DataElement const & de); /** * \note Pointer is null if undefined */ const float * GetPointPositionAccuracy() const; void SetPointPositionAccuracy(const float * accuracies); float GetMeanPointDistance() const; void SetMeanPointDistance(float average); float GetMaximumPointDistance() const; void SetMaximumPointDistance(float maximum); /** * \note Pointer is null if undefined */ const float * GetPointsBoundingBoxCoordinates() const; void SetPointsBoundingBoxCoordinates(const float * coordinates); /** * \note Pointer is null if undefined */ const float * GetAxisOfRotation() const; void SetAxisOfRotation(const float * axis); /** * \note Pointer is null if undefined */ const float * GetCenterOfRotation() const; void SetCenterOfRotation(const float * center); //** Vectors getters/setters **// unsigned long GetNumberOfVectors() const; void SetNumberOfVectors(const unsigned long nb); unsigned short GetVectorDimensionality() const; void SetVectorDimensionality(const unsigned short dim); const float * GetVectorAccuracy() const; void SetVectorAccuracy(const float * accuracy); const DataElement & GetVectorCoordinateData() const; DataElement & GetVectorCoordinateData(); void SetVectorCoordinateData(DataElement const & de); //** Primitive getters/setters **// MeshPrimitive const & GetMeshPrimitive() const; MeshPrimitive & GetMeshPrimitive(); void SetMeshPrimitive(MeshPrimitive const & mp); private: //** Common members **// //0066 0003 UL 1 Surface Number unsigned long SurfaceNumber; //0066 0004 LT 1 Surface Comments std::string SurfaceComments; //0066 0009 CS 1 Surface Processing bool SurfaceProcessing; //0066 000a FL 1 Surface Processing Ratio float SurfaceProcessingRatio; //0066 000b LO 1 Surface Processing Description std::string SurfaceProcessingDescription; // Processing Algorithm Code SegmentHelper::BasicCodedEntry ProcessingAlgorithm; //0062 000c US 1 Recommended Display Grayscale Value unsigned short RecommendedDisplayGrayscaleValue; //0062 000d US 3 Recommended Display CIELab Value unsigned short RecommendedDisplayCIELabValue[3]; // 0066 000c FL 1 Recommended Presentation Opacity float RecommendedPresentationOpacity; // 0066 000d CS 1 Recommended Presentation Type VIEWType RecommendedPresentationType; //0066 000e CS 1 Finite Volume STATES FiniteVolume; //0066 0010 CS 1 Manifold STATES Manifold; // Algorithm Family Code SegmentHelper::BasicCodedEntry AlgorithmFamily; //0066 0031 LO 1 Algorithm Version std::string AlgorithmVersion; //0066 0032 LT 1 Algorithm Parameters //0066 0036 LO 1 Algorithm Name std::string AlgorithmName; //** Point members **// //0066 0015 UL 1 Number of Surface Points unsigned long NumberOfSurfacePoints; //0066 0016 OF 1 Point Coordinates Data DataElement PointCoordinatesData; //0066 0017 FL 3 Point Position Accuracy float * PointPositionAccuracy; //0066 0018 FL 1 Mean Point Distance float MeanPointDistance; //0066 0019 FL 1 Maximum Point Distance float MaximumPointDistance; //0066 001a FL 6 Points Bounding Box Coordinates float * PointsBoundingBoxCoordinates; //0066 001b FL 3 Axis of Rotation float * AxisOfRotation; //0066 001c FL 3 Center of Rotation float * CenterOfRotation; //** Normal members **// //0066 001e UL 1 Number of Vectors unsigned long NumberOfVectors; //0066 001f US 1 Vector Dimensionality unsigned short VectorDimensionality; //0066 0020 FL 1-n Vector Accuracy float * VectorAccuracy; //0066 0021 OF 1 Vector Coordinate Data DataElement VectorCoordinateData; //** Primitive members **// SmartPointer< MeshPrimitive > Primitive; }; } #endif // GDCMSURFACE_H