X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a2d6d210991fb1d29570a46e0f26c7a4b9cf89ff..c4807c0a8fdce8c8a21f7296cc224c08297ca54b:/src/mac/carbon/dcscreen.cpp?ds=inline diff --git a/src/mac/carbon/dcscreen.cpp b/src/mac/carbon/dcscreen.cpp index 2468ce77db..ba827defdd 100644 --- a/src/mac/carbon/dcscreen.cpp +++ b/src/mac/carbon/dcscreen.cpp @@ -14,13 +14,21 @@ #include "wx/dcscreen.h" #include "wx/mac/uma.h" +#include "wx/graphics.h" IMPLEMENT_DYNAMIC_CLASS(wxScreenDC, wxWindowDC) +// TODO : for the Screenshot use case, which doesn't work in Quartz +// we should do a GetAsBitmap using something like +// http://www.cocoabuilder.com/archive/message/cocoa/2005/8/13/144256 + // Create a DC representing the whole screen wxScreenDC::wxScreenDC() { -#if wxMAC_USE_CORE_GRAPHICS +#ifdef __LP64__ + m_graphicContext = NULL; + m_ok = false ; +#else CGRect cgbounds ; cgbounds = CGDisplayBounds(CGMainDisplayID()); Rect bounds; @@ -34,43 +42,16 @@ wxScreenDC::wxScreenDC() SetGraphicsContext( wxGraphicsContext::CreateFromNativeWindow( m_overlayWindow ) ); m_width = (wxCoord)cgbounds.size.width; m_height = (wxCoord)cgbounds.size.height; -#else - m_macPort = CreateNewPort() ; - GrafPtr port ; - GetPort( &port ) ; - SetPort( (GrafPtr) m_macPort ) ; - Point pt = { 0,0 } ; - LocalToGlobal( &pt ) ; - SetPort( port ) ; - m_macLocalOrigin.x = -pt.h ; - m_macLocalOrigin.y = -pt.v ; - - BitMap screenBits; - GetQDGlobalsScreenBits( &screenBits ); - m_minX = screenBits.bounds.left ; - - SInt16 height ; - GetThemeMenuBarHeight( &height ) ; - m_minY = screenBits.bounds.top + height ; - - m_maxX = screenBits.bounds.right ; - m_maxY = screenBits.bounds.bottom ; - - MacSetRectRgn( (RgnHandle) m_macBoundaryClipRgn , m_minX , m_minY , m_maxX , m_maxY ) ; - OffsetRgn( (RgnHandle) m_macBoundaryClipRgn , m_macLocalOrigin.x , m_macLocalOrigin.y ) ; - CopyRgn( (RgnHandle) m_macBoundaryClipRgn , (RgnHandle) m_macCurrentClipRgn ) ; -#endif m_ok = true ; +#endif } wxScreenDC::~wxScreenDC() { -#if wxMAC_USE_CORE_GRAPHICS delete m_graphicContext; m_graphicContext = NULL; - DisposeWindow((WindowRef) m_overlayWindow ); +#ifdef __LP64__ #else - if ( m_macPort ) - DisposePort( (CGrafPtr) m_macPort ) ; + DisposeWindow((WindowRef) m_overlayWindow ); #endif }