public class DicomDirectory
extends java.lang.Object
implements javax.swing.tree.TreeModel
Modifier and Type | Field and Description |
---|---|
protected java.util.HashMap |
mapOfDirectoryRecordsToSequenceItems |
Constructor and Description |
---|
DicomDirectory()
Create an empty DicomDirectory
|
DicomDirectory(AttributeList list)
Create a DicomDirectory from a DICOMDIR instance already read as an AttributeList
|
DicomDirectory(AttributeList list,
boolean doConcatenations)
Create a DicomDirectory from a DICOMDIR instance already read as an AttributeList, optionally creating synthetic concatenation records
|
DicomDirectory(java.io.File rootDirectory,
java.lang.String[] fileNames)
Create a new DicomDirectory from a list of existing DICOM files contained within a specified root directory.
|
DicomDirectory(java.lang.String[] fileNames)
Create a new DicomDirectory from a list of existing DICOM files contained within the current working directory.
|
Modifier and Type | Method and Description |
---|---|
void |
addAttributeListFromDicomFileToDirectory(AttributeList list,
java.lang.String fileName)
Add an instance described by a list of attributes to this directory.
|
void |
addTreeModelListener(javax.swing.event.TreeModelListener tml) |
static java.util.Vector<java.lang.String> |
findAllContainedReferencedFileNames(DicomDirectoryRecord record,
java.lang.String parentFilePath)
Get all the referenced file names at or below the specified directory record.
|
java.util.Vector<java.lang.String> |
findAllContainedReferencedFileNames(java.lang.String parentFilePath)
Get all the referenced file names in the entire directory.
|
static java.util.HashMap<java.lang.String,DicomDirectoryRecord> |
findAllContainedReferencedFileNamesAndTheirRecords(DicomDirectoryRecord record,
java.lang.String parentFilePath)
Get all the referenced file names at or below the specified directory record, and a map to the directory records that reference them.
|
java.util.HashMap<java.lang.String,DicomDirectoryRecord> |
findAllContainedReferencedFileNamesAndTheirRecords(java.lang.String parentFilePath)
Get all the referenced file names in the entire directory, and a map to the directory records that reference them.
|
java.util.Vector<AttributeList> |
findAllImagesForFrameOfReference(java.lang.String frameOfReferenceUID)
Get the attribute lists from all the IMAGE level directory records which have a particular FrameOfReferenceUID.
|
java.lang.Object |
getChild(java.lang.Object node,
int index) |
int |
getChildCount(java.lang.Object parent) |
int |
getIndexOfChild(java.lang.Object parent,
java.lang.Object child) |
java.util.Map<java.lang.String,java.lang.String> |
getMapOfSOPInstanceUIDToReferencedFileName(java.lang.String parentFilePath)
Build a map of file names indexed by SOP Instance UID.
|
java.lang.String |
getReferencedFileNameForSOPInstanceUID(java.lang.String sopInstanceUID)
Get the file name for the specified SOP Instance UID.
|
java.lang.Object |
getRoot() |
boolean |
isLeaf(java.lang.Object node) |
static void |
main(java.lang.String[] arg)
Read DICOM files and create a DICOMDIR.
|
void |
readDicomFileAndAddToDirectory(java.io.File rootDirectory,
java.lang.String fileName)
Read DICOM file and add it to this directory.
|
void |
readDicomFileAndAddToDirectory(java.lang.String fileName)
Read DICOM file and add it to this directory.
|
void |
removeTreeModelListener(javax.swing.event.TreeModelListener tml) |
java.lang.String |
toString() |
void |
valueForPathChanged(javax.swing.tree.TreePath path,
java.lang.Object newValue) |
void |
write(java.lang.String name)
Write the directory to the named file.
|
protected java.util.HashMap mapOfDirectoryRecordsToSequenceItems
public DicomDirectory()
public DicomDirectory(AttributeList list) throws DicomException
list
- a list of attributes describing a DICOMDIR instanceDicomException
- if error in DICOM encodingpublic DicomDirectory(AttributeList list, boolean doConcatenations) throws DicomException
list
- a list of attributes describing a DICOMDIR instancedoConcatenations
- true if synthetic concatenation records are to be createdDicomException
- if error in DICOM encodingpublic DicomDirectory(java.io.File rootDirectory, java.lang.String[] fileNames)
Create a new DicomDirectory from a list of existing DICOM files contained within a specified root directory.
The specified root directory will NOT be included in the referenced file name in the DICOMDIR records.
Filenames are NOT checked for compliance with restrictions on length and character set.
rootDirectory
- the name of the directory to use as the root, which contains the DICOM filefileNames
- the names of the DICOM files (relative to rootDirectory)public DicomDirectory(java.lang.String[] fileNames)
Create a new DicomDirectory from a list of existing DICOM files contained within the current working directory.
The filenames must be relative to the current working directory, and not absolute paths, since the full name will be used in the DICOMDIR records.
Filenames are NOT checked for compliance with restrictions on length and character set.
fileNames
- the names of the DICOM files (relative to the current working directory)public void addAttributeListFromDicomFileToDirectory(AttributeList list, java.lang.String fileName) throws DicomException, java.io.IOException
list
- the list of attributes containing the attributes to add to this directoryfileName
- the name of the DICOM filejava.io.IOException
- if an I/O error occursDicomException
- if error in DICOM encoding, or the SOP Class is not recognized, or the instance already exists in the directorypublic void addTreeModelListener(javax.swing.event.TreeModelListener tml)
addTreeModelListener
in interface javax.swing.tree.TreeModel
public static java.util.Vector<java.lang.String> findAllContainedReferencedFileNames(DicomDirectoryRecord record, java.lang.String parentFilePath)
Get all the referenced file names at or below the specified directory record.
record
- directory record to start atparentFilePath
- the folder in which the DICOMDIR lives (i.e., the base for contained references)Vector
of String
file names fully qualified by the specified parentpublic java.util.Vector<java.lang.String> findAllContainedReferencedFileNames(java.lang.String parentFilePath)
Get all the referenced file names in the entire directory.
parentFilePath
- the folder in which the DICOMDIR lives (i.e., the base for contained references)Vector
of String
file names fully qualified by the specified parentpublic static java.util.HashMap<java.lang.String,DicomDirectoryRecord> findAllContainedReferencedFileNamesAndTheirRecords(DicomDirectoryRecord record, java.lang.String parentFilePath)
Get all the referenced file names at or below the specified directory record, and a map to the directory records that reference them.
record
- directory record to start atparentFilePath
- the folder in which the DICOMDIR lives (i.e., the base for contained references)HashMap
whose keys are String
file names fully qualified by the specified parent, mapped to DicomDirectoryRecordspublic java.util.HashMap<java.lang.String,DicomDirectoryRecord> findAllContainedReferencedFileNamesAndTheirRecords(java.lang.String parentFilePath)
Get all the referenced file names in the entire directory, and a map to the directory records that reference them.
parentFilePath
- the folder in which the DICOMDIR lives (i.e., the base for contained references)HashMap
whose keys are String
file names fully qualified by the specified parent, mapped to DicomDirectoryRecordspublic java.util.Vector<AttributeList> findAllImagesForFrameOfReference(java.lang.String frameOfReferenceUID)
Get the attribute lists from all the IMAGE level directory records which have a particular FrameOfReferenceUID.
Useful for finding potential localizers and orthogonal images.
Note that even though FrameOfReference is a series level entity, in the CT/MR profiles it is specified at the IMAGE directory record level.
frameOfReferenceUID
- the frame of reference UID to search forVector
of AttributeList
public java.lang.Object getChild(java.lang.Object node, int index)
getChild
in interface javax.swing.tree.TreeModel
public int getChildCount(java.lang.Object parent)
getChildCount
in interface javax.swing.tree.TreeModel
public int getIndexOfChild(java.lang.Object parent, java.lang.Object child)
getIndexOfChild
in interface javax.swing.tree.TreeModel
public java.util.Map<java.lang.String,java.lang.String> getMapOfSOPInstanceUIDToReferencedFileName(java.lang.String parentFilePath)
Build a map of file names indexed by SOP Instance UID.
parentFilePath
- the path to the root of the file names encoded in this directorypublic java.lang.String getReferencedFileNameForSOPInstanceUID(java.lang.String sopInstanceUID) throws DicomException
Get the file name for the specified SOP Instance UID.
sopInstanceUID
- the SOP Instance UID wantedDicomException
- if map has not been initializedpublic java.lang.Object getRoot()
getRoot
in interface javax.swing.tree.TreeModel
public boolean isLeaf(java.lang.Object node)
isLeaf
in interface javax.swing.tree.TreeModel
public static void main(java.lang.String[] arg)
Read DICOM files and create a DICOMDIR.
arg
- optionally the folder in which the files and DICOMDIR are rooted, the filename of the DICOMDIR to be created, then optionally a list of all the filenames of the DICOM files to include (otherwise the folder will be searched)public void readDicomFileAndAddToDirectory(java.io.File rootDirectory, java.lang.String fileName) throws DicomException, java.io.IOException
rootDirectory
- the name of the directory to use as the root, which contains the DICOM filefileName
- the name of the DICOM file (relative to rootDirectory)java.io.IOException
- if an I/O error occursDicomException
- if error in DICOM encodingpublic void readDicomFileAndAddToDirectory(java.lang.String fileName) throws DicomException, java.io.IOException
fileName
- the name of the DICOM file (relative to the current working directory)java.io.IOException
- if an I/O error occursDicomException
- if error in DICOM encodingpublic void removeTreeModelListener(javax.swing.event.TreeModelListener tml)
removeTreeModelListener
in interface javax.swing.tree.TreeModel
public java.lang.String toString()
toString
in class java.lang.Object
public void valueForPathChanged(javax.swing.tree.TreePath path, java.lang.Object newValue)
valueForPathChanged
in interface javax.swing.tree.TreeModel
public void write(java.lang.String name) throws java.io.IOException, DicomException
Write the directory to the named file.
name
- the file name to write tojava.io.IOException
- if an I/O error occursDicomException
- if error in DICOM encoding