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
|
/*
*
* 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 Plan objects
*
*/
#include "dcmtk/config/osconfig.h" /* make sure OS specific configuration is included first */
#include "dcmtk/dcmrt/drmplan.h"
#include "dcmtk/dcmrt/drmsrch.h"
OFCondition DRTPlan::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;
}
DRTFractionGroupSequence::Item& DRTPlan::getFractionGroup(Sint32 fractionGroupNumber)
{
// First some typedefs to make the following more readable
typedef DRTFractionGroupSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getFractionGroupSequence(), fractionGroupNumber,
&seq::Item::getFractionGroupNumber);
}
DRTBeamSequence::Item& DRTPlan::getBeam(Sint32 beamNumber)
{
// First some typedefs to make the following more readable
typedef DRTBeamSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getBeamSequence(), beamNumber,
&seq::Item::getBeamNumber);
}
DRTDoseReferenceSequence::Item& DRTPlan::getDoseReference(Sint32 referenceNumber)
{
// First some typedefs to make the following more readable
typedef DRTDoseReferenceSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getDoseReferenceSequence(), referenceNumber,
&seq::Item::getDoseReferenceNumber);
}
DRTToleranceTableSequence::Item& DRTPlan::getToleranceTable(Sint32 tableNumber)
{
// First some typedefs to make the following more readable
typedef DRTToleranceTableSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getToleranceTableSequence(), tableNumber,
&seq::Item::getToleranceTableNumber);
}
DRTPatientSetupSequence::Item& DRTPlan::getPatientSetup(Sint32 setupNumber)
{
// First some typedefs to make the following more readable
typedef DRTPatientSetupSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getPatientSetupSequence(), setupNumber,
&seq::Item::getPatientSetupNumber);
}
DRTApplicationSetupSequence::Item& DRTPlan::getApplicationSetup(Sint32 setupNumber)
{
// First some typedefs to make the following more readable
typedef DRTApplicationSetupSequence seq;
typedef DRTSearch::searchPropertyEqualHelper<seq, seq::Item, Sint32, const unsigned long, 0> helper;
return helper::search(getApplicationSetupSequence(), setupNumber,
&seq::Item::getApplicationSetupNumber);
}
|