// we store the window in case we would have to issue a Refresh()
wxWindow* m_window ;
- EventHandlerRef m_overlayParentHandler ;
- EventHandlerRef m_overlayHandler;
-
- static pascal OSStatus OverlayParentWindowEventHandlerProc( EventHandlerCallRef inCallRef, EventRef inEvent, void* inUserData );
- static pascal OSStatus OverlayWindowEventHandlerProc( EventHandlerCallRef inCallRef, EventRef inEvent, void* inUserData );
-
int m_x ;
int m_y ;
int m_width ;
bool wxOverlayImpl::IsOk()
{
- return m_overlayContext != NULL ;
-}
-
-pascal OSStatus wxOverlayImpl::OverlayWindowEventHandlerProc( EventHandlerCallRef WXUNUSED(inCallRef), EventRef inEvent, void* inUserData )
-{
- OSStatus err = noErr ;
- wxOverlayImpl* self = (wxOverlayImpl*) inUserData;
-
- wxMacCarbonEvent cEvent(inEvent) ;
- switch( cEvent.GetClass() )
- {
- case kEventClassWindow:
- switch( cEvent.GetKind() )
- {
- case kEventWindowBoundsChanged:
- break;
- default :
- break;
- }
- break ;
- default :
- break ;
- }
- // as we didn't interfere with the event itself, always return a notHandled
- return eventNotHandledErr ;
-}
-
-pascal OSStatus wxOverlayImpl::OverlayParentWindowEventHandlerProc( EventHandlerCallRef inCallRef, EventRef inEvent, void* inUserData )
-{
- OSStatus err = eventNotHandledErr ;
- wxOverlayImpl* self = (wxOverlayImpl*) inUserData;
-
- wxMacCarbonEvent cEvent(inEvent) ;
- switch( cEvent.GetClass() )
- {
- case kEventClassWindow:
- switch( cEvent.GetKind() )
- {
- case kEventWindowBoundsChanging:
- case kEventWindowBoundsChanged:
- {
- err = CallNextEventHandler(inCallRef,inEvent);
- Rect bounds ;
- self->MacGetBounds(&bounds);
- SetWindowBounds(self->m_overlayWindow,kWindowContentRgn,&bounds);
- }
- break;
- default :
- break;
- }
- break ;
- default :
- break ;
- }
- return err ;
+ return m_overlayWindow != NULL ;
}
void wxOverlayImpl::MacGetBounds( Rect *bounds )
{
OSStatus err;
- WindowAttributes overlayAttributes = kWindowHideOnSuspendAttribute | kWindowIgnoreClicksAttribute;
-
- static EventHandlerUPP overlayWindowEventHandlerUPP = NULL ;
- static EventHandlerUPP overlayParentWindowEventHandlerUPP = NULL ;
- const EventTypeSpec windowEvents[] =
- {
- { kEventClassWindow, kEventWindowBoundsChanged },
- };
-
- const EventTypeSpec parentWindowEvents[] =
- {
- { kEventClassWindow, kEventWindowBoundsChanged },
- { kEventClassWindow, kEventWindowBoundsChanging },
- };
-
- if ( overlayWindowEventHandlerUPP == NULL )
- overlayWindowEventHandlerUPP = NewEventHandlerUPP( OverlayWindowEventHandlerProc );
- if ( overlayParentWindowEventHandlerUPP == NULL )
-
- overlayParentWindowEventHandlerUPP = NewEventHandlerUPP( OverlayParentWindowEventHandlerProc );
-
+ WindowAttributes overlayAttributes = kWindowIgnoreClicksAttribute;
+
m_overlayParentWindow =(WindowRef) m_window->MacGetTopLevelWindowRef();
Rect bounds ;
err = CreateNewWindow( kOverlayWindowClass, overlayAttributes, &bounds, &m_overlayWindow );
if ( err == noErr )
{
- SetWindowGroup( m_overlayWindow, GetWindowGroup(m_overlayParentWindow) ); // Put them in the same group so that their window layers are consistent
- err = InstallWindowEventHandler( m_overlayWindow, overlayWindowEventHandlerUPP, GetEventTypeCount(windowEvents), windowEvents, this, &m_overlayHandler );
- if ( err == noErr )
- err = InstallWindowEventHandler( m_overlayParentWindow, overlayParentWindowEventHandlerUPP, GetEventTypeCount(parentWindowEvents), parentWindowEvents, this, &m_overlayParentHandler );
+ SetWindowGroup( m_overlayWindow, GetWindowGroup(m_overlayParentWindow)); // Put them in the same group so that their window layers are consistent
+ ShowWindow(m_overlayWindow);
}
return err;
}
OSStatus err = CreateOverlayWindow();
wxASSERT_MSG( err == noErr , _("Couldn't create the overlay window") );
- ShowWindow(m_overlayWindow);
-
+
err = QDBeginCGContext(GetWindowPort(m_overlayWindow), &m_overlayContext);
CGContextTranslateCTM( m_overlayContext, 0, m_height+m_y );
CGContextScaleCTM( m_overlayContext, 1, -1 );
{
delete dc->m_graphicContext ;
dc->m_graphicContext = new wxMacCGContext( m_overlayContext );
+ // we are right now startin at 0,0 not at the wxWindow's origin, so most of the calculations
+ // int dc are already corect
+ // just to make sure :
dc->m_macLocalOrigin.x = 0 ;
dc->m_macLocalOrigin.y = 0 ;
+ wxSize size = m_window->GetSize() ;
+ dc->SetClippingRegion( 0 , 0 , size.x , size.y ) ;
}
void wxOverlayImpl::EndDrawing( wxWindowDC* dc)
{
+ delete dc->m_graphicContext ;
+ dc->m_graphicContext = NULL ;
+
}
void wxOverlayImpl::Clear(wxWindowDC* dc)
{
wxASSERT_MSG( IsOk() , _("You cannot Clear an overlay that is not inited") );
- delete dc->m_graphicContext ;
- dc->m_graphicContext = NULL ;
-
- Reset();
+ CGRect box = CGRectMake( m_x - 1, m_y - 1 , m_width + 2 , m_height + 2 );
+ CGContextClearRect( m_overlayContext, box );
}
void wxOverlayImpl::Reset()
wxASSERT_MSG( err == noErr , _("Couldn't end the context on the overlay window") );
m_overlayContext = NULL ;
- }
+ }
// todo : don't dispose, only hide and reposition on next run
if (m_overlayWindow)
{
- RemoveEventHandler( m_overlayParentHandler ) ;
- m_overlayParentHandler = NULL;
- RemoveEventHandler( m_overlayHandler ) ;
- m_overlayHandler = NULL;
DisposeWindow(m_overlayWindow);
m_overlayWindow = NULL ;
}
//
//
-#else
+#else // ie not wxMAC_USE_CORE_GRAPHICS
class wxOverlayImpl
{
int m_y ;
int m_width ;
int m_height ;
+// this is to enable wxMOTIF and UNIV to compile....
+// currently (10 oct 06) we don't use m_window
+// ce - how do we fix this
+#if defined(__WXGTK__) || defined(__WXMSW__)
+//
wxWindow* m_window ;
+#endif
} ;
wxOverlayImpl::wxOverlayImpl()
{
- m_window = NULL ;
+#if defined(__WXGTK__) || defined(__WXMSW__)
+ m_window = NULL ;
+#endif
m_x = m_y = m_width = m_height = 0 ;
}
#if defined(__WXGTK__)
m_window = dc->m_owner;
#else
+ #if defined (__WXMSW__)
m_window = dc->GetWindow();
+ #endif // __WXMSW__
+
#endif
wxMemoryDC dcMem ;
m_bmpSaved.Create( width, height );