X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/888dde65f43d5f57e8fb2028b27191cca1741403..7b0ccb8a603b4f97740acc65d9429bb58f7ba1bd:/include/wx/mac/carbon/metafile.h?ds=sidebyside diff --git a/include/wx/mac/carbon/metafile.h b/include/wx/mac/carbon/metafile.h index 119ed37967..da4c864150 100644 --- a/include/wx/mac/carbon/metafile.h +++ b/include/wx/mac/carbon/metafile.h @@ -37,9 +37,8 @@ class wxMetafileRefData ; #define M_METAFILEDATA ((wxMetafileRefData *)m_refData) -class WXDLLEXPORT wxMetafile: public wxGDIObject +class WXDLLIMPEXP_CORE wxMetafile : public wxGDIObject { - DECLARE_DYNAMIC_CLASS(wxMetafile) public: wxMetafile(const wxString& file = wxEmptyString); virtual ~wxMetafile(void); @@ -49,8 +48,6 @@ public: virtual bool SetClipboard(int width = 0, int height = 0); virtual bool Play(wxDC *dc); - bool Ok() const { return IsOk(); } - bool IsOk() const ; wxSize GetSize() const; int GetWidth() const { return GetSize().x; } @@ -65,10 +62,16 @@ public: // backwards compatibility void SetPICT(void* pictHandle) ; #endif + +protected: + virtual wxGDIRefData *CreateGDIRefData() const; + virtual wxGDIRefData *CloneGDIRefData(const wxGDIRefData *data) const; + + DECLARE_DYNAMIC_CLASS(wxMetafile) }; -class WXDLLEXPORT wxMetafileDCImpl: public wxGCDCImpl +class WXDLLIMPEXP_CORE wxMetafileDCImpl: public wxGCDCImpl { public: wxMetafileDCImpl( wxDC *owner, @@ -89,34 +92,35 @@ protected: virtual void DoGetSize(int *width, int *height) const; wxMetafile* m_metaFile; - + private: DECLARE_CLASS(wxMetafileDCImpl) DECLARE_NO_COPY_CLASS(wxMetafileDCImpl) }; -class WXDLLEXPORT wxMetafileDC: public wxDC +class WXDLLIMPEXP_CORE wxMetafileDC: public wxDC { public: // the ctor parameters specify the filename (empty for memory metafiles), // the metafile picture size and the optional description/comment wxMetafileDC( const wxString& filename = wxEmptyString, int width = 0, int height = 0, - const wxString& description = wxEmptyString ) - { m_pimpl = new wxMetafileDCImpl( this, filename, width, height, description ); } - - wxMetafile *GetMetafile() const + const wxString& description = wxEmptyString ) : + wxDC( new wxMetafileDCImpl( this, filename, width, height, description) ) + { } + + wxMetafile *GetMetafile() const { return ((wxMetafileDCImpl*)m_pimpl)->GetMetaFile(); } - + wxMetafile *Close() { return ((wxMetafileDCImpl*)m_pimpl)->Close(); } - + private: DECLARE_CLASS(wxMetafileDC) DECLARE_NO_COPY_CLASS(wxMetafileDC) }; - - + + /* * Pass filename of existing non-placeable metafile, and bounding box. * Adds a placeable metafile header, sets the mapping mode to anisotropic, @@ -126,21 +130,21 @@ private: // No origin or extent #define wxMakeMetaFilePlaceable wxMakeMetafilePlaceable -bool WXDLLEXPORT wxMakeMetafilePlaceable(const wxString& filename, float scale = 1.0); +bool WXDLLIMPEXP_CORE wxMakeMetafilePlaceable(const wxString& filename, float scale = 1.0); // Optional origin and extent -bool WXDLLEXPORT wxMakeMetaFilePlaceable(const wxString& filename, int x1, int y1, int x2, int y2, float scale = 1.0, bool useOriginAndExtent = TRUE); +bool WXDLLIMPEXP_CORE wxMakeMetaFilePlaceable(const wxString& filename, int x1, int y1, int x2, int y2, float scale = 1.0, bool useOriginAndExtent = TRUE); // ---------------------------------------------------------------------------- // wxMetafileDataObject is a specialization of wxDataObject for metafile data // ---------------------------------------------------------------------------- #if wxUSE_DATAOBJ -class WXDLLEXPORT wxMetafileDataObject : public wxDataObjectSimple +class WXDLLIMPEXP_CORE wxMetafileDataObject : public wxDataObjectSimple { public: // ctors - wxMetafileDataObject() + wxMetafileDataObject() : wxDataObjectSimple(wxDF_METAFILE) { }; wxMetafileDataObject(const wxMetafile& metafile) : wxDataObjectSimple(wxDF_METAFILE), m_metafile(metafile) { }