/*========================================================================= 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. =========================================================================*/ #include "gdcmSurface.h" #include "gdcmCodeString.h" #include "gdcmString.h" #include namespace gdcm { static const char * STATESStrings[] = { "NO", "YES", "UNKNOWN", nullptr }; const char * Surface::GetSTATESString(STATES state) { assert( state <= STATES_END ); return STATESStrings[(int)state]; } Surface::STATES Surface::GetSTATES(const char * state) { if(!state) return STATES_END; // Delete possible space as last character String<> str( state ); str.Trim(); std::string stateClearStr = str.Trim(); const char * stateClear = stateClearStr.c_str(); for(unsigned int i = 0; STATESStrings[i] != nullptr; ++i) { if( strcmp(stateClear, STATESStrings[i]) == 0 ) { return (STATES)i; } } // Ouch ! We did not find anything, that's pretty bad, let's hope that // the toolkit which wrote the image is buggy and tolerate space padded binary // string CodeString codestring = stateClear; std::string cs = codestring.GetAsString(); for(unsigned int i = 0; STATESStrings[i] != nullptr; ++i) { if( strcmp(cs.c_str(), STATESStrings[i]) == 0 ) { return (STATES)i; } } return STATES_END; } static const char * VIEWStrings[] = { "SURFACE", "WIREFRAME", "POINTS", nullptr }; const char * Surface::GetVIEWTypeString(VIEWType type) { assert( type <= VIEWType_END ); return VIEWStrings[(int)type]; } Surface::VIEWType Surface::GetVIEWType(const char * type) { if(!type) return VIEWType_END; // Delete possible space as last character String<> str( type ); str.Trim(); std::string typeClearStr = str.Trim(); const char * typeClear = typeClearStr.c_str(); for(unsigned int i = 0; VIEWStrings[i] != nullptr; ++i) { if( strcmp(typeClear, VIEWStrings[i]) == 0 ) { return (VIEWType)i; } } // Ouch ! We did not find anything, that's pretty bad, let's hope that // the toolkit which wrote the image is buggy and tolerate space padded binary // string CodeString codestring = typeClear; std::string cs = codestring.GetAsString(); for(unsigned int i = 0; VIEWStrings[i] != nullptr; ++i) { if( strcmp(cs.c_str(), VIEWStrings[i]) == 0 ) { return (VIEWType)i; } } return VIEWType_END; } Surface::Surface(): SurfaceNumber(0), SurfaceComments(""), SurfaceProcessing(false), SurfaceProcessingRatio(1.), SurfaceProcessingDescription(""), ProcessingAlgorithm(), RecommendedDisplayGrayscaleValue(0), RecommendedPresentationOpacity(1), RecommendedPresentationType(SURFACE), FiniteVolume(UNKNOWN), Manifold(UNKNOWN), AlgorithmFamily(), AlgorithmVersion(""), AlgorithmName(""), NumberOfSurfacePoints(0), PointCoordinatesData(), PointPositionAccuracy(nullptr), MeanPointDistance(0), MaximumPointDistance(0), PointsBoundingBoxCoordinates(nullptr), AxisOfRotation(nullptr), CenterOfRotation(nullptr), NumberOfVectors(0), VectorDimensionality(0), VectorAccuracy(nullptr), VectorCoordinateData(), Primitive(new MeshPrimitive) { RecommendedDisplayCIELabValue[0] = 0; RecommendedDisplayCIELabValue[1] = 0; RecommendedDisplayCIELabValue[2] = 0; } Surface::~Surface() { if (PointPositionAccuracy != nullptr) delete PointPositionAccuracy; if (PointsBoundingBoxCoordinates != nullptr) delete PointsBoundingBoxCoordinates; if (AxisOfRotation != nullptr) delete AxisOfRotation; if (CenterOfRotation != nullptr) delete CenterOfRotation; if (VectorAccuracy != nullptr) delete VectorAccuracy; } unsigned short Surface::GetRecommendedDisplayGrayscaleValue() const { return RecommendedDisplayGrayscaleValue; } void Surface::SetRecommendedDisplayGrayscaleValue(const unsigned short vl) { RecommendedDisplayGrayscaleValue = vl; } const unsigned short * Surface::GetRecommendedDisplayCIELabValue() const { return &RecommendedDisplayCIELabValue[0]; } unsigned short Surface::GetRecommendedDisplayCIELabValue(const unsigned int idx) const { assert( idx < 3 ); return RecommendedDisplayCIELabValue[idx]; } void Surface::SetRecommendedDisplayCIELabValue(const unsigned short vl[3]) { RecommendedDisplayCIELabValue[0] = vl[0]; RecommendedDisplayCIELabValue[1] = vl[1]; RecommendedDisplayCIELabValue[2] = vl[2]; } void Surface::SetRecommendedDisplayCIELabValue(const unsigned short vl, const unsigned int idx/* = 0*/) { assert( idx < 3 ); RecommendedDisplayCIELabValue[idx] = vl; } void Surface::SetRecommendedDisplayCIELabValue(const std::vector< unsigned short > & vl) { assert( vl.size() > 2 ); RecommendedDisplayCIELabValue[0] = vl[0]; RecommendedDisplayCIELabValue[1] = vl[1]; RecommendedDisplayCIELabValue[2] = vl[2]; } float Surface::GetRecommendedPresentationOpacity() const { return RecommendedPresentationOpacity; } void Surface::SetRecommendedPresentationOpacity(float opacity) { if( (0 <= opacity) && (opacity <= 1) ) { RecommendedPresentationOpacity = opacity; } //else keep default value : 1 } Surface::VIEWType Surface::GetRecommendedPresentationType() const { return RecommendedPresentationType; } void Surface::SetRecommendedPresentationType(VIEWType type) { if( type < VIEWType_END) { RecommendedPresentationType = type; } } unsigned long Surface::GetSurfaceNumber() const { return SurfaceNumber; } void Surface::SetSurfaceNumber(const unsigned long nb) { SurfaceNumber = nb; } const char * Surface::GetSurfaceComments() const { return SurfaceComments.c_str(); } void Surface::SetSurfaceComments(const char * comment) { SurfaceComments = comment; } bool Surface::GetSurfaceProcessing() const { return SurfaceProcessing; } void Surface::SetSurfaceProcessing(bool b) { SurfaceProcessing = b; } float Surface::GetSurfaceProcessingRatio() const { return SurfaceProcessingRatio; } void Surface::SetSurfaceProcessingRatio(const float ratio) { SurfaceProcessingRatio = ratio; } const char * Surface::GetSurfaceProcessingDescription() const { return SurfaceProcessingDescription.c_str(); } void Surface::SetSurfaceProcessingDescription(const char * description) { SurfaceProcessingDescription = description; } SegmentHelper::BasicCodedEntry const & Surface::GetProcessingAlgorithm() const { return ProcessingAlgorithm; } SegmentHelper::BasicCodedEntry & Surface::GetProcessingAlgorithm() { return ProcessingAlgorithm; } void Surface::SetProcessingAlgorithm(SegmentHelper::BasicCodedEntry const & BSE) { ProcessingAlgorithm.CV = BSE.CV; ProcessingAlgorithm.CSD = BSE.CSD; ProcessingAlgorithm.CM = BSE.CM; } Surface::STATES Surface::GetFiniteVolume() const { return FiniteVolume; } void Surface::SetFiniteVolume(STATES state) { assert( state < STATES_END ); FiniteVolume = state; } Surface::STATES Surface::GetManifold() const { return Manifold; } void Surface::SetManifold(STATES state) { assert( state < STATES_END ); Manifold = state; } SegmentHelper::BasicCodedEntry const & Surface::GetAlgorithmFamily() const { return AlgorithmFamily; } SegmentHelper::BasicCodedEntry & Surface::GetAlgorithmFamily() { return AlgorithmFamily; } void Surface::SetAlgorithmFamily(SegmentHelper::BasicCodedEntry const & BSE) { AlgorithmFamily.CV = BSE.CV; AlgorithmFamily.CSD = BSE.CSD; AlgorithmFamily.CM = BSE.CM; } const char * Surface::GetAlgorithmVersion() const { return AlgorithmVersion.c_str(); } void Surface::SetAlgorithmVersion(const char * str) { AlgorithmVersion = str; } const char * Surface::GetAlgorithmName() const { return AlgorithmName.c_str(); } void Surface::SetAlgorithmName(const char * str) { AlgorithmName = str; } unsigned long Surface::GetNumberOfSurfacePoints() const { return NumberOfSurfacePoints; } void Surface::SetNumberOfSurfacePoints(const unsigned long nb) { NumberOfSurfacePoints = nb; } const DataElement & Surface::GetPointCoordinatesData() const { return PointCoordinatesData; } DataElement & Surface::GetPointCoordinatesData() { return PointCoordinatesData; } void Surface::SetPointCoordinatesData(DataElement const & de) { PointCoordinatesData = de; } const float * Surface::GetPointPositionAccuracy() const { return PointPositionAccuracy; } void Surface::SetPointPositionAccuracy(const float * accuracies) { assert(accuracies); if (PointPositionAccuracy == nullptr) PointPositionAccuracy = new float[3]; PointPositionAccuracy[0] = accuracies[0]; PointPositionAccuracy[1] = accuracies[1]; PointPositionAccuracy[2] = accuracies[2]; } float Surface::GetMeanPointDistance() const { return MeanPointDistance; } void Surface::SetMeanPointDistance(float average) { MeanPointDistance = average; } float Surface::GetMaximumPointDistance() const { return MaximumPointDistance; } void Surface::SetMaximumPointDistance(float maximum) { MaximumPointDistance = maximum; } const float * Surface::GetPointsBoundingBoxCoordinates() const { return PointsBoundingBoxCoordinates; } void Surface::SetPointsBoundingBoxCoordinates(const float * coordinates) { assert(coordinates); if (PointsBoundingBoxCoordinates == nullptr) PointsBoundingBoxCoordinates = new float[6]; PointsBoundingBoxCoordinates[0] = coordinates[0]; PointsBoundingBoxCoordinates[1] = coordinates[1]; PointsBoundingBoxCoordinates[2] = coordinates[2]; PointsBoundingBoxCoordinates[3] = coordinates[3]; PointsBoundingBoxCoordinates[4] = coordinates[4]; PointsBoundingBoxCoordinates[5] = coordinates[5]; } const float * Surface::GetAxisOfRotation() const { return AxisOfRotation; } void Surface::SetAxisOfRotation(const float * axis) { assert(axis); if (AxisOfRotation == nullptr) AxisOfRotation = new float[3]; AxisOfRotation[0] = axis[0]; AxisOfRotation[1] = axis[1]; AxisOfRotation[2] = axis[2]; } const float * Surface::GetCenterOfRotation() const { return CenterOfRotation; } void Surface::SetCenterOfRotation(const float * center) { assert(center); if (CenterOfRotation == nullptr) CenterOfRotation = new float[3]; CenterOfRotation[0] = center[0]; CenterOfRotation[1] = center[1]; CenterOfRotation[2] = center[2]; } unsigned long Surface::GetNumberOfVectors() const { return NumberOfVectors; } void Surface::SetNumberOfVectors(const unsigned long nb) { NumberOfVectors = nb; } unsigned short Surface::GetVectorDimensionality() const { return VectorDimensionality; } void Surface::SetVectorDimensionality(const unsigned short dim) { VectorDimensionality = dim; } const float * Surface::GetVectorAccuracy() const { return VectorAccuracy; } void Surface::SetVectorAccuracy(const float * accuracy) { assert(accuracy); if (VectorAccuracy == nullptr) VectorAccuracy = new float[ VectorDimensionality ]; for (unsigned int i = 0; i < VectorDimensionality; ++i) VectorAccuracy[i] = accuracy[i]; } const DataElement & Surface::GetVectorCoordinateData() const { return VectorCoordinateData; } DataElement & Surface::GetVectorCoordinateData() { return VectorCoordinateData; } void Surface::SetVectorCoordinateData(DataElement const & de) { VectorCoordinateData = de; } MeshPrimitive const & Surface::GetMeshPrimitive() const { return *Primitive; } MeshPrimitive & Surface::GetMeshPrimitive() { return *Primitive; } void Surface::SetMeshPrimitive(MeshPrimitive & mp) { Primitive = mp; } }