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
|
/*
*
* Copyright (C) 2012, OFFIS e.V.
* All rights reserved. See COPYRIGHT file for details.
*
* This software and supporting documentation were developed by
*
* OFFIS e.V.
* R&D Division Health
* Escherweg 2
* D-26121 Oldenburg, Germany
*
*
* Module: dcmrt
*
* Author: Uli Schlachter
*
* Purpose: Mid-Level API for RT Structure Set objects
*
*/
#include "dcmtk/config/osconfig.h" /* make sure OS specific configuration is included first */
#include "dcmtk/dcmrt/drmstrct.h"
#include "dcmtk/dcmrt/drmsrch.h"
OFCondition DRTStructureSet::loadFile(const OFFilename &filename,
const E_FileReadMode readMode,
const E_TransferSyntax readXfer)
{
DcmFileFormat format;
OFCondition cond = format.loadFile(filename, readXfer, EGL_noChange,
DCM_MaxReadLength, readMode);
if (cond.good())
cond = read(*format.getDataset());
return cond;
}
DRTReferencedFrameOfReferenceSequence::Item& DRTStructureSet::getFrameOfReference(const OFString& uid)
{
// First some typedefs to make the following more readable
typedef DRTReferencedFrameOfReferenceSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, OFString, const long, 0> helper;
return helper::search(getReferencedFrameOfReferenceSequence(), uid,
&seq::Item::getFrameOfReferenceUID);
}
DRTStructureSetROISequence::Item& DRTStructureSet::getROI(Sint32 roiNumber)
{
// First some typedefs to make the following more readable
typedef DRTStructureSetROISequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getStructureSetROISequence(), roiNumber,
&seq::Item::getROINumber);
}
DRTRTROIObservationsSequence::Item& DRTStructureSet::getObservation(Sint32 observationNumber)
{
// First some typedefs to make the following more readable
typedef DRTRTROIObservationsSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getRTROIObservationsSequence(), observationNumber,
&seq::Item::getObservationNumber);
}
DRTRTROIObservationsSequence::Item& DRTStructureSet::getObservationByROINumber(Sint32 roiNumber)
{
// First some typedefs to make the following more readable
typedef DRTRTROIObservationsSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getRTROIObservationsSequence(), roiNumber,
&seq::Item::getReferencedROINumber);
}
OFCondition DRTStructureSet::getContoursForROINumber(OFVector<DRTROIContourSequence::Item*> result, Sint32 roiNumber)
{
DRTROIContourSequence& seq = getROIContourSequence();
OFCondition cond = seq.gotoFirstItem();
// tbd: This method could easily be turned into a template if needed,
// to avoid code duplication
// Go through all items in the sequence...
result.clear();
while (cond.good()) {
Sint32 number;
DRTROIContourSequence::Item& item = seq.getCurrentItem();
cond = item.getReferencedROINumber(number);
if (cond.bad())
return cond;
// ...looking for items with the wanted roiNumber
if (number == roiNumber)
result.push_back(&item);
cond = seq.gotoNextItem();
}
return EC_Normal;
}
OFCondition DRTStructureSet::getContoursForROINumber(OFList<DRTROIContourSequence::Item*> result, Sint32 roiNumber)
{
DRTROIContourSequence& seq = getROIContourSequence();
OFCondition cond = seq.gotoFirstItem();
// tbd: This method could easily be turned into a template if needed,
// to avoid code duplication
// Go through all items in the sequence...
result.clear();
while (cond.good()) {
Sint32 number;
DRTROIContourSequence::Item& item = seq.getCurrentItem();
cond = item.getReferencedROINumber(number);
if (cond.bad())
return cond;
// ...looking for items with the wanted roiNumber
if (number == roiNumber)
result.push_back(&item);
cond = seq.gotoNextItem();
}
return EC_Normal;
}
|