X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e73ae7474c13fe7c412b363d6824700b3654dd4b..419c6f4046799f604a61192dbca9747a839b0a19:/src/cocoa/window.mm diff --git a/src/cocoa/window.mm b/src/cocoa/window.mm index 1e4fd289db..00f89e22d1 100644 --- a/src/cocoa/window.mm +++ b/src/cocoa/window.mm @@ -25,6 +25,8 @@ #import #import #import +#import +#import // Turn this on to paint green over the dummy views for debugging #undef WXCOCOA_FILL_DUMMY_VIEW @@ -60,14 +62,14 @@ private: }; // ======================================================================== -// wxWindowCocoaScroller +// wxWindowCocoaScrollView // ======================================================================== -class wxWindowCocoaScroller: protected wxCocoaNSView +class wxWindowCocoaScrollView: protected wxCocoaNSView { - DECLARE_NO_COPY_CLASS(wxWindowCocoaScroller) + DECLARE_NO_COPY_CLASS(wxWindowCocoaScrollView) public: - wxWindowCocoaScroller(wxWindow *owner); - virtual ~wxWindowCocoaScroller(); + wxWindowCocoaScrollView(wxWindow *owner); + virtual ~wxWindowCocoaScrollView(); inline WX_NSScrollView GetNSScrollView() { return m_cocoaNSScrollView; } void ClientSizeToSize(int &width, int &height); void DoGetClientSize(int *x, int *y) const; @@ -78,7 +80,7 @@ protected: WX_NSScrollView m_cocoaNSScrollView; virtual void Cocoa_FrameChanged(void); private: - wxWindowCocoaScroller(); + wxWindowCocoaScrollView(); }; // ======================================================================== @@ -151,9 +153,9 @@ bool wxWindowCocoaHider::Cocoa_drawRect(const NSRect& rect) @end // ======================================================================== -// wxWindowCocoaScroller +// wxWindowCocoaScrollView // ======================================================================== -wxWindowCocoaScroller::wxWindowCocoaScroller(wxWindow *owner) +wxWindowCocoaScrollView::wxWindowCocoaScrollView(wxWindow *owner) : m_owner(owner) { wxAutoNSAutoreleasePool pool; @@ -176,7 +178,7 @@ wxWindowCocoaScroller::wxWindowCocoaScroller(wxWindow *owner) Encapsulate(); } -void wxWindowCocoaScroller::Encapsulate() +void wxWindowCocoaScrollView::Encapsulate() { // Set the scroll view autoresizingMask to match the current NSView [m_cocoaNSScrollView setAutoresizingMask: [m_owner->GetNSView() autoresizingMask]]; @@ -190,7 +192,7 @@ void wxWindowCocoaScroller::Encapsulate() // Now it's also retained by the NSScrollView } -void wxWindowCocoaScroller::Unencapsulate() +void wxWindowCocoaScrollView::Unencapsulate() { [m_cocoaNSScrollView setDocumentView: nil]; m_owner->CocoaReplaceView(m_cocoaNSScrollView, m_owner->GetNSView()); @@ -198,13 +200,13 @@ void wxWindowCocoaScroller::Unencapsulate() [m_owner->GetNSView() setAutoresizingMask: NSViewMinYMargin]; } -wxWindowCocoaScroller::~wxWindowCocoaScroller() +wxWindowCocoaScrollView::~wxWindowCocoaScrollView() { DisassociateNSView(m_cocoaNSScrollView); [m_cocoaNSScrollView release]; } -void wxWindowCocoaScroller::ClientSizeToSize(int &width, int &height) +void wxWindowCocoaScrollView::ClientSizeToSize(int &width, int &height) { NSSize frameSize = [NSScrollView frameSizeForContentSize: NSMakeSize(width,height) @@ -215,7 +217,7 @@ void wxWindowCocoaScroller::ClientSizeToSize(int &width, int &height) height = (int)frameSize.height; } -void wxWindowCocoaScroller::DoGetClientSize(int *x, int *y) const +void wxWindowCocoaScrollView::DoGetClientSize(int *x, int *y) const { NSSize nssize = [m_cocoaNSScrollView contentSize]; if(x) @@ -224,7 +226,7 @@ void wxWindowCocoaScroller::DoGetClientSize(int *x, int *y) const *y = (int)nssize.height; } -void wxWindowCocoaScroller::Cocoa_FrameChanged(void) +void wxWindowCocoaScrollView::Cocoa_FrameChanged(void) { wxLogTrace(wxTRACE_COCOA,wxT("Cocoa_FrameChanged")); wxSizeEvent event(m_owner->GetSize(), m_owner->GetId()); @@ -252,7 +254,7 @@ void wxWindowCocoa::Init() { m_cocoaNSView = NULL; m_cocoaHider = NULL; - m_cocoaScroller = NULL; + m_wxCocoaScrollView = NULL; m_isBeingDeleted = FALSE; m_isInPaint = FALSE; m_shouldBeEnabled = true; @@ -294,7 +296,7 @@ wxWindow::~wxWindow() if(m_parent && m_parent->GetNSView()==[GetNSViewForSuperview() superview]) CocoaRemoveFromParent(); delete m_cocoaHider; - delete m_cocoaScroller; + delete m_wxCocoaScrollView; if(m_cocoaNSView) SendDestroyEvent(); SetNSView(NULL); @@ -330,15 +332,15 @@ WX_NSView wxWindowCocoa::GetNSViewForSuperview() const { return m_cocoaHider ? m_cocoaHider->GetNSView() - : m_cocoaScroller - ? m_cocoaScroller->GetNSScrollView() + : m_wxCocoaScrollView + ? m_wxCocoaScrollView->GetNSScrollView() : m_cocoaNSView; } WX_NSView wxWindowCocoa::GetNSViewForHiding() const { - return m_cocoaScroller - ? m_cocoaScroller->GetNSScrollView() + return m_wxCocoaScrollView + ? m_wxCocoaScrollView->GetNSScrollView() : m_cocoaNSView; } @@ -706,14 +708,8 @@ void wxWindow::Refresh(bool eraseBack, const wxRect *rect) void wxWindow::SetFocus() { -#ifdef __WXDEBUG__ - bool bOK = -#endif - [GetNSView() lockFocusIfCanDraw]; - - //Note that the normal lockFocus works on hidden and minimized windows - //and has no return value - which probably isn't what we want - wxASSERT(bOK); + if([GetNSView() acceptsFirstResponder]) + [[GetNSView() window] makeFirstResponder: GetNSView()]; } void wxWindow::DoCaptureMouse() @@ -742,8 +738,8 @@ void wxWindow::DoClientToScreen(int *x, int *y) const void wxWindow::DoGetClientSize(int *x, int *y) const { wxLogTrace(wxTRACE_COCOA,wxT("DoGetClientSize:")); - if(m_cocoaScroller) - m_cocoaScroller->DoGetClientSize(x,y); + if(m_wxCocoaScrollView) + m_wxCocoaScrollView->DoGetClientSize(x,y); else wxWindowCocoa::DoGetSize(x,y); } @@ -751,8 +747,8 @@ void wxWindow::DoGetClientSize(int *x, int *y) const void wxWindow::DoSetClientSize(int width, int height) { wxLogTrace(wxTRACE_COCOA_Window_Size,wxT("DoSetClientSize=(%d,%d)"),width,height); - if(m_cocoaScroller) - m_cocoaScroller->ClientSizeToSize(width,height); + if(m_wxCocoaScrollView) + m_wxCocoaScrollView->ClientSizeToSize(width,height); CocoaSetWxWindowSize(width,height); } @@ -812,9 +808,9 @@ void wxWindow::SetScrollPos(int orient, int pos, bool refresh) void wxWindow::CocoaCreateNSScrollView() { - if(!m_cocoaScroller) + if(!m_wxCocoaScrollView) { - m_cocoaScroller = new wxWindowCocoaScroller(this); + m_wxCocoaScrollView = new wxWindowCocoaScrollView(this); } } @@ -894,12 +890,30 @@ bool wxWindow::DoPopupMenu(wxMenu *menu, int x, int y) // Get the window with the focus wxWindow *wxWindowBase::DoFindFocus() { - wxCocoaNSView *win = wxCocoaNSView::GetFromCocoa([NSView focusView]); - - if (!win) + // Basically we are somewhat emulating the responder chain here except + // we are only loking for the first responder in the key window or + // upon failing to find one if the main window is different we look + // for the first responder in the main window. + + // Note that the firstResponder doesn't necessarily have to be an + // NSView but wxCocoaNSView::GetFromCocoa() will simply return + // NULL unless it finds its argument in its hash map. + + wxCocoaNSView *win; + + NSWindow *keyWindow = [[NSApplication sharedApplication] keyWindow]; + win = wxCocoaNSView::GetFromCocoa([keyWindow firstResponder]); + if(win) + return win->GetWxWindow(); + + NSWindow *mainWindow = [[NSApplication sharedApplication] keyWindow]; + if(mainWindow == keyWindow) return NULL; - - return win->GetWxWindow(); + win = wxCocoaNSView::GetFromCocoa([mainWindow firstResponder]); + if(win) + return win->GetWxWindow(); + + return NULL; } /* static */ wxWindow *wxWindowBase::GetCapture()