DYT/Tool/3rdParty_x64/include/dcmtk/dcmpstat/dvpsibl.h

389 lines
16 KiB
C
Raw Normal View History

2024-11-22 15:19:31 +00:00
/*
*
* Copyright (C) 1998-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: dcmpstat
*
* Author: Marco Eichelberg
*
* Purpose:
* classes: DVPSImageBoxContent_PList
*
*/
#ifndef DVPSIBL_H
#define DVPSIBL_H
#include "dcmtk/config/osconfig.h" /* make sure OS specific configuration is included first */
#include "dcmtk/dcmpstat/dvpstyp.h" /* for enum types */
#include "dcmtk/dcmpstat/dpdefine.h"
#include "dcmtk/dcmdata/dcitem.h"
#include "dcmtk/dcmdata/dcvrui.h"
class DVPSImageBoxContent;
class DVPSPresentationLUT_PList;
/** the list of Image Boxes contained in a stored print object.
* This class manages the data structures comprising one complete
* Image Box Content Sequence in a Stored Print object.
*/
class DCMTK_DCMPSTAT_EXPORT DVPSImageBoxContent_PList
{
public:
/// default constructor
DVPSImageBoxContent_PList();
/// copy constructor
DVPSImageBoxContent_PList(const DVPSImageBoxContent_PList& copy);
/** clone method.
* @return a pointer to a new DVPSImageBoxContent_PList object containing
* a deep copy of this object.
*/
DVPSImageBoxContent_PList *clone() { return new DVPSImageBoxContent_PList(*this); }
/// destructor
virtual ~DVPSImageBoxContent_PList();
/** reads a list of image boxes (ImageBoxContentSequence) from a DICOM dataset.
* The DICOM elements of the image boxes are copied from the dataset to this object.
* The completeness of all items (presence of all required elements,
* value multiplicity) is checked.
* If this method returns an error code, the object is in undefined state afterwards.
* @param dset the DICOM dataset from which the sequence is to be read
* @param presentationLUTList list of presentation LUTs which may be referenced
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition read(DcmItem &dset, DVPSPresentationLUT_PList& presentationLUTList);
/** writes the list of image boxes managed by this object to a DICOM dataset.
* Copies of the DICOM element managed by this object are inserted into
* the DICOM dataset.
* @param dset the DICOM dataset to which the ImageBoxContentSequence is written
* @param writeRequestedImageSize if false, the Requested Image Size attributes are not written,
* e.g. because they are not supported by the target printer.
* @param numItems the number of items (from the beginning of the list) to be written.
* Default: all items are written.
* @param ignoreEmptyImages if true, all image boxes without image box position are ignored
* when writing.
* @param writeReferencedPLUTSQ if false, the Referenced Presentation LUT Sequence is not written,
* e.g. because a "general" presentation LUT is used instead of those referenced by the image boxes.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition write(
DcmItem &dset,
OFBool writeRequestedImageSize,
size_t numItems,
OFBool ignoreEmptyImages,
OFBool writeReferencedPLUTSQ = OFTrue);
/** reset the object to initial state.
* After this call, the object is in the same state as after
* creation with the default constructor.
*/
void clear();
/** gets the number of image boxes in this list.
* @return the number of image boxes.
*/
size_t size() const { return list_.size(); }
/** create default values for all missing type 1 elements.
* Called before a stored print object is written.
* @param renumber if true, new imageBoxPosition values are created
* @param ignoreEmptyImages if true, an empty image box position does not cause an error.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition createDefaultValues(OFBool renumber, OFBool ignoreEmptyImages);
/** adds all image SOP classes referenced in the image box list to
* the given sequence. Duplicate entries are suppressed.
* @param seq sequence to be added to, should be a PrintManagementCapabilitiesSequence.
* @param numItems number of items of this list to be taken into account.
* Default: all items.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition addImageSOPClasses(DcmSequenceOfItems& seq, size_t numItems=0);
/** creates a new image box object and sets the content of this image box object.
* @param instanceuid SOP instance UID of this image box
* @param retrieveaetitle retrieve AETITLE of the referenced image
* @param refstudyuid study instance UID of the referenced image
* @param refseriesuid series instance UID of the referenced image
* @param refsopclassuid SOP class UID of the referenced image
* @param refsopinstanceuid SOP instance UID of the referenced image
* @param requestedimagesize requested images size for this image, default: absent
* @param patientid patient ID for the referenced image, default: absent
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition addImageBox(
const char *instanceuid,
const char *retrieveaetitle,
const char *refstudyuid,
const char *refseriesuid,
const char *refsopclassuid,
const char *refsopinstanceuid,
const char *requestedimagesize,
const char *patientid,
const char *presentationlutuid);
/** adds the given image box object to the list managed by this object.
* @param box image box object to be added.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition addImageBox(DVPSImageBoxContent *box);
/** sets the (optional) requested decimate/crop behaviour
* for all image boxes managed by this object.
* @param value new enumerated value. The caller is responsible for
* making sure that the selected printer supports decimate/crop
* if a non-default value is set.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setRequestedDecimateCropBehaviour(DVPSDecimateCropBehaviour value);
/** deletes one of the registered images.
* @param idx index, must be < size()
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition deleteImage(size_t idx);
/** deletes multiple of the registered images, starting with the first one.
* @param number number of images to delete, must be <= size()
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition deleteMultipleImages(size_t number);
/** checks if one of the registered images has additional settings that are not
* default values on the image box level.
* @param idx index, must be < getNumberOfImages()
* @return EC_Normal if successful, an error code otherwise.
*/
OFBool imageHasAdditionalSettings(size_t idx);
/** sets the polarity for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @param value new attribute value (NORMAL or REVERSE), may be NULL.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setImagePolarity(size_t idx, const char *value);
/** sets the requested size for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @param value new attribute value, may be NULL.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setImageRequestedSize(size_t idx, const char *value);
/** sets the (optional) magnification type for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @param value new attribute value, may be NULL.
* The caller is responsible for making sure
* that the value is valid for the selected printer.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setImageMagnificationType(size_t idx, const char *value);
/** sets the (optional) smoothing type for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @param value new attribute value, may be NULL.
* The caller is responsible for making sure
* that the value is valid for the selected printer.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setImageSmoothingType(size_t idx, const char *value);
/** sets the (optional) configuration information for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @param value new attribute value, may be NULL.
* The caller is responsible for making sure
* that the value is valid for the selected printer.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setImageConfigurationInformation(size_t idx, const char *value);
/** sets the SOP instance UID for the given image box.
* @param idx index, must be < getNumberOfImages()
* @param value new attribute value, must not be NULL.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setImageSOPInstanceUID(size_t idx, const char *value);
/** sets magnification type, smoothing type and configuration information back to default
* for all registered images.
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition setAllImagesToDefault();
/** gets the polarity for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @return polarity, may be NULL.
*/
const char *getImagePolarity(size_t idx);
/** gets the requested size for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @return requested size, may be NULL.
*/
const char *getImageRequestedSize(size_t idx);
/** gets the (optional) magnification type for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @return magnification type, may be NULL.
*/
const char *getImageMagnificationType(size_t idx);
/** gets the (optional) smoothing type for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @return smoothing type, may be NULL.
*/
const char *getImageSmoothingType(size_t idx);
/** gets the (optional) configuration information for the given registered image box.
* @param idx index, must be < getNumberOfImages()
* @return configuration information, may be NULL.
*/
const char *getImageConfigurationInformation(size_t idx);
/** gets the current SOP Instance UID for the given registered image box..
* @param idx index, must be < getNumberOfImages()
* @return SOP Instance UID, may be NULL.
*/
const char *getSOPInstanceUID(size_t idx);
/** gets the referenced Presentation LUT SOP Instance UID for the given registered image box..
* @param idx index, must be < getNumberOfImages()
* @return SOP Instance UID, may be NULL.
*/
const char *getReferencedPresentationLUTInstanceUID(size_t idx);
/** returns the image UIDs that are required to look up the referenced image in the database
* @param idx index, must be < getNumberOfImages()
* @param studyUID Study UID of the image
* @param seriesUID series UID of the image
* @param instanceUID instance UID of the image
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition getImageReference(size_t idx, const char *&studyUID, const char *&seriesUID, const char *&instanceUID);
/** writes the attributes managed by the referenced object that are part of a
* basic grayscale image box N-SET request into the DICOM dataset.
* Copies of the DICOM element managed by this object are inserted into
* the DICOM dataset.
* @param idx index, must be < getNumberOfImages()
* @param dset the dataset to which the data is written
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition prepareBasicImageBox(size_t idx, DcmItem &dset);
/** checks whether the given SOP instance UID is used as
* referenced Presentation LUT SOP Instance UID inside the list of
* image boxes managed by this object.
* @param uid name of UID
* @return OFTrue if UID is used, OFFalse otherwise.
*/
OFBool presentationLUTInstanceUIDisUsed(const char *uid);
/** if only one Presentation LUT is required to render all images
* managed by this object, returns the UID of this presentation LUT.
* Otherwise returns NULL.
* @param filmBox UID of Presentation LUT specified on Film Box
* level. May be NULL or empty string if absent.
* @return UID of Presentation LUT if found, NULL or empty string otherwise.
*/
const char *haveSinglePresentationLUTUsed(const char *filmBox);
/** creates a number of image boxes as part of a Print SCP N-CREATE operation.
* The previous content of the list is deleted.
* @param numBoxes number of boxes to be created
* @param studyUID study instance UID under which Hardcopy Grayscale images will be saved
* @param seriesUID series instance UID under which Hardcopy Grayscale images will be saved
* @param aetitle retrieve AE title for Hardcopy Grayscale images
* @return OFTrue if successful, OFFalse otherwise.
*/
OFBool printSCPCreate(
unsigned long numBoxes,
DcmUniqueIdentifier& studyUID,
DcmUniqueIdentifier& seriesUID,
const char *aetitle);
/** writes a Referenced Image Box Sequence for the image boxes
* managed by this object. Used in a Print SCP N-CREATE operation.
* @param dset the dataset to which the data is written
* @return EC_Normal if successful, an error code otherwise.
*/
OFCondition writeReferencedImageBoxSQ(DcmItem &dset);
/** checks whether the given Presentation LUT type could be used together
* with all image boxes in this list on a Print SCP that requires a matching
* alignment between a Presentation LUT and the image pixel data.
* @param align LUT alignment type
* @return OFTrue if matching, OFFalse otherwise
*/
OFBool matchesPresentationLUT(DVPSPrintPresentationLUTAlignment align) const;
/** looks up the image box with the given SOP instance UID in this list
* and returns a pointer to a new object containing a copy of this
* image box. If the object is not found, NULL is returned.
* @param uid SOP instance UID of the image box to be looked up
* @return pointer to copied image box object, may be NULL.
*/
DVPSImageBoxContent *duplicateImageBox(const char *uid);
/** checks whether any of the image boxes managed by this list
* has the same position as the given one, but a different
* SOP instance UID. This is used during an Print SCP N-SET operation
* to check whether a position clash exists.
* @param uid SOP instance UID of the image box to be looked up
* @param position image position to be looked up
*/
OFBool haveImagePositionClash(const char *uid, Uint16 position);
/** adds the given image box object to this list. Any other object existing
* in the list with the same SOP instance UID is removed.
* Used during a Print SCP image box N-SET operation.
* @param newImageBox new image box object to be added to the list.
*/
void replace(DVPSImageBoxContent *newImageBox);
/** checks whether any of the image boxes has an image box position
* assigned. If no image box position is assigned, the object list
* cannot be written and a Print SCP should return a warning
* status upon receipt of an N-ACTION request.
* @return OFTrue if empty page (no image box position assigned), OFFalse otherwise.
*/
OFBool emptyPageWarning();
private:
/** private undefined assignment operator
*/
DVPSImageBoxContent_PList& operator=(const DVPSImageBoxContent_PList&);
/** returns a pointer to the image box with the given
* index or NULL if it does not exist.
* @param idx index, must be < size()
* @return pointer to image box object or NULL
*/
DVPSImageBoxContent *getImageBox(size_t idx);
/** the list maintained by this object
*/
OFList<DVPSImageBoxContent *> list_;
};
#endif