00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
#ifndef __DVPSIB_H__
00035
#define __DVPSIB_H__
00036
00037
#include "osconfig.h"
00038
#include "ofstring.h"
00039
#include "dctk.h"
00040
#include "dvpstyp.h"
00041
#include "dimse.h"
00042
00043
class DVPSPresentationLUT_PList;
00044
class DVConfiguration;
00045
00049 class DVPSImageBoxContent
00050 {
00051
public:
00053
DVPSImageBoxContent();
00054
00056
DVPSImageBoxContent(
const DVPSImageBoxContent& copy);
00057
00062 DVPSImageBoxContent *
clone() {
return new DVPSImageBoxContent(*
this); }
00063
00065
virtual ~DVPSImageBoxContent();
00066
00071
void clear();
00072
00083
OFCondition read(
DcmItem &dset,
DVPSPresentationLUT_PList& presentationLUTList);
00084
00095
OFCondition write(
DcmItem &dset, OFBool writeRequestedImageSize, OFBool writeReferencedPLUTSQ = OFTrue);
00096
00104
OFCondition createDefaultValues(OFBool renumber,
unsigned long number, OFBool ignoreEmptyImages);
00105
00109
const char *
getSOPClassUID();
00110
00123
OFCondition setContent(
00124
const char *instanceuid,
00125
const char *retrieveaetitle,
00126
const char *refstudyuid,
00127
const char *refseriesuid,
00128
const char *refsopclassuid,
00129
const char *refsopinstanceuid,
00130
const char *requestedimagesize,
00131
const char *patientid,
00132
const char *presentationlutreference);
00133
00140
OFCondition setRequestedDecimateCropBehaviour(DVPSDecimateCropBehaviour value);
00141
00146 DVPSDecimateCropBehaviour
getRequestedDecimateCropBehaviour();
00147
00152 OFBool
hasAdditionalSettings();
00153
00157
const char *
getReferencedPresentationLUTInstanceUID();
00158
00162
const char *
getPolarity();
00163
00167
const char *
getRequestedImageSize();
00168
00172
const char *
getMagnificationType();
00173
00177
const char *
getSmoothingType();
00178
00182
const char *
getConfigurationInformation();
00183
00187
const char *
getSOPInstanceUID();
00188
00192 Uint16
getImageBoxPosition();
00193
00198
OFCondition setPolarity(
const char *value);
00199
00204
OFCondition setRequestedImageSize(
const char *value);
00205
00212
OFCondition setMagnificationType(
const char *value);
00213
00220
OFCondition setSmoothingType(
const char *value);
00221
00228
OFCondition setConfigurationInformation(
const char *value);
00229
00234
OFCondition setSOPInstanceUID(
const char *value);
00235
00239
OFCondition setDefault();
00240
00247
OFCondition getImageReference(
const char *&studyUID,
const char *&seriesUID,
const char *&instanceUID);
00248
00256
OFCondition prepareBasicImageBox(
DcmItem &dset);
00257
00263
void setLog(
OFConsole *stream, OFBool verbMode, OFBool dbgMode);
00264
00271 OFBool
matchesPresentationLUT(DVPSPrintPresentationLUTAlignment align)
const;
00272
00293 OFBool
printSCPSet(
00294
DVConfiguration& cfg,
00295
const char *cfgname,
00296
DcmDataset *rqDataset,
00297 T_DIMSE_Message& rsp,
00298
DcmDataset *& rspDataset,
00299
DcmDataset &imageDataset,
00300 DVPSPrintPresentationLUTAlignment align,
00301 OFBool presentationLUTnegotiated);
00302
00310
OFCondition setUIDsAndAETitle(
00311
DcmUniqueIdentifier& studyUID,
00312
DcmUniqueIdentifier& seriesUID,
00313
const char *aetitle);
00314
00315
private:
00317
DVPSImageBoxContent&
operator=(
const DVPSImageBoxContent&);
00318
00324
OFCondition addReferencedPLUTSQ(
DcmItem &dset);
00325
00345 OFBool
printSCPEvaluateBasicGrayscaleImageSequence(
00346
DVConfiguration& cfg,
00347
const char *cfgname,
00348
DcmItem *rqDataset,
00349 T_DIMSE_Message& rsp,
00350
DcmDataset &imageDataset,
00351 DVPSPrintPresentationLUTAlignment align,
00352 OFBool presentationLUTnegotiated);
00353
00355 DcmUniqueIdentifier sOPInstanceUID;
00357 DcmUnsignedShort imageBoxPosition;
00359 DcmCodeString polarity;
00361 DcmCodeString magnificationType;
00363 DcmShortText configurationInformation;
00365 DcmCodeString smoothingType;
00367 DcmDecimalString requestedImageSize;
00369 DcmCodeString requestedDecimateCropBehavior;
00370
00371
00372
00373
00375 DcmApplicationEntity retrieveAETitle;
00377 DcmUniqueIdentifier referencedSOPClassUID;
00379 DcmUniqueIdentifier referencedSOPInstanceUID;
00381 DcmUniqueIdentifier studyInstanceUID;
00383 DcmUniqueIdentifier seriesInstanceUID;
00385 DcmIntegerString referencedFrameNumber;
00387 DcmLongString patientID;
00388
00389
00390
00391
00392
DcmUniqueIdentifier referencedPresentationLUTInstanceUID;
00393
00395 DVPSImageDepth
imageDepth;
00396
00399 OFConsole *
logstream;
00400
00403 OFBool
verboseMode;
00404
00407 OFBool
debugMode;
00408
00409 };
00410
00411
#endif
00412
00413
00414
00415
00416
00417
00418
00419
00420
00421
00422
00423
00424
00425
00426
00427
00428
00429
00430
00431
00432
00433
00434
00435
00436
00437
00438
00439
00440
00441
00442
00443
00444
00445
00446
00447
00448
00449
00450
00451
00452
00453
00454
00455
00456
00457
00458
00459
00460
00461
00462
00463
00464
00465
00466
00467
00468
00469
00470
00471
00472
00473
00474
00475
00476
00477
00478
00479
00480
00481
00482
00483