/usr/include/InsightToolkit/IO/itkDICOMSeriesFileNames.h is in libinsighttoolkit3-dev 3.20.1+git20120521-6build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 | /*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: itkDICOMSeriesFileNames.h
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm 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 notices for more information.
=========================================================================*/
#ifndef __itkDICOMSeriesFileNames_h
#define __itkDICOMSeriesFileNames_h
#ifdef _MSC_VER
#pragma warning ( disable : 4786 )
#endif
#include "itkObject.h"
#include "itkObjectFactory.h"
#include "itkExceptionObject.h"
#include <vector>
#include "DICOMParser.h"
#include "DICOMAppHelper.h"
namespace itk
{
/** \class DICOMSeriesFileNames
* \brief Generate an ordered sequence of filenames.
*
* This class generates an ordered sequence of filenames based on the
* DICOM tags in the files. Files can be sorted based on image number,
* slice location, or patient position. The files in the specified
* directory are grouped by SeriesUID. The list of SeriesUIDs can be
* queried and the filenames for a specific series extracted.
*
* \ingroup IOFilters
*
*/
class ITK_EXPORT DICOMSeriesFileNames : public Object
{
public:
/** Standard class typedefs. */
typedef DICOMSeriesFileNames Self;
typedef Object Superclass;
typedef SmartPointer<Self> Pointer;
/** Method for creation through the object factory. */
itkNewMacro(Self);
/** Run-time type information (and related methods). */
itkTypeMacro(DICOMSeriesFileNames, Object);
/* -------- Define the API for DICOMSeriesFileNames ----------- */
/** Set the directory containing the DICOM
* files. DICOMSeriesFileNames caches information about filenames
* and series UIDs. Calling SetDirectory() causes this information
* to be cleared. This is the behavior even if SetDirectory() is
* called with the same directory as the previous call. In this
* case, a second call to SetDirectory() with the same directory
* name forces the directory to be rescanned. This is useful if
* DICOM files have been added to a directory since the last time
* the directory was scanned. */
void SetDirectory(const std::string& dir)
{
if (m_Directory != dir)
{
m_Directory = dir;
this->Modified();
// Clear the SeriesUIDs and FileNames
m_SeriesUIDs.clear();
m_FileNames.clear();
m_AppHelper.Clear();
}
// Keep track of when the directory name was set so we can
// compare it when the directory was last scanned. We set this
// modified time each time SetDirectory() is called. This allows
// a call to SetDirectory() to force a directory to be rescanned
// the next time GetFileNames() or GetSeriesUIDs() is called.
m_DirectorySetTime.Modified();
}
/** Get the directory containing the DICOM files. */
itkGetStringMacro(Directory);
/** The sorting order can be ascending or descending. The default
* sort order is ascending. */
itkSetMacro(Ascending, bool);
itkGetConstMacro(Ascending, bool);
itkBooleanMacro(Ascending);
/** Type of the array used for returning filenames */
typedef std::vector<std::string> FileNamesArrayType;
/** Returns a vector containing the UIDs for each series in the
* directory. If parameter "recursive" is true, subdirectories will
* be scanned. */
const FileNamesArrayType & GetSeriesUIDs(bool recursive = false);
/** Returns a vector containing the Descriptions for each series in the
* directory. GetSeriesUIDs() should be called before */
const FileNamesArrayType & GetSeriesDescriptions(){return m_SeriesDescriptions;}
const FileNamesArrayType & GetSeriesBodyParts(){return m_BodyParts;}
const FileNamesArrayType & GetSeriesScanOptions(){return m_ScanOptions;}
/** Returns a vector containing the series file names. The file
* names are sorted based on the current sorting mode. If parameter
* "recursive" is true, subdirectories will be scanned. */
const FileNamesArrayType & GetFileNames (bool recursive = false);
/** Returns a vector containing the file names for a specified
* series UID. The file names are sorted based on the current
* sorting mode. If parameter "recursive" is true, subdirectories
* will be scanned. */
const FileNamesArrayType & GetFileNames (const std::string& seriesUID,
bool recursive = false);
/** Set the filename sorting order to sorting images based on the
* DICOM field of slice number, the DICOM field of slice location,
* or the position of the image computed using the
* ImagePositionPatient and ImageOrientationPatient DICOM fields. */
typedef enum {SortByImageNumber, SortBySliceLocation, SortByImagePositionPatient} FileNameSortingOrderType;
itkSetEnumMacro(FileNameSortingOrder, FileNameSortingOrderType);
itkGetEnumMacro(FileNameSortingOrder, FileNameSortingOrderType);
void SetFileNameSortingOrderToSortByImageNumber()
{ this->SetFileNameSortingOrder(SortByImageNumber); }
void SetFileNameSortingOrderToSortBySliceLocation()
{ this->SetFileNameSortingOrder(SortBySliceLocation); }
void SetFileNameSortingOrderToSortByImagePositionPatient()
{ this->SetFileNameSortingOrder(SortByImagePositionPatient); }
/** Get the filename associated with a specific instance UID. This
* requires the internal database has already been built via a call
* to GetFileNames() */
std::string GetFileName(const std::string& instanceUID);
protected:
DICOMSeriesFileNames();
~DICOMSeriesFileNames() {};
void PrintSelf(std::ostream& os, Indent indent) const;
private:
DICOMSeriesFileNames(const Self&); //purposely not implemented
void operator=(const Self&); //purposely not implemented
int CanReadFile(const char* fname);
void RecurseDirectory( std::string directory, FileNamesArrayType &filenames);
itkdicomparser::DICOMParser m_Parser;
itkdicomparser::DICOMAppHelper m_AppHelper;
bool m_Ascending;
std::string m_Directory;
FileNamesArrayType m_FileNames;
FileNamesArrayType m_SeriesUIDs;
FileNamesArrayType m_SeriesDescriptions;
FileNamesArrayType m_BodyParts;
FileNamesArrayType m_ScanOptions;
FileNameSortingOrderType m_FileNameSortingOrder;
TimeStamp m_DirectorySetTime;
TimeStamp m_DirectoryScanTime;
};
} //namespace ITK
#endif // __itkDICOMSeriesFileNames_h
|