MeVisLab Toolbox Reference
|
Class managing a list of MultiFileVolume instances for the DirectDicomImport module; taking ownership of all added, push_back-ed or inserted MultiFileVolume instances. More...
#include <mlMultiFileVolumeList.h>
Public Types | |
typedef void | ProgressCB(void *usrData, const std::string &info, float state) |
Progress callback which can be passed to some functions for progress bar updates in DirectDicomImport. More... | |
typedef void | RemoveUserFileCB(const size_t volumeIndex, const std::string &validCacheDir, const std::string &validCacheFileName) |
A function callback which removes a user added cache file related to a volume which is stored in the cache director validCacheDir and is related to the cache file validCacheFileName. More... | |
Public Member Functions | |
MultiFileVolumeList () | |
virtual | ~MultiFileVolumeList () |
Destructor. More... | |
MultiFileVolumeList (const MultiFileVolumeList &ref) | |
Copy constructor. More... | |
MultiFileVolumeList & | operator= (const MultiFileVolumeList &ref) |
Assignment operator *creating copied duplicates from ref). More... | |
void | setUpIssues (const DicomMessageCollector *dcmMsgCollector=nullptr) |
Sets up the 'issues' members of all volumes; see MultiFileVolume::setUpIssues() for details. More... | |
std::string | getIssues (const DicomMessageCollector *dcmMsgCollector=nullptr) const |
Returns a collected string with all issues; requires that issues have been set up before. More... | |
void | freeAllVolumes () |
Deletes all volumes and reduce vector size to 0. More... | |
bool | equals (const MultiFileVolumeList &obj) const |
Returns true if basic properties of *this and obj are identical, otherwise false. More... | |
void | sortVolumes (MultiFileVolumeListSort::SortModes sortMode, bool sortUpwards, MLint rawTagId, bool useNumericTagStringValueSorting) |
Sorts the volume list according the given sort criteria sortMode; see MultiFileVolumeListSort for details. More... | |
MultiFileVolume * | findVolumeByInstanceUID (std::string sopClassUID, std::string sopInstanceUID) const |
Find a volume in *this using given SOPClassUID and SOPInstanceUID; see MultiFileVolumeListFind for details. More... | |
bool | findVolumesByCriteria (TSearchTerm searchTerm, std::vector< MLuint32 > &outVolumeIds, MultiFileVolumeListFind::BooleanOperation booleanOperation, bool searchAnyValue) const |
Find volumes in *this using given searchTerm (containing e.g. More... | |
MLErrorCode | appendToCache (const std::string &cacheDirPath, std::string &currCacheState, bool useRelativePaths, const std::string &optionalFilePrefix="") const |
Converts the current state of this to a string. More... | |
MLErrorCode | setFromString (const std::string &state, const std::string &cacheDirPath, ProgressCB progressCB=nullptr, void *userData=nullptr, const float startPercentage=0.0f, const float percentageRange=1.0f, std::list< std::string > *cacheFileList=nullptr, DicomMessageCollector *dcmMsgCollector=nullptr) |
Reads the state of this from the string state; returns ML_RESULT_OK on successful load and false on failure. More... | |
bool | searchFrameWithSOPInstanceUID (const std::string &sopInstanceUID, DICOMCachedIOFileHandle &foundHandle, DICOMTagTools::ZTUIndex &ztuPosition, MultiFileVolumeList::const_iterator &volumeIt, bool forceSearchInEnhancedHandles, bool alsoSearchInSMFTrees, DicomMessageCollector &dcmMsgCollector) const |
Returns position and file handle of the first frame in the first volume with the given SOPInstanceUID. More... | |
bool | searchFrameWithValueInTag (unsigned int tagId, const std::string &tagValue, DICOMCachedIOFileHandle &foundHandle, DICOMTagTools::ZTUIndex &ztuPosition, MultiFileVolumeList::const_iterator &volumeIt, bool forceSearchInEnhancedHandles, bool alsoSearchInSMFTrees, DicomMessageCollector &dcmMsgCollector) const |
Returns file handle and position of the first frame in the first volume with tagValue in a tag with id tagId. More... | |
std::vector< MultiFileVolumeList::const_iterator > | searchVolumesWithFramesWithValueInTag (unsigned int tagId, const std::string &tagValue, bool forceSearchInEnhancedHandles, bool alsoSearchInSMFTrees, DicomMessageCollector &dcmMsgCollector) const |
Returns a vector of iterators to volumes which contain a frame with a tag with id tagId with value tagValue. More... | |
std::set< size_t > | searchVolumeIndexesWithValueInTag (unsigned int tagId, const std::string &tagValue, bool forceSearchInEnhancedHandles, bool alsoSearchInSMFTrees, DicomMessageCollector &dcmMsgCollector) const |
Returns a set of indexes to volumes which contain a frame with a tag with id tagId with value tagValue. More... | |
Protected Member Functions | |
MLErrorCode | _setFromMultiCacheFile (const std::string &state, const std::string &cacheDirPath, ProgressCB progressCB, void *userData, const float startPercentage, const float percentageRange, std::list< std::string > *cacheFileList, size_t &readPos, DicomMessageCollector *dcmMsgCollector) |
Helper function for setFromString: Reads the state of this from the string state; returns ML_RESULT_OK on successful load and false on failure. More... | |
Loading, clearing, and saving the result cache. | |
MLErrorCode | loadResultCache (const std::string &fileNameInput, const std::string &cachePathInput, ProgressLogger *progressLogger, bool &volumeListChanged, ProgressCB progressCallback, void *userData) |
Reload all information from the cache file in the cache file directory into the internal volume list and updates all related fields etc. More... | |
MLErrorCode | writeResultCache (const std::string &fileNameInput, const std::string &cachePathInput, const bool useRelativePaths, const bool writeSingleVolumeCaches, ProgressLogger *progressLogger) const |
Writes all information into the cache file in the cache file directory. More... | |
MLErrorCode | loadResultCacheIntoVolumeList (const std::string &sourceFileName, const std::string &cacheDirPath, bool *volumeListChanged=nullptr, ProgressCB progressCB=nullptr, void *userData=nullptr, const float startPercentage=0.0f, const float percentageRange=1.0f, std::list< std::string > *cacheFileList=nullptr, DicomMessageCollector *dcmMsgCollector=nullptr) |
Reload all information from the cache file in the cache file directory into *this. More... | |
MLErrorCode | loadMultiFileVolumeListCache (const std::string &fileName, bool *volumeListChanged=nullptr, ProgressCB progressCB=nullptr, void *userData=nullptr, const float startPercentage=0.0f, const float percentageRange=1.0f, std::list< std::string > *cacheFileList=nullptr) |
Alternative load routine for a MultiFileVolume(List) from a cache file which first splits fileName to sourceFileName and cacheDirPath and then calls loadResultCacheIntoVolumeList; see its documentation for all other parameters. More... | |
MLErrorCode | clearResultFiles (ProgressLogger *progressLogger=nullptr) const |
Clear all stored SMF-Tree files for the MultiFileVolumeList instance; cache files are not removed. More... | |
static std::string | getResultCacheFileName (const std::string &fileNameInput, const std::string &cachePathInput, std::string &fileName, std::string &cacheDirPath, const MLint fileIndex=-1) |
Returns the full name path of the result cache file. More... | |
static MLErrorCode | clearResultCacheFiles (const std::string &fileNameInput, const std::string &cachePathInput, ProgressLogger *progressLogger=nullptr, RemoveUserFileCB userFileDeleter=nullptr) |
Clear all files from the cache containing result volume files in the cache file directory. More... | |
Class managing a list of MultiFileVolume instances for the DirectDicomImport module; taking ownership of all added, push_back-ed or inserted MultiFileVolume instances.
Definition at line 47 of file mlMultiFileVolumeList.h.
typedef void ml::MultiFileVolumeList::ProgressCB(void *usrData, const std::string &info, float state) |
Progress callback which can be passed to some functions for progress bar updates in DirectDicomImport.
Definition at line 52 of file mlMultiFileVolumeList.h.
typedef void ml::MultiFileVolumeList::RemoveUserFileCB(const size_t volumeIndex, const std::string &validCacheDir, const std::string &validCacheFileName) |
A function callback which removes a user added cache file related to a volume which is stored in the cache director validCacheDir and is related to the cache file validCacheFileName.
Should be silent if the file does not exist.
Definition at line 59 of file mlMultiFileVolumeList.h.
ml::MultiFileVolumeList::MultiFileVolumeList | ( | ) |
|
virtual |
Destructor.
ml::MultiFileVolumeList::MultiFileVolumeList | ( | const MultiFileVolumeList & | ref | ) |
Copy constructor.
|
protected |
Helper function for setFromString: Reads the state of this from the string state; returns ML_RESULT_OK on successful load and false on failure.
On other return codes the state of this remains undefined. The content of the string state is reduced by the loaded volumes.
state | The string from which the data is read starting at readPos. |
cacheDirPath | The directory path where the cache file is located which contains state. |
progressCB | An optional static function pointer which is then called by this function to notify the progress while this function is executed (as described in percentageRange). |
userData | a pointer with user data passed to progressCB. It for example can be used to pass the calling instance object which is updated. |
startPercentage | is the percentage value of a progress bar which is updated when this function starts (for example to 0.3). |
percentageRange | is the range incrementally stepped through while this method is executed, for example 0.5. The progress then is increased incrementally from percentageStart to percentageStart+percentageRange, thus from 0.3 to 0.8 by a number of steps whose number is determined inside of the function. |
cacheFileList | If passed nullptr then it is ignored, otherwise it will be filled with the names of all cache files belonging to this stored cache. |
readPos | The position in state where reading shall start from; will be incremented to the position after data set during read. |
dcmMsgCollector | If passed non-nullptr then it collects error, info and issue messages (typically related to a handle). |
MLErrorCode ml::MultiFileVolumeList::appendToCache | ( | const std::string & | cacheDirPath, |
std::string & | currCacheState, | ||
bool | useRelativePaths, | ||
const std::string & | optionalFilePrefix = "" |
||
) | const |
Converts the current state of this to a string.
cacheDirPath | Directory location where the cache file shall be stored. |
currCacheState | The returned string containing the composed string list of cache strings of volumes. |
useRelativePaths | If false (the default) then all file names in the cache string are stored with absolute paths. If true and if all referenced and stored files are located in cacheDirPath then all files are stored relative to cacheDirPath. Files which are not in that path are stored with absolute paths. |
optionalFilePrefix | A prefix which is added before files which are created as sub files of the cache state, for example SMF trees which are stored on disk for caching will have this prefix. |
|
static |
Clear all files from the cache containing result volume files in the cache file directory.
fileNameInput | the file name as it comes from the module input field. |
cachePathInput | the cache path as it comes from the module input field. |
progressLogger | If non nullptr then message are sent to this logger, otherwise it is ignored and messages are not logged. |
userFileDeleter | can be passed to be called for each volume of the result cache; it can delete files created for each volume and which have been placed next to the cache file. |
MLErrorCode ml::MultiFileVolumeList::clearResultFiles | ( | ProgressLogger * | progressLogger = nullptr | ) | const |
Clear all stored SMF-Tree files for the MultiFileVolumeList instance; cache files are not removed.
progressLogger | If non nullptr then message are sent to this logger, otherwise it is ignored and messages are not logged. |
bool ml::MultiFileVolumeList::equals | ( | const MultiFileVolumeList & | obj | ) | const |
Returns true if basic properties of *this and obj are identical, otherwise false.
MultiFileVolume* ml::MultiFileVolumeList::findVolumeByInstanceUID | ( | std::string | sopClassUID, |
std::string | sopInstanceUID | ||
) | const |
Find a volume in *this using given SOPClassUID and SOPInstanceUID; see MultiFileVolumeListFind for details.
bool ml::MultiFileVolumeList::findVolumesByCriteria | ( | TSearchTerm | searchTerm, |
std::vector< MLuint32 > & | outVolumeIds, | ||
MultiFileVolumeListFind::BooleanOperation | booleanOperation, | ||
bool | searchAnyValue | ||
) | const |
Find volumes in *this using given searchTerm (containing e.g.
DICOM tag ids of uint32 type); see MultiFileVolumeListFind for details.
void ml::MultiFileVolumeList::freeAllVolumes | ( | ) |
Deletes all volumes and reduce vector size to 0.
std::string ml::MultiFileVolumeList::getIssues | ( | const DicomMessageCollector * | dcmMsgCollector = nullptr | ) | const |
Returns a collected string with all issues; requires that issues have been set up before.
|
static |
Returns the full name path of the result cache file.
fileNameInput | the file name as it comes from the module input field. |
cachePathInput | the cache path as it comes from the module input field. |
fileName | will return the fileName with suffix without path components. |
cacheDirPath | will return the directory path including "/" at its end without file name. |
fileIndex | If < 0 (the default) then it is ignored, otherwise it will be added to the file name as an index. |
MLErrorCode ml::MultiFileVolumeList::loadMultiFileVolumeListCache | ( | const std::string & | fileName, |
bool * | volumeListChanged = nullptr , |
||
ProgressCB | progressCB = nullptr , |
||
void * | userData = nullptr , |
||
const float | startPercentage = 0.0f , |
||
const float | percentageRange = 1.0f , |
||
std::list< std::string > * | cacheFileList = nullptr |
||
) |
Alternative load routine for a MultiFileVolume(List) from a cache file which first splits fileName to sourceFileName and cacheDirPath and then calls loadResultCacheIntoVolumeList; see its documentation for all other parameters.
MLErrorCode ml::MultiFileVolumeList::loadResultCache | ( | const std::string & | fileNameInput, |
const std::string & | cachePathInput, | ||
ProgressLogger * | progressLogger, | ||
bool & | volumeListChanged, | ||
ProgressCB | progressCallback, | ||
void * | userData | ||
) |
Reload all information from the cache file in the cache file directory into the internal volume list and updates all related fields etc.
If no changes occur on the volume list then volumeListChanged is set to false, otherwise it is set to true. On errors the internal list is completely cleared.
fileNameInput | the file name as it comes from the module input field. |
cachePathInput | the cache path as it comes from the module input field. |
progressLogger | If non nullptr then message are sent to this logger, otherwise it is ignored and messages are not logged. |
volumeListChanged | returns false if the volume list was not changed by the call, otherwise true. |
progressCallback | An optional static function pointer which is then called by this function to notify the progress while this function is executed. |
userData | The user data object passed from caller passing hidden contents. |
MLErrorCode ml::MultiFileVolumeList::loadResultCacheIntoVolumeList | ( | const std::string & | sourceFileName, |
const std::string & | cacheDirPath, | ||
bool * | volumeListChanged = nullptr , |
||
ProgressCB | progressCB = nullptr , |
||
void * | userData = nullptr , |
||
const float | startPercentage = 0.0f , |
||
const float | percentageRange = 1.0f , |
||
std::list< std::string > * | cacheFileList = nullptr , |
||
DicomMessageCollector * | dcmMsgCollector = nullptr |
||
) |
Reload all information from the cache file in the cache file directory into *this.
Return ML_RESULT_OK on success, otherwise an error code describing the problem. On errors the list is returned as far as possible to allow file clean up operations, even if it might not be complete. Non existing cache file are considered as error.
sourceFileName | The name of the cache file without path. |
cacheDirPath | The directory in which the sourceFile is located. |
volumeListChanged | If passed non nullptr then *volumeListChanged is set to true on any change or reload of volumeList, otherwise false. For example it returns false on return code ML_RESULT_OK, if the cache file is considered unchanged. |
progressCB | An optional static function pointer which is then called by this function to notify the progress while this function is executed (as described in percentageRange). |
userData | a pointer with user data passed to progressCB. It for example can be used to pass the calling instance object which is updated. |
startPercentage | is the percentage value of a progress bar which is updated when this function starts (for example to 0.3). |
percentageRange | is the range incrementally stepped through while this method is executed, for example 0.5. The progress then is increased incrementally from percentageStart to percentageStart+percentageRange, thus from 0.3 to 0.8 by a number of steps whose number is determined inside of the function. |
cacheFileList | If passed nullptr then it is ignored, otherwise it will be filled with the names of all cache files belonging to this stored cache (but no image or DICOM tree files). |
dcmMsgCollector | If passed non-nullptr then it collects error, info and issue messages (typically related to a handle). |
MultiFileVolumeList& ml::MultiFileVolumeList::operator= | ( | const MultiFileVolumeList & | ref | ) |
Assignment operator *creating copied duplicates from ref).
bool ml::MultiFileVolumeList::searchFrameWithSOPInstanceUID | ( | const std::string & | sopInstanceUID, |
DICOMCachedIOFileHandle & | foundHandle, | ||
DICOMTagTools::ZTUIndex & | ztuPosition, | ||
MultiFileVolumeList::const_iterator & | volumeIt, | ||
bool | forceSearchInEnhancedHandles, | ||
bool | alsoSearchInSMFTrees, | ||
DicomMessageCollector & | dcmMsgCollector | ||
) | const |
Returns position and file handle of the first frame in the first volume with the given SOPInstanceUID.
sopInstanceUID | Input parameter: The SOPInstanceUID to be searched in the frames. |
foundHandle | Output parameter: The file handle of the frame with the given SOPInstanceUID; will be empty if not found. |
ztuPosition | Output parameter: Will be set with z, t, and u indexes of the frame in the FileNameSet which has the given SOPInstanceUID; z, t, and u will be set to 0 if no frame with the given SOPInstanceUID is not found. |
volumeIt | Output parameter: Set to the found volume or to end() if not found. |
forceSearchInEnhancedHandles | Input parameter: If true then in enhanced frame handles is always searched; if false then only if the frames are available or if it is a normal frame handles. |
alsoSearchInSMFTrees | Input parameter: If true then the tagId+Value is also searched in the DicomSMFTree of the volume if not found in frames; in this case foundHandle will be set to the will be set to the firstFileName of the volume and ztuPosition members will be set to 0 and empty value. |
dcmMsgCollector | I/O parameter: Collects error, info and issue messages (typically related to a handle). |
bool ml::MultiFileVolumeList::searchFrameWithValueInTag | ( | unsigned int | tagId, |
const std::string & | tagValue, | ||
DICOMCachedIOFileHandle & | foundHandle, | ||
DICOMTagTools::ZTUIndex & | ztuPosition, | ||
MultiFileVolumeList::const_iterator & | volumeIt, | ||
bool | forceSearchInEnhancedHandles, | ||
bool | alsoSearchInSMFTrees, | ||
DicomMessageCollector & | dcmMsgCollector | ||
) | const |
Returns file handle and position of the first frame in the first volume with tagValue in a tag with id tagId.
tagId | Input parameter: The id of the tag to be searched. |
tagValue | Input parameter: The tagValue to be searched in the frames. |
foundHandle | Output parameter: The file handle of the frame with tagValue in a tag with id tagId; will be empty if not found. |
ztuPosition | Output parameter: Will be set with z, t, and u indexes of the frame in the FileNameSet which has the given tagValue in a tag with id tagId; z, t, and u will be set to 0 if no frame with the given SOPInstanceUID is not found. |
volumeIt | Output parameter: Set to the found volume or to end() if not found. |
forceSearchInEnhancedHandles | Input parameter: If true then in enhanced frame handles is always searched; if false then only if the frames are available or if it is a normal frame handles. |
alsoSearchInSMFTrees | Input parameter: If true then the tagId+Value is also searched in the DicomSMFTree of the volume if not found in frames; in this case foundHandle will be set to the will be set to the firstFileName of the volume and ztuPosition members will be set to 0 and empty value. |
dcmMsgCollector | I/O parameter: Collects error, info and issue messages (typically related to a handle). |
std::set<size_t> ml::MultiFileVolumeList::searchVolumeIndexesWithValueInTag | ( | unsigned int | tagId, |
const std::string & | tagValue, | ||
bool | forceSearchInEnhancedHandles, | ||
bool | alsoSearchInSMFTrees, | ||
DicomMessageCollector & | dcmMsgCollector | ||
) | const |
Returns a set of indexes to volumes which contain a frame with a tag with id tagId with value tagValue.
tagId | The id of the tag to be searched. |
tagValue | The tagValue to be searched in the frames. |
forceSearchInEnhancedHandles | If true then in enhanced frame handles is always searched; if false then only if the frames are available or if it is a normal frame handles. |
alsoSearchInSMFTrees | If true then the tagId+Value is also searched in the DicomSMFTree of the volume if not found in frames; in this case foundHandle will be set to the will be set to the firstFileName of the volume and ztuPosition members will be set to 0 and empty value. |
dcmMsgCollector | Collects error, info and issue messages (typically related to a handle). |
std::vector<MultiFileVolumeList::const_iterator> ml::MultiFileVolumeList::searchVolumesWithFramesWithValueInTag | ( | unsigned int | tagId, |
const std::string & | tagValue, | ||
bool | forceSearchInEnhancedHandles, | ||
bool | alsoSearchInSMFTrees, | ||
DicomMessageCollector & | dcmMsgCollector | ||
) | const |
Returns a vector of iterators to volumes which contain a frame with a tag with id tagId with value tagValue.
tagId | The id of the tag to be searched. |
tagValue | The tagValue to be searched in the frames. |
forceSearchInEnhancedHandles | If true then in enhanced frame handles is searched if they exist; if false then only normal frame handles and SMF trees are scanned. |
alsoSearchInSMFTrees | If true then the tagId+Value is also searched in the DicomSMFTree of the volume if not found in frames; in this case foundHandle will be set to the will be set to the firstFileName of the volume and ztuPosition members will be set to 0 and empty value. |
dcmMsgCollector | Collects error, info and issue messages (typically related to a handle). |
MLErrorCode ml::MultiFileVolumeList::setFromString | ( | const std::string & | state, |
const std::string & | cacheDirPath, | ||
ProgressCB | progressCB = nullptr , |
||
void * | userData = nullptr , |
||
const float | startPercentage = 0.0f , |
||
const float | percentageRange = 1.0f , |
||
std::list< std::string > * | cacheFileList = nullptr , |
||
DicomMessageCollector * | dcmMsgCollector = nullptr |
||
) |
Reads the state of this from the string state; returns ML_RESULT_OK on successful load and false on failure.
On other return codes the state of this remains undefined. The content of the string state is reduced by the loaded volumes.
state | The string from which the data is read. |
cacheDirPath | The directory path where the cache file is located which contains state. |
progressCB | An optional static function pointer which is then called by this function to notify the progress while this function is executed (as described in percentageRange). |
userData | a pointer with user data passed to progressCB. It for example can be used to pass the calling instance object which is updated. |
startPercentage | is the percentage value of a progress bar which is updated when this function starts (for example to 0.3). |
percentageRange | is the range incrementally stepped through while this method is executed, for example 0.5. The progress then is increased incrementally from percentageStart to percentageStart+percentageRange, thus from 0.3 to 0.8 by a number of steps whose number is determined inside of the function. |
cacheFileList | If passed nullptr then it is ignored, otherwise it will be filled with the names of all cache files belonging to this stored cache. |
dcmMsgCollector | If passed non-nullptr then it collects error, info and issue messages (typically related to a handle). |
void ml::MultiFileVolumeList::setUpIssues | ( | const DicomMessageCollector * | dcmMsgCollector = nullptr | ) |
Sets up the 'issues' members of all volumes; see MultiFileVolume::setUpIssues() for details.
void ml::MultiFileVolumeList::sortVolumes | ( | MultiFileVolumeListSort::SortModes | sortMode, |
bool | sortUpwards, | ||
MLint | rawTagId, | ||
bool | useNumericTagStringValueSorting | ||
) |
Sorts the volume list according the given sort criteria sortMode; see MultiFileVolumeListSort for details.
MLErrorCode ml::MultiFileVolumeList::writeResultCache | ( | const std::string & | fileNameInput, |
const std::string & | cachePathInput, | ||
const bool | useRelativePaths, | ||
const bool | writeSingleVolumeCaches, | ||
ProgressLogger * | progressLogger | ||
) | const |
Writes all information into the cache file in the cache file directory.
Return ML_RESULT_OK on success, otherwise an error code describing the problem.
fileNameInput | the file name as it comes from the module input field. |
cachePathInput | the cache path as it comes from the module input field. |
useRelativePaths | If true the relative paths are stored in cache files, otherwise absolute paths. |
writeSingleVolumeCaches | If false one big cache file is written for all volume references, otherwise one for each one. |
progressLogger | If non nullptr then message are sent to this logger, otherwise it is ignored and messages are not logged. |