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 #ifndef DVPSIBL_H
00031 #define DVPSIBL_H
00032
00033 #include "dcmtk/config/osconfig.h"
00034 #include "dcmtk/dcmdata/dcitem.h"
00035 #include "dcmtk/dcmpstat/dvpstyp.h"
00036 #include "dcmtk/dcmdata/dcvrui.h"
00037
00038 class DVPSImageBoxContent;
00039 class DVPSPresentationLUT_PList;
00040
00046 class DVPSImageBoxContent_PList
00047 {
00048 public:
00049
00051 DVPSImageBoxContent_PList();
00052
00054 DVPSImageBoxContent_PList(const DVPSImageBoxContent_PList& copy);
00055
00060 DVPSImageBoxContent_PList *clone() { return new DVPSImageBoxContent_PList(*this); }
00061
00063 virtual ~DVPSImageBoxContent_PList();
00064
00074 OFCondition read(DcmItem &dset, DVPSPresentationLUT_PList& presentationLUTList);
00075
00090 OFCondition write(
00091 DcmItem &dset,
00092 OFBool writeRequestedImageSize,
00093 size_t numItems,
00094 OFBool ignoreEmptyImages,
00095 OFBool writeReferencedPLUTSQ = OFTrue);
00096
00101 void clear();
00102
00106 size_t size() const { return list_.size(); }
00107
00114 OFCondition createDefaultValues(OFBool renumber, OFBool ignoreEmptyImages);
00115
00123 OFCondition addImageSOPClasses(DcmSequenceOfItems& seq, size_t numItems=0);
00124
00136 OFCondition addImageBox(
00137 const char *instanceuid,
00138 const char *retrieveaetitle,
00139 const char *refstudyuid,
00140 const char *refseriesuid,
00141 const char *refsopclassuid,
00142 const char *refsopinstanceuid,
00143 const char *requestedimagesize,
00144 const char *patientid,
00145 const char *presentationlutuid);
00146
00151 OFCondition addImageBox(DVPSImageBoxContent *box);
00152
00160 OFCondition setRequestedDecimateCropBehaviour(DVPSDecimateCropBehaviour value);
00161
00166 OFCondition deleteImage(size_t idx);
00167
00172 OFCondition deleteMultipleImages(size_t number);
00173
00179 OFBool imageHasAdditionalSettings(size_t idx);
00180
00186 OFCondition setImagePolarity(size_t idx, const char *value);
00187
00193 OFCondition setImageRequestedSize(size_t idx, const char *value);
00194
00202 OFCondition setImageMagnificationType(size_t idx, const char *value);
00203
00211 OFCondition setImageSmoothingType(size_t idx, const char *value);
00212
00220 OFCondition setImageConfigurationInformation(size_t idx, const char *value);
00221
00227 OFCondition setImageSOPInstanceUID(size_t idx, const char *value);
00228
00233 OFCondition setAllImagesToDefault();
00234
00239 const char *getImagePolarity(size_t idx);
00240
00245 const char *getImageRequestedSize(size_t idx);
00246
00251 const char *getImageMagnificationType(size_t idx);
00252
00257 const char *getImageSmoothingType(size_t idx);
00258
00263 const char *getImageConfigurationInformation(size_t idx);
00264
00269 const char *getSOPInstanceUID(size_t idx);
00270
00275 const char *getReferencedPresentationLUTInstanceUID(size_t idx);
00276
00284 OFCondition getImageReference(size_t idx, const char *&studyUID, const char *&seriesUID, const char *&instanceUID);
00285
00294 OFCondition prepareBasicImageBox(size_t idx, DcmItem &dset);
00295
00302 OFBool presentationLUTInstanceUIDisUsed(const char *uid);
00303
00311 const char *haveSinglePresentationLUTUsed(const char *filmBox);
00312
00321 OFBool printSCPCreate(
00322 unsigned long numBoxes,
00323 DcmUniqueIdentifier& studyUID,
00324 DcmUniqueIdentifier& seriesUID,
00325 const char *aetitle);
00326
00332 OFCondition writeReferencedImageBoxSQ(DcmItem &dset);
00333
00340 OFBool matchesPresentationLUT(DVPSPrintPresentationLUTAlignment align) const;
00341
00348 DVPSImageBoxContent *duplicateImageBox(const char *uid);
00349
00357 OFBool haveImagePositionClash(const char *uid, Uint16 position);
00358
00364 void replace(DVPSImageBoxContent *newImageBox);
00365
00372 OFBool emptyPageWarning();
00373
00374 private:
00375
00378 DVPSImageBoxContent_PList& operator=(const DVPSImageBoxContent_PList&);
00379
00385 DVPSImageBoxContent *getImageBox(size_t idx);
00386
00389 OFList<DVPSImageBoxContent *> list_;
00390
00391 };
00392
00393
00394 #endif
00395
00396
00397
00398
00399
00400
00401
00402
00403
00404
00405
00406
00407
00408
00409
00410
00411
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
00487
00488
00489
00490
00491