GDCM 3.0.24
gdcmPresentationContextRQ.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: GDCM (Grassroots DICOM). A DICOM library
4
5 Copyright (c) 2006-2011 Mathieu Malaterre
6 All rights reserved.
7 See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details.
8
9 This software is distributed WITHOUT ANY WARRANTY; without even
10 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11 PURPOSE. See the above copyright notice for more information.
12
13=========================================================================*/
14#ifndef GDCMPRESENTATIONCONTEXTRQ_H
15#define GDCMPRESENTATIONCONTEXTRQ_H
16
17#include "gdcmTypes.h"
18#include "gdcmAbstractSyntax.h"
20#include "gdcmDataSet.h"
21
22namespace gdcm
23{
24class PresentationContext;
25namespace network
26{
27
35{
36public:
38
43 UIDs::ImplicitVRLittleEndianDefaultTransferSyntaxforDICOM );
44
45 std::istream &Read(std::istream &is);
46 const std::ostream &Write(std::ostream &os) const;
47 size_t Size() const;
48
49 void SetAbstractSyntax( AbstractSyntax const & absyn );
50 AbstractSyntax const &GetAbstractSyntax() const { return SubItems; }
51 AbstractSyntax &GetAbstractSyntax() { return SubItems; }
52
54 typedef std::vector<TransferSyntaxSub>::size_type SizeType;
55 TransferSyntaxSub const & GetTransferSyntax(SizeType i) const { return TransferSyntaxes[i]; }
56 TransferSyntaxSub & GetTransferSyntax(SizeType i) { return TransferSyntaxes[i]; }
57 std::vector<TransferSyntaxSub> const & GetTransferSyntaxes() const {return TransferSyntaxes; }
58 SizeType GetNumberOfTransferSyntaxes() const { return TransferSyntaxes.size(); }
59
60 void SetPresentationContextID( uint8_t id );
61 uint8_t GetPresentationContextID() const;
62
63 void Print(std::ostream &os) const;
64
65 bool operator==(const PresentationContextRQ & pc) const
66 {
67 assert( TransferSyntaxes.size() == 1 ); // TODO
68 assert( pc.TransferSyntaxes.size() == 1 );
69 return SubItems == pc.SubItems && TransferSyntaxes == pc.TransferSyntaxes;
70 }
71
73
74private:
75 static const uint8_t ItemType;
76 static const uint8_t Reserved2;
77 uint16_t ItemLength; // len of last transfer syntax
78 uint8_t /*PresentationContext*/ID;
79 static const uint8_t Reserved6;
80 static const uint8_t Reserved7;
81 static const uint8_t Reserved8;
82 /*
83 This variable field shall contain the following sub-items: one Abstract
84 Syntax and one or more Transfer Syntax(es). For a complete
85 description of the use and encoding of these sub-items see Sections
86 9.3.2.2.1 and 9.3.2.2.2.
87 */
88 AbstractSyntax SubItems;
89 std::vector<TransferSyntaxSub> TransferSyntaxes;
90};
91
92} // end namespace network
93
94} // end namespace gdcm
95
96#endif //GDCMPRESENTATIONCONTEXTRQ_H
PresentationContext.
Definition gdcmPresentationContext.h:30
TSName
Definition gdcmUIDs.h:501
AbstractSyntax.
Definition gdcmAbstractSyntax.h:33
PresentationContextRQ.
Definition gdcmPresentationContextRQ.h:35
AbstractSyntax const & GetAbstractSyntax() const
Definition gdcmPresentationContextRQ.h:50
TransferSyntaxSub const & GetTransferSyntax(SizeType i) const
Definition gdcmPresentationContextRQ.h:55
PresentationContextRQ(UIDs::TSName asname, UIDs::TSName tsname=UIDs::ImplicitVRLittleEndianDefaultTransferSyntaxforDICOM)
void SetAbstractSyntax(AbstractSyntax const &absyn)
std::istream & Read(std::istream &is)
AbstractSyntax & GetAbstractSyntax()
Definition gdcmPresentationContextRQ.h:51
PresentationContextRQ(const PresentationContext &pc)
std::vector< TransferSyntaxSub > const & GetTransferSyntaxes() const
Definition gdcmPresentationContextRQ.h:57
TransferSyntaxSub & GetTransferSyntax(SizeType i)
Definition gdcmPresentationContextRQ.h:56
void AddTransferSyntax(TransferSyntaxSub const &ts)
std::vector< TransferSyntaxSub >::size_type SizeType
Definition gdcmPresentationContextRQ.h:54
void Print(std::ostream &os) const
SizeType GetNumberOfTransferSyntaxes() const
Definition gdcmPresentationContextRQ.h:58
const std::ostream & Write(std::ostream &os) const
bool operator==(const PresentationContextRQ &pc) const
Definition gdcmPresentationContextRQ.h:65
TransferSyntaxSub.
Definition gdcmTransferSyntaxSub.h:38
#define GDCM_EXPORT
Definition gdcmWin32.h:34
Definition gdcmASN1.h:21