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 "dcmtk/config/osconfig.h"
00038 #include "dcmtk/ofstd/ofstring.h"
00039 #include "dcmtk/dcmdata/dctk.h"
00040 #include "dcmtk/dcmpstat/dvpstyp.h"
00041 #include "dcmtk/dcmnet/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
00484
00485
00486