cleanup mac

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@50102 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Stefan Csomor
2007-11-20 07:35:53 +00:00
parent e1673e527f
commit 315e9e5a66

View File

@@ -38,13 +38,8 @@ IMPLEMENT_ABSTRACT_CLASS(wxMetafileDC, wxDC)
class wxMetafileRefData: public wxGDIRefData class wxMetafileRefData: public wxGDIRefData
{ {
public: public:
#if wxMAC_USE_CORE_GRAPHICS
// creates a metafile from memory, assumes ownership // creates a metafile from memory, assumes ownership
wxMetafileRefData(CFDataRef data); wxMetafileRefData(CFDataRef data);
#else
// creates a metafile from memory, assumes ownership
wxMetafileRefData(PicHandle data);
#endif
// prepares a recording metafile // prepares a recording metafile
wxMetafileRefData( int width, int height); wxMetafileRefData( int width, int height);
// prepares a metafile to be read from a file (if filename is not empty) // prepares a metafile to be read from a file (if filename is not empty)
@@ -56,53 +51,34 @@ public:
int GetWidth() const { return m_width; } int GetWidth() const { return m_width; }
int GetHeight() const { return m_height; } int GetHeight() const { return m_height; }
#if wxMAC_USE_CORE_GRAPHICS
CGPDFDocumentRef GetPDFDocument() const { return m_pdfDoc; } CGPDFDocumentRef GetPDFDocument() const { return m_pdfDoc; }
void UpdateDocumentFromData() ; void UpdateDocumentFromData() ;
const wxCFDataRef& GetData() const { return m_data; } const wxCFDataRef& GetData() const { return m_data; }
CGContextRef GetContext() const { return m_context; } CGContextRef GetContext() const { return m_context; }
#else
PicHandle GetHandle() const { return m_metafile; }
#endif
// ends the recording // ends the recording
void Close(); void Close();
private: private:
#if wxMAC_USE_CORE_GRAPHICS
wxCFDataRef m_data; wxCFDataRef m_data;
wxCFRef<CGPDFDocumentRef> m_pdfDoc; wxCFRef<CGPDFDocumentRef> m_pdfDoc;
CGContextRef m_context; CGContextRef m_context;
#else
PicHandle m_metafile;
#endif
int m_width ; int m_width ;
int m_height ; int m_height ;
}; };
#if !wxMAC_USE_CORE_GRAPHICS
wxMetafileRefData::wxMetafileRefData(PicHandle pict)
{
Init();
m_metafile = pict;
Rect r;
wxMacGetPictureBounds( m_metafile, &r );
m_width = r.right - r.left;
m_height = r.bottom - r.top;
}
#else
wxMetafileRefData::wxMetafileRefData(CFDataRef data) : wxMetafileRefData::wxMetafileRefData(CFDataRef data) :
m_data(data) m_data(data)
{ {
Init(); Init();
UpdateDocumentFromData(); UpdateDocumentFromData();
} }
#endif
wxMetafileRefData::wxMetafileRefData( const wxString& filename ) wxMetafileRefData::wxMetafileRefData( const wxString& filename )
{ {
Init(); Init();
#if wxMAC_USE_CORE_GRAPHICS
if ( !filename.empty() ) if ( !filename.empty() )
{ {
wxCFRef<CFMutableStringRef> cfMutableString(CFStringCreateMutableCopy(NULL, 0, wxMacCFStringHolder(filename))); wxCFRef<CFMutableStringRef> cfMutableString(CFStringCreateMutableCopy(NULL, 0, wxMacCFStringHolder(filename)));
@@ -110,10 +86,6 @@ wxMetafileRefData::wxMetafileRefData( const wxString& filename )
wxCFRef<CFURLRef> url(CFURLCreateWithFileSystemPath(kCFAllocatorDefault, cfMutableString , kCFURLPOSIXPathStyle, false)); wxCFRef<CFURLRef> url(CFURLCreateWithFileSystemPath(kCFAllocatorDefault, cfMutableString , kCFURLPOSIXPathStyle, false));
m_pdfDoc.reset(CGPDFDocumentCreateWithURL(url)); m_pdfDoc.reset(CGPDFDocumentCreateWithURL(url));
} }
#else
wxASSERT_MSG( filename.empty(), wxT("no file-based metafile support yet") );
m_metafile = NULL;
#endif
} }
@@ -123,7 +95,7 @@ wxMetafileRefData::wxMetafileRefData( int width, int height)
m_width = width; m_width = width;
m_height = height; m_height = height;
#if wxMAC_USE_CORE_GRAPHICS
CGRect r = CGRectMake( 0 , 0 , width , height ); CGRect r = CGRectMake( 0 , 0 , width , height );
CFMutableDataRef data = CFDataCreateMutable(kCFAllocatorDefault, 0); CFMutableDataRef data = CFDataCreateMutable(kCFAllocatorDefault, 0);
@@ -133,12 +105,7 @@ wxMetafileRefData::wxMetafileRefData( int width, int height)
CGDataConsumerRelease( dataConsumer ); CGDataConsumerRelease( dataConsumer );
if ( m_context ) if ( m_context )
{ {
#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4 CGPDFContextBeginPage(m_context, NULL);
if ( &CGPDFContextBeginPage != NULL )
CGPDFContextBeginPage(m_context, NULL);
else
#endif
CGContextBeginPage(m_context, &r);
CGColorSpaceRef genericColorSpace = wxMacGetGenericRGBColorSpace(); CGColorSpaceRef genericColorSpace = wxMacGetGenericRGBColorSpace();
@@ -148,54 +115,29 @@ wxMetafileRefData::wxMetafileRefData( int width, int height)
CGContextTranslateCTM( m_context , 0 , height ) ; CGContextTranslateCTM( m_context , 0 , height ) ;
CGContextScaleCTM( m_context , 1 , -1 ) ; CGContextScaleCTM( m_context , 1 , -1 ) ;
} }
#else
Rect r = { 0, 0, height, width };
m_metafile = OpenPicture( &r ) ;
#endif
} }
wxMetafileRefData::~wxMetafileRefData() wxMetafileRefData::~wxMetafileRefData()
{ {
#if! wxMAC_USE_CORE_GRAPHICS
if (m_metafile)
{
KillPicture( (PicHandle)m_metafile );
m_metafile = NULL;
}
#endif
} }
void wxMetafileRefData::Init() void wxMetafileRefData::Init()
{ {
#if wxMAC_USE_CORE_GRAPHICS
m_context = NULL; m_context = NULL;
#else
m_metafile = NULL;
#endif
m_width = -1; m_width = -1;
m_height = -1; m_height = -1;
} }
void wxMetafileRefData::Close() void wxMetafileRefData::Close()
{ {
#if wxMAC_USE_CORE_GRAPHICS CGPDFContextEndPage(m_context);
#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_4
if ( &CGPDFContextEndPage != NULL )
CGPDFContextEndPage(m_context);
else
#endif
CGContextEndPage(m_context);
CGContextRelease(m_context); CGContextRelease(m_context);
m_context = NULL; m_context = NULL;
UpdateDocumentFromData(); UpdateDocumentFromData();
#else
ClosePicture();
#endif
} }
#if wxMAC_USE_CORE_GRAPHICS
void wxMetafileRefData::UpdateDocumentFromData() void wxMetafileRefData::UpdateDocumentFromData()
{ {
wxCFRef<CGDataProviderRef> provider(UMACGDataProviderCreateWithCFData(m_data)); wxCFRef<CGDataProviderRef> provider(UMACGDataProviderCreateWithCFData(m_data));
@@ -208,7 +150,6 @@ void wxMetafileRefData::UpdateDocumentFromData()
m_height = wx_static_cast(int, rect.size.height); m_height = wx_static_cast(int, rect.size.height);
} }
} }
#endif
wxMetaFile::wxMetaFile(const wxString& file) wxMetaFile::wxMetaFile(const wxString& file)
{ {
@@ -221,20 +162,12 @@ wxMetaFile::~wxMetaFile()
bool wxMetaFile::IsOk() const bool wxMetaFile::IsOk() const
{ {
#if wxMAC_USE_CORE_GRAPHICS
return (M_METAFILEDATA && (M_METAFILEDATA->GetData() != NULL)); return (M_METAFILEDATA && (M_METAFILEDATA->GetData() != NULL));
#else
return (M_METAFILEDATA && (M_METAFILEDATA->GetHandle() != NULL));
#endif
} }
WXHMETAFILE wxMetaFile::GetHMETAFILE() const WXHMETAFILE wxMetaFile::GetHMETAFILE() const
{ {
#if wxMAC_USE_CORE_GRAPHICS
return (WXHMETAFILE) (CFDataRef) M_METAFILEDATA->GetData(); return (WXHMETAFILE) (CFDataRef) M_METAFILEDATA->GetData();
#else
return (WXHMETAFILE) M_METAFILEDATA->GetHandle();
#endif
} }
bool wxMetaFile::SetClipboard(int WXUNUSED(width), int WXUNUSED(height)) bool wxMetaFile::SetClipboard(int WXUNUSED(width), int WXUNUSED(height))
@@ -265,18 +198,13 @@ void wxMetafile::SetHMETAFILE(WXHMETAFILE mf)
{ {
UnRef(); UnRef();
#if wxMAC_USE_CORE_GRAPHICS
m_refData = new wxMetafileRefData((CFDataRef)mf); m_refData = new wxMetafileRefData((CFDataRef)mf);
#else
m_refData = new wxMetafileRefData((PicHandle)mf);
#endif
} }
void wxMetafile::SetPICT(void* pictHandle) void wxMetafile::SetPICT(void* pictHandle)
{ {
UnRef(); UnRef();
#if wxMAC_USE_CORE_GRAPHICS
Handle picHandle = (Handle) pictHandle; Handle picHandle = (Handle) pictHandle;
HLock(picHandle); HLock(picHandle);
CFDataRef data = CFDataCreateWithBytesNoCopy( kCFAllocatorDefault, (const UInt8*) *picHandle, GetHandleSize(picHandle), kCFAllocatorNull); CFDataRef data = CFDataCreateWithBytesNoCopy( kCFAllocatorDefault, (const UInt8*) *picHandle, GetHandleSize(picHandle), kCFAllocatorNull);
@@ -289,9 +217,6 @@ void wxMetafile::SetPICT(void* pictHandle)
CFRelease( data ); CFRelease( data );
QDPictRelease( pictRef ); QDPictRelease( pictRef );
((wxMetafileRefData*) m_refData)->Close(); ((wxMetafileRefData*) m_refData)->Close();
#else
m_refData = new wxMetafileRefData((PicHandle)pictHandle);
#endif
} }
bool wxMetaFile::Play(wxDC *dc) bool wxMetaFile::Play(wxDC *dc)
@@ -303,7 +228,6 @@ bool wxMetaFile::Play(wxDC *dc)
return false; return false;
{ {
#if wxMAC_USE_CORE_GRAPHICS
CGContextRef cg = (CGContextRef) dc->GetGraphicsContext()->GetNativeContext(); CGContextRef cg = (CGContextRef) dc->GetGraphicsContext()->GetNativeContext();
CGPDFDocumentRef doc = M_METAFILEDATA->GetPDFDocument(); CGPDFDocumentRef doc = M_METAFILEDATA->GetPDFDocument();
CGPDFPageRef page = CGPDFDocumentGetPage( doc, 1 ); CGPDFPageRef page = CGPDFDocumentGetPage( doc, 1 );
@@ -311,12 +235,6 @@ bool wxMetaFile::Play(wxDC *dc)
CGContextDrawPDFPage( cg, page ); CGContextDrawPDFPage( cg, page );
// CGContextTranslateCTM( cg, 0, bounds.size.width ); // CGContextTranslateCTM( cg, 0, bounds.size.width );
// CGContextScaleCTM( cg, 1, -1 ); // CGContextScaleCTM( cg, 1, -1 );
#else
PicHandle pict = (PicHandle)GetHMETAFILE();
wxMacPortSetter helper( dc );
Rect picFrame;
DrawPicture( pict, wxMacGetPictureBounds( pict, &picFrame ) );
#endif
} }
return true; return true;
@@ -352,16 +270,9 @@ wxMetaFileDC::wxMetaFileDC(
wxMetafileRefData* metafiledata = new wxMetafileRefData(width, height); wxMetafileRefData* metafiledata = new wxMetafileRefData(width, height);
m_metaFile->UnRef(); m_metaFile->UnRef();
m_metaFile->SetRefData( metafiledata ); m_metaFile->SetRefData( metafiledata );
#if wxMAC_USE_CORE_GRAPHICS
SetGraphicsContext( wxGraphicsContext::CreateFromNative(metafiledata->GetContext())); SetGraphicsContext( wxGraphicsContext::CreateFromNative(metafiledata->GetContext()));
m_ok = (m_graphicContext != NULL) ; m_ok = (m_graphicContext != NULL) ;
#else
Rect r = { 0, 0, height, width };
RectRgn( (RgnHandle)m_macBoundaryClipRgn, &r );
CopyRgn( (RgnHandle)m_macBoundaryClipRgn, (RgnHandle)m_macCurrentClipRgn );
::GetPort( (GrafPtr*)&m_macPort );
m_ok = true;
#endif
SetMapMode( wxMM_TEXT ); SetMapMode( wxMM_TEXT );
} }
@@ -383,11 +294,9 @@ void wxMetaFileDC::DoGetSize(int *width, int *height) const
wxMetaFile *wxMetaFileDC::Close() wxMetaFile *wxMetaFileDC::Close()
{ {
#if wxMAC_USE_CORE_GRAPHICS
delete m_graphicContext; delete m_graphicContext;
m_graphicContext = NULL; m_graphicContext = NULL;
m_ok = false; m_ok = false;
#endif
M_METAFILEREFDATA(*m_metaFile)->Close(); M_METAFILEREFDATA(*m_metaFile)->Close();
@@ -397,21 +306,17 @@ wxMetaFile *wxMetaFileDC::Close()
#if wxUSE_DATAOBJ #if wxUSE_DATAOBJ
size_t wxMetafileDataObject::GetDataSize() const size_t wxMetafileDataObject::GetDataSize() const
{ {
#if wxMAC_USE_CORE_GRAPHICS
CFIndex length = 0; CFIndex length = 0;
wxMetafileRefData* refData = M_METAFILEREFDATA(m_metafile); wxMetafileRefData* refData = M_METAFILEREFDATA(m_metafile);
if ( refData ) if ( refData )
length = refData->GetData().GetLength(); length = refData->GetData().GetLength();
return length; return length;
#else
return GetHandleSize( (Handle) (*((wxMetafile*)&m_metafile)).GetHMETAFILE() );
#endif
} }
bool wxMetafileDataObject::GetDataHere(void *buf) const bool wxMetafileDataObject::GetDataHere(void *buf) const
{ {
bool result = false; bool result = false;
#if wxMAC_USE_CORE_GRAPHICS
wxMetafileRefData* refData = M_METAFILEREFDATA(m_metafile); wxMetafileRefData* refData = M_METAFILEREFDATA(m_metafile);
if ( refData ) if ( refData )
{ {
@@ -422,29 +327,14 @@ bool wxMetafileDataObject::GetDataHere(void *buf) const
refData->GetData().GetBytes(CFRangeMake(0,length), (UInt8 *) buf); refData->GetData().GetBytes(CFRangeMake(0,length), (UInt8 *) buf);
} }
} }
#else
Handle pictH = (Handle)(*((wxMetafile*)&m_metafile)).GetHMETAFILE();
result = (pictH != NULL);
if (result)
memcpy( buf, *pictH, GetHandleSize( pictH ) );
#endif
return result; return result;
} }
bool wxMetafileDataObject::SetData(size_t len, const void *buf) bool wxMetafileDataObject::SetData(size_t len, const void *buf)
{ {
#if wxMAC_USE_CORE_GRAPHICS
wxMetafileRefData* metafiledata = new wxMetafileRefData(wxCFRefFromGet(wxCFDataRef((UInt8*)buf, len).get())); wxMetafileRefData* metafiledata = new wxMetafileRefData(wxCFRefFromGet(wxCFDataRef((UInt8*)buf, len).get()));
m_metafile.UnRef(); m_metafile.UnRef();
m_metafile.SetRefData( metafiledata ); m_metafile.SetRefData( metafiledata );
#else
Handle handle = NewHandle( len );
SetHandleSize( handle, len );
memcpy( *handle, buf, len );
m_metafile.SetHMETAFILE( (WXHMETAFILE) handle );
#endif
return true; return true;
} }
#endif #endif