X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e9576ca53db96b462ed4c0b4bdf47d64c40203e4..850df2d78866c3edcf848103b5dbc7e7fa1ee5fa:/src/mac/carbon/dcscreen.cpp?ds=sidebyside diff --git a/src/mac/carbon/dcscreen.cpp b/src/mac/carbon/dcscreen.cpp index e03bbac0c8..1de302dade 100644 --- a/src/mac/carbon/dcscreen.cpp +++ b/src/mac/carbon/dcscreen.cpp @@ -1,32 +1,49 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: dcscreen.cpp +// Name: src/mac/carbon/dcscreen.cpp // Purpose: wxScreenDC class -// Author: AUTHOR +// Author: Stefan Csomor // Modified by: -// Created: ??/??/98 +// Created: 1998-01-01 // RCS-ID: $Id$ -// Copyright: (c) AUTHOR -// Licence: wxWindows licence +// Copyright: (c) Stefan Csomor +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "dcscreen.h" -#endif +#include "wx/wxprec.h" #include "wx/dcscreen.h" -#if !USE_SHARED_LIBRARY +#include "wx/mac/uma.h" +#include "wx/graphics.h" + IMPLEMENT_DYNAMIC_CLASS(wxScreenDC, wxWindowDC) -#endif + +// 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() { - // TODO + CGRect cgbounds ; + cgbounds = CGDisplayBounds(CGMainDisplayID()); + Rect bounds; + bounds.top = (short)cgbounds.origin.y; + bounds.left = (short)cgbounds.origin.x; + bounds.bottom = bounds.top + (short)cgbounds.size.height; + bounds.right = bounds.left + (short)cgbounds.size.width; + WindowAttributes overlayAttributes = kWindowIgnoreClicksAttribute; + CreateNewWindow( kOverlayWindowClass, overlayAttributes, &bounds, (WindowRef*) &m_overlayWindow ); + ShowWindow((WindowRef)m_overlayWindow); + SetGraphicsContext( wxGraphicsContext::CreateFromNativeWindow( m_overlayWindow ) ); + m_width = (wxCoord)cgbounds.size.width; + m_height = (wxCoord)cgbounds.size.height; + m_ok = true ; } wxScreenDC::~wxScreenDC() { - // TODO + delete m_graphicContext; + m_graphicContext = NULL; + DisposeWindow((WindowRef) m_overlayWindow ); } -