summaryrefslogtreecommitdiff
path: root/inc/Xw_MarkMap.hxx
blob: 741e9fb86774f9d025c2836ecc81d12905c155ed (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// This file is generated by WOK (CPPExt).
// Please do not edit this file; modify original file instead.
// The copyright and license terms as defined for the original file apply to 
// this header file considered to be the "object code" form of the original source.

#ifndef _Xw_MarkMap_HeaderFile
#define _Xw_MarkMap_HeaderFile

#ifndef _Standard_HeaderFile
#include <Standard.hxx>
#endif
#ifndef _Standard_DefineHandle_HeaderFile
#include <Standard_DefineHandle.hxx>
#endif
#ifndef _Handle_Xw_MarkMap_HeaderFile
#include <Handle_Xw_MarkMap.hxx>
#endif

#ifndef _Standard_Address_HeaderFile
#include <Standard_Address.hxx>
#endif
#ifndef _Standard_Transient_HeaderFile
#include <Standard_Transient.hxx>
#endif
#ifndef _Standard_CString_HeaderFile
#include <Standard_CString.hxx>
#endif
#ifndef _Handle_Aspect_MarkMap_HeaderFile
#include <Handle_Aspect_MarkMap.hxx>
#endif
#ifndef _Standard_Integer_HeaderFile
#include <Standard_Integer.hxx>
#endif
class Aspect_MarkMapDefinitionError;
class Aspect_BadAccess;
class Xw_GraphicDevice;
class Aspect_MarkMapEntry;
class Aspect_MarkMap;


//! This class defines a MarkMap object. <br>
class Xw_MarkMap : public Standard_Transient {

public:

  //! Creates a MarkMap with unallocated MarkMapEntry. <br>
//!  Warning: Raises if MarkMap creation failed according <br>
//!	    to the supported hardware <br>
  Standard_EXPORT   Xw_MarkMap(const Standard_CString Connexion);
  //! Modifies an entry already defined or Add the Entry <br>
//!	    in the marker map <me> if it don't exist. <br>
//!  Warning: Raises if MarkMap size is exceeded, <br>
//!	    or MarkMap is not defined properly, <br>
//!	    or MarkMapEntry Index is out of range according <br>
//!	    to the supported hardware <br>
  Standard_EXPORT   virtual  void SetEntry(const Aspect_MarkMapEntry& anEntry) ;
  //! Modifies all entries from a new Markmap <br>
//!  Warning: Raises if MarkMap size is exceeded, <br>
//!	    or MarkMap is not defined properly, <br>
//!	    or One of new MarkMapEntry Index is out of range according <br>
//!	    to the supported hardware <br>
  Standard_EXPORT   virtual  void SetEntries(const Handle(Aspect_MarkMap)& aMarkmap) ;
  //! Destroies the Markmap <br>
  Standard_EXPORT   virtual  void Destroy() ;
~Xw_MarkMap()
{
  Destroy();
}
  //! Returns the Number of Free Marks in the Typemap <br>
//!	    depending of the HardWare <br>
//!  Warning: Raises if MarkMap is not defined properly <br>
  Standard_EXPORT     Standard_Integer FreeMarkers() const;

friend class Xw_GraphicDevice;


  DEFINE_STANDARD_RTTI(Xw_MarkMap)

protected:

  
  Standard_EXPORT   Xw_MarkMap();
  //! Returns extended data markermap structure pointer. <br>
  Standard_EXPORT     Standard_Address ExtendedMarkMap() const;



private: 


Standard_Address MyExtendedDisplay;
Standard_Address MyExtendedMarkMap;


};





// other Inline functions and methods (like "C++: function call" methods)


#endif