You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
171 lines
3.7 KiB
C++
171 lines
3.7 KiB
C++
/*============================================================================
|
|
MetaIO
|
|
Copyright 2000-2010 Insight Software Consortium
|
|
|
|
Distributed under the OSI-approved BSD License (the "License");
|
|
see accompanying file Copyright.txt for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
See the License for more information.
|
|
============================================================================*/
|
|
#include "metaTypes.h"
|
|
|
|
#ifndef ITKMetaIO_METACONTOUR_H
|
|
#define ITKMetaIO_METACONTOUR_H
|
|
|
|
#include "metaUtils.h"
|
|
#include "metaObject.h"
|
|
|
|
#ifdef _MSC_VER
|
|
#pragma warning ( disable: 4786 )
|
|
#pragma warning ( disable: 4251 )
|
|
#endif
|
|
|
|
#include <list>
|
|
|
|
#if (METAIO_USE_NAMESPACE)
|
|
namespace METAIO_NAMESPACE {
|
|
#endif
|
|
|
|
/**
|
|
* Description:
|
|
* Reads and Writes MetaContour Files.
|
|
*
|
|
* \author Julien Jomier
|
|
*
|
|
* \date March 2006
|
|
*
|
|
*/
|
|
class METAIO_EXPORT ContourControlPnt
|
|
{
|
|
public:
|
|
|
|
ContourControlPnt(int dim);
|
|
~ContourControlPnt();
|
|
|
|
unsigned int m_Dim;
|
|
unsigned int m_Id;
|
|
float* m_X;
|
|
float* m_XPicked;
|
|
float* m_V;
|
|
float m_Color[4];
|
|
};
|
|
|
|
|
|
class METAIO_EXPORT ContourInterpolatedPnt
|
|
{
|
|
public:
|
|
|
|
ContourInterpolatedPnt(int dim)
|
|
{
|
|
m_Dim = dim;
|
|
m_Id = 0;
|
|
m_X = new float[m_Dim];
|
|
//Color is red by default
|
|
m_Color[0]=1.0f;
|
|
m_Color[1]=0.0f;
|
|
m_Color[2]=0.0f;
|
|
m_Color[3]=1.0f;
|
|
}
|
|
|
|
~ContourInterpolatedPnt()
|
|
{
|
|
delete []m_X;
|
|
}
|
|
|
|
unsigned int m_Dim;
|
|
float* m_X;
|
|
unsigned int m_Id;
|
|
float m_Color[4];
|
|
};
|
|
|
|
|
|
class METAIO_EXPORT MetaContour : public MetaObject
|
|
{
|
|
|
|
public:
|
|
|
|
typedef METAIO_STL::list<ContourControlPnt*> ControlPointListType;
|
|
typedef METAIO_STL::list<ContourInterpolatedPnt*> InterpolatedPointListType;
|
|
|
|
MetaContour(void);
|
|
MetaContour(const char *_headerName);
|
|
MetaContour(const MetaContour *_Contour);
|
|
MetaContour(unsigned int dim);
|
|
|
|
~MetaContour(void);
|
|
|
|
void PrintInfo(void) const;
|
|
void CopyInfo(const MetaObject * _object);
|
|
|
|
// NPoints(...)
|
|
// Required Field
|
|
// Number of points wich compose the tube
|
|
int NControlPoints(void) const;
|
|
|
|
// ControlPointDim(...)
|
|
// Required Field
|
|
// Definition of points
|
|
void ControlPointDim(const char* pointDim);
|
|
const char* ControlPointDim(void) const;
|
|
|
|
MET_InterpolationEnumType Interpolation(void) const;
|
|
void Interpolation(MET_InterpolationEnumType _interpolation);
|
|
|
|
int NInterpolatedPoints(void) const;
|
|
|
|
void InterpolatedPointDim(const char* pointDim);
|
|
const char* InterpolatedPointDim(void) const;
|
|
|
|
void Closed(bool close);
|
|
bool Closed() const;
|
|
|
|
void AttachedToSlice(long int slice);
|
|
long int AttachedToSlice() const;
|
|
|
|
void DisplayOrientation(int display);
|
|
int DisplayOrientation() const;
|
|
|
|
void Clear(void);
|
|
|
|
ControlPointListType & GetControlPoints(void)
|
|
{return m_ControlPointsList;}
|
|
const ControlPointListType & GetControlPoints(void) const
|
|
{return m_ControlPointsList;}
|
|
|
|
InterpolatedPointListType & GetInterpolatedPoints(void)
|
|
{return m_InterpolatedPointsList;}
|
|
const InterpolatedPointListType & GetInterpolatedPoints(void) const
|
|
{return m_InterpolatedPointsList;}
|
|
|
|
protected:
|
|
|
|
bool m_ElementByteOrderMSB;
|
|
void M_Destroy(void);
|
|
void M_SetupReadFields(void);
|
|
void M_SetupWriteFields(void);
|
|
bool M_Read(void);
|
|
bool M_Write(void);
|
|
|
|
int m_NControlPoints;
|
|
int m_NInterpolatedPoints;
|
|
char m_ControlPointDim[255];
|
|
char m_InterpolatedPointDim[255];
|
|
bool m_Closed;
|
|
MET_InterpolationEnumType m_InterpolationType;
|
|
ControlPointListType m_ControlPointsList;
|
|
InterpolatedPointListType m_InterpolatedPointsList;
|
|
|
|
int m_DisplayOrientation;
|
|
long m_AttachedToSlice;
|
|
|
|
};
|
|
|
|
#if (METAIO_USE_NAMESPACE)
|
|
};
|
|
#endif
|
|
|
|
|
|
#endif
|