X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f2555abd7afd7a7a6017f46dd6550d804850fb9f..09b895cb4a954494063eb17d3dc302a654fd99e5:/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 23a0dc9570..da4c864150 100644 --- a/include/wx/mac/carbon/metafile.h +++ b/include/wx/mac/carbon/metafile.h @@ -22,6 +22,8 @@ #include "wx/dataobj.h" #endif +#include "wx/mac/carbon/dcclient.h" + /* * Metafile and metafile device context classes * @@ -30,29 +32,22 @@ #define wxMetaFile wxMetafile #define wxMetaFileDC wxMetafileDC -class WXDLLEXPORT wxMetafile; +class WXDLLIMPEXP_FWD_CORE wxMetafile; class wxMetafileRefData ; #define M_METAFILEDATA ((wxMetafileRefData *)m_refData) -class WXDLLEXPORT wxMetafile: public wxGDIObject +class WXDLLIMPEXP_CORE wxMetafile : public wxGDIObject { - DECLARE_DYNAMIC_CLASS(wxMetafile) public: - // Copy constructor - wxMetafile(const wxMetafile& metafile) - : wxGDIObject() - { Ref(metafile); } - wxMetafile(const wxString& file = wxEmptyString); - ~wxMetafile(void); + virtual ~wxMetafile(void); // After this is called, the metafile cannot be used for anything // since it is now owned by the clipboard. virtual bool SetClipboard(int width = 0, int height = 0); virtual bool Play(wxDC *dc); - bool Ok() const ; wxSize GetSize() const; int GetWidth() const { return GetSize().x; } @@ -61,40 +56,71 @@ public: // Implementation WXHMETAFILE GetHMETAFILE() const ; void SetHMETAFILE(WXHMETAFILE mf) ; - - // Operators - inline wxMetafile& operator = (const wxMetafile& metafile) { if (*this == metafile) return (*this); Ref(metafile); return *this; } - inline bool operator == (const wxMetafile& metafile) { return m_refData == metafile.m_refData; } - inline bool operator != (const wxMetafile& metafile) { return m_refData != metafile.m_refData; } +#ifndef __LP64__ + // Since the native metafile format is PDF for Quartz + // we need a call that allows setting PICT content for + // 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 wxMetafileDC: public wxDC + +class WXDLLIMPEXP_CORE wxMetafileDCImpl: public wxGCDCImpl { - DECLARE_DYNAMIC_CLASS(wxMetafileDC) +public: + wxMetafileDCImpl( wxDC *owner, + const wxString& filename, + int width, int height, + const wxString& description ); + + virtual ~wxMetafileDCImpl(); + + // Should be called at end of drawing + virtual wxMetafile *Close(); + // Implementation + wxMetafile *GetMetaFile(void) const { return m_metaFile; } + void SetMetaFile(wxMetafile *mf) { m_metaFile = mf; } + +protected: + virtual void DoGetSize(int *width, int *height) const; + + wxMetafile* m_metaFile; + +private: + DECLARE_CLASS(wxMetafileDCImpl) + DECLARE_NO_COPY_CLASS(wxMetafileDCImpl) +}; + +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, + wxMetafileDC( const wxString& filename = wxEmptyString, int width = 0, int height = 0, - const wxString& description = wxEmptyString); - - ~wxMetafileDC(void); + const wxString& description = wxEmptyString ) : + wxDC( new wxMetafileDCImpl( this, filename, width, height, description) ) + { } - // Should be called at end of drawing - virtual wxMetafile *Close(void); - virtual void DoGetSize(int *width, int *height) const ; + wxMetafile *GetMetafile() const + { return ((wxMetafileDCImpl*)m_pimpl)->GetMetaFile(); } - // Implementation - inline wxMetafile *GetMetaFile(void) const { return m_metaFile; } - inline void SetMetaFile(wxMetafile *mf) { m_metaFile = mf; } + wxMetafile *Close() + { return ((wxMetafileDCImpl*)m_pimpl)->Close(); } -protected: - wxMetafile* m_metaFile; +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, @@ -104,21 +130,21 @@ protected: // 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) { }