1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126
|
/*============================================================================
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_METASCENE_H
# define ITKMetaIO_METASCENE_H
# include "metaUtils.h"
# include "metaObject.h"
# ifdef _MSC_VER
# pragma warning(disable : 4251)
# endif
# include <list>
/*! MetaScene (.h and .cpp)
*
* Description:
* Reads and Writes MetaTubeFiles.
*
* \author Julien Jomier
*
* \date July, 2002
*
*/
# if (METAIO_USE_NAMESPACE)
namespace METAIO_NAMESPACE
{
# endif
class METAIO_EXPORT MetaScene : public MetaObject
{
// PUBLIC
public:
typedef std::list<MetaObject *> ObjectListType;
// Constructors & Destructor
MetaScene();
explicit MetaScene(const MetaScene * _scene);
explicit MetaScene(unsigned int dim);
~MetaScene() override;
void
PrintInfo() const override;
void
CopyInfo(const MetaObject * _object) override;
void
AddObject(MetaObject * object);
// This function only reads registered tubes
bool
Read(const char * _headerName = nullptr) override;
bool
Write(const char * _headName = nullptr) override;
bool
Append(const char * = nullptr) override
{
std::cout << "Not Implemented !" << std::endl;
return true;
}
void
Clear() override;
// NObjects(...)
// Required Field
// Number of points which compose the tube
void
NObjects(int nobjects);
int
NObjects() const;
ObjectListType *
GetObjectList()
{
return &m_ObjectList;
}
// PROTECTED
protected:
bool m_ElementByteOrderMSB{};
void
M_SetupReadFields() override;
void
M_SetupWriteFields() override;
bool
M_Read() override;
bool
M_Write() override;
int m_NObjects{}; // "NObjects = " 0
ObjectListType m_ObjectList;
};
# if (METAIO_USE_NAMESPACE)
};
# endif
#endif
|