]> git.saurik.com Git - wxWidgets.git/blob - include/wx/msw/enhmeta.h
A little black magic... When the C++ object (for a window or
[wxWidgets.git] / include / wx / msw / enhmeta.h
1 ///////////////////////////////////////////////////////////////////////////////
2 // Name: wx/msw/enhmeta.h
3 // Purpose: wxEnhMetaFile class for Win32
4 // Author: Vadim Zeitlin
5 // Modified by:
6 // Created: 13.01.00
7 // RCS-ID: $Id$
8 // Copyright: (c) 2000 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9 // Licence: wxWindows license
10 ///////////////////////////////////////////////////////////////////////////////
11
12 #ifndef _WX_MSW_ENHMETA_H_
13 #define _WX_MSW_ENHMETA_H_
14
15 #ifdef __GNUG__
16 #pragma interface "enhmeta.h"
17 #endif
18
19 #include "wx/dc.h"
20
21 #if wxUSE_DRAG_AND_DROP
22 #include "wx/dataobj.h"
23 #endif
24
25 // ----------------------------------------------------------------------------
26 // wxEnhMetaFile: encapsulation of Win32 HENHMETAFILE
27 // ----------------------------------------------------------------------------
28
29 class WXDLLEXPORT wxEnhMetaFile : public wxObject
30 {
31 public:
32 wxEnhMetaFile(const wxString& file = wxEmptyString) : m_filename(file)
33 { Init(); }
34 wxEnhMetaFile(const wxEnhMetaFile& metafile)
35 { Init(); Assign(metafile); }
36 wxEnhMetaFile& operator=(const wxEnhMetaFile& metafile)
37 { Free(); Assign(metafile); return *this; }
38
39 virtual ~wxEnhMetaFile()
40 { Free(); }
41
42 // display the picture stored in the metafile on the given DC
43 bool Play(wxDC *dc, wxRect *rectBound = (wxRect *)NULL);
44
45 // accessors
46 bool Ok() const { return m_hMF != 0; }
47
48 wxSize GetSize() const;
49 int GetWidth() const { return GetSize().x; }
50 int GetHeight() const { return GetSize().y; }
51
52 const wxString& GetFileName() const { return m_filename; }
53
54 // copy the metafile to the clipboard: the width and height parameters are
55 // for backwards compatibility (with wxMetaFile) only, they are ignored by
56 // this method
57 bool SetClipboard(int width = 0, int height = 0);
58
59 // implementation
60 WXHANDLE GetHENHMETAFILE() const { return m_hMF; }
61 void SetHENHMETAFILE(WXHANDLE hMF) { Free(); m_hMF = hMF; }
62
63 protected:
64 void Init() { m_hMF = 0; }
65 void Free();
66 void Assign(const wxEnhMetaFile& mf);
67
68 private:
69 wxString m_filename;
70 WXHANDLE m_hMF;
71
72 DECLARE_DYNAMIC_CLASS(wxEnhMetaFile)
73 };
74
75 // ----------------------------------------------------------------------------
76 // wxEnhMetaFileDC: allows to create a wxEnhMetaFile
77 // ----------------------------------------------------------------------------
78
79 class WXDLLEXPORT wxEnhMetaFileDC : public wxDC
80 {
81 public:
82 // the ctor parameters specify the filename (empty for memory metafiles),
83 // the metafile picture size and the optional description/comment
84 wxEnhMetaFileDC(const wxString& filename = wxEmptyString,
85 int width = 0, int height = 0,
86 const wxString& description = wxEmptyString);
87
88 virtual ~wxEnhMetaFileDC();
89
90 // obtain a pointer to the new metafile (caller should delete it)
91 wxEnhMetaFile *Close();
92
93 private:
94 DECLARE_DYNAMIC_CLASS(wxEnhMetaFileDC)
95 };
96
97 #if wxUSE_DRAG_AND_DROP
98
99 // ----------------------------------------------------------------------------
100 // wxEnhMetaFileDataObject is a specialization of wxDataObject for enh metafile
101 // ----------------------------------------------------------------------------
102
103 // notice that we want to support both CF_METAFILEPICT and CF_ENHMETAFILE and
104 // so we derive from wxDataObject and not from wxDataObjectSimple
105 class WXDLLEXPORT wxEnhMetaFileDataObject : public wxDataObject
106 {
107 public:
108 // ctors
109 wxEnhMetaFileDataObject() { }
110 wxEnhMetaFileDataObject(const wxEnhMetaFile& metafile)
111 : m_metafile(metafile) { }
112
113 // virtual functions which you may override if you want to provide data on
114 // demand only - otherwise, the trivial default versions will be used
115 virtual void SetMetafile(const wxEnhMetaFile& metafile)
116 { m_metafile = metafile; }
117 virtual wxEnhMetaFile GetMetafile() const
118 { return m_metafile; }
119
120 // implement base class pure virtuals
121 virtual wxDataFormat GetPreferredFormat(Direction dir) const;
122 virtual size_t GetFormatCount(Direction dir) const;
123 virtual void GetAllFormats(wxDataFormat *formats, Direction dir) const;
124 virtual size_t GetDataSize(const wxDataFormat& format) const;
125 virtual bool GetDataHere(const wxDataFormat& format, void *buf) const;
126 virtual bool SetData(const wxDataFormat& format, size_t len,
127 const void *buf);
128
129 protected:
130 wxEnhMetaFile m_metafile;
131 };
132
133
134 // ----------------------------------------------------------------------------
135 // wxEnhMetaFileSimpleDataObject does derive from wxDataObjectSimple which
136 // makes it more convenient to use (it can be used with wxDataObjectComposite)
137 // at the price of not supoprting any more CF_METAFILEPICT but only
138 // CF_ENHMETAFILE
139 // ----------------------------------------------------------------------------
140
141 class WXDLLEXPORT wxEnhMetaFileSimpleDataObject : public wxDataObjectSimple
142 {
143 public:
144 // ctors
145 wxEnhMetaFileSimpleDataObject() : wxDataObjectSimple(wxDF_ENHMETAFILE) { }
146 wxEnhMetaFileSimpleDataObject(const wxEnhMetaFile& metafile)
147 : wxDataObjectSimple(wxDF_ENHMETAFILE), m_metafile(metafile) { }
148
149 // virtual functions which you may override if you want to provide data on
150 // demand only - otherwise, the trivial default versions will be used
151 virtual void SetEnhMetafile(const wxEnhMetaFile& metafile)
152 { m_metafile = metafile; }
153 virtual wxEnhMetaFile GetEnhMetafile() const
154 { return m_metafile; }
155
156 // implement base class pure virtuals
157 virtual size_t GetDataSize() const;
158 virtual bool GetDataHere(void *buf) const;
159 virtual bool SetData(size_t len, const void *buf);
160
161 protected:
162 wxEnhMetaFile m_metafile;
163 };
164
165 #endif // wxUSE_DRAG_AND_DROP
166
167 #endif // _WX_MSW_ENHMETA_H_