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 DVPSSPL_H
00031 #define DVPSSPL_H
00032
00033 #include "dcmtk/config/osconfig.h"
00034 #include "dcmtk/ofstd/oflist.h"
00035 #include "dcmtk/dcmdata/dcvrus.h"
00036 #include "dcmtk/dcmdata/dcvrui.h"
00037 #include "dcmtk/dcmnet/dimse.h"
00038 #include "dcmtk/dcmpstat/dvpstyp.h"
00039
00040 class DVInterface;
00041 class DVPSStoredPrint;
00042 class DVConfiguration;
00043 class DVPSPresentationLUT_PList;
00044
00048 class DVPSStoredPrint_PList
00049 {
00050 public:
00052 DVPSStoredPrint_PList();
00053
00055 DVPSStoredPrint_PList(const DVPSStoredPrint_PList& copy);
00056
00061 DVPSStoredPrint_PList *clone() { return new DVPSStoredPrint_PList(*this); }
00062
00064 virtual ~DVPSStoredPrint_PList();
00065
00070 void clear();
00071
00075 size_t size() const { return list_.size(); }
00076
00082 void insert(DVPSStoredPrint *newSP) { if (newSP) list_.push_back(newSP); }
00083
00099 void printSCPBasicFilmBoxSet(
00100 DVConfiguration& cfg,
00101 const char *cfgname,
00102 T_DIMSE_Message& rq,
00103 DcmDataset *rqDataset,
00104 T_DIMSE_Message& rsp,
00105 DcmDataset *& rspDataset,
00106 OFBool presentationLUTnegotiated,
00107 DVPSPresentationLUT_PList& globalPresentationLUTList);
00108
00124 void printSCPBasicGrayscaleImageBoxSet(
00125 DVInterface& cfg,
00126 const char *cfgname,
00127 T_DIMSE_Message& rq,
00128 DcmDataset *rqDataset,
00129 T_DIMSE_Message& rsp,
00130 DcmDataset *& rspDataset,
00131 OFBool presentationLUTnegotiated);
00132
00144 void printSCPBasicFilmBoxAction(
00145 DVInterface& cfg,
00146 const char *cfgname,
00147 T_DIMSE_Message& rq,
00148 T_DIMSE_Message& rsp,
00149 DVPSPresentationLUT_PList& globalPresentationLUTList);
00150
00161 void printSCPBasicFilmSessionAction(
00162 DVInterface& cfg,
00163 const char *cfgname,
00164 T_DIMSE_Message& rsp,
00165 DVPSPresentationLUT_PList& globalPresentationLUTList);
00166
00172 void printSCPBasicFilmBoxDelete(T_DIMSE_Message& rq, T_DIMSE_Message& rsp);
00173
00179 OFBool haveFilmBoxInstance(const char *uid);
00180
00187 OFBool usesPresentationLUT(const char *uid);
00188
00195 OFBool matchesPresentationLUT(DVPSPrintPresentationLUTAlignment align) const;
00196
00206 void overridePresentationLUTSettings(
00207 DcmUnsignedShort& newIllumination,
00208 DcmUnsignedShort& newReflectedAmbientLight,
00209 DcmUniqueIdentifier& newReferencedPLUT,
00210 DVPSPrintPresentationLUTAlignment newAlignment);
00211
00212 private:
00213
00215 DVPSStoredPrint_PList& operator=(const DVPSStoredPrint_PList&);
00216
00219 OFList<DVPSStoredPrint *> list_;
00220 };
00221
00222 #endif
00223
00224
00225
00226
00227
00228
00229
00230
00231
00232
00233
00234
00235
00236
00237
00238
00239
00240
00241
00242
00243
00244
00245
00246
00247
00248
00249
00250
00251
00252
00253
00254
00255
00256
00257
00258
00259
00260
00261
00262