going private with userpane info

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@67243 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Stefan Csomor
2011-03-19 08:36:23 +00:00
parent 0a761908f2
commit d15694e8ca
35 changed files with 264 additions and 182 deletions

View File

@@ -201,9 +201,9 @@ public:
bool MacIsReallyHilited() ; bool MacIsReallyHilited() ;
#if WXWIN_COMPATIBILITY_2_8 #if WXWIN_COMPATIBILITY_2_8
bool MacIsUserPane() { return m_macIsUserPane; } bool MacIsUserPane();
#endif #endif
bool MacIsUserPane() const { return m_macIsUserPane; } bool MacIsUserPane() const;
virtual bool MacSetupCursor( const wxPoint& pt ) ; virtual bool MacSetupCursor( const wxPoint& pt ) ;
@@ -246,9 +246,19 @@ public:
int& w, int& h , bool adjustForOrigin ) const ; int& w, int& h , bool adjustForOrigin ) const ;
// the 'true' OS level control for this wxWindow // the 'true' OS level control for this wxWindow
wxOSXWidgetImpl* GetPeer() const { return m_peer ; } wxOSXWidgetImpl* GetPeer() const;
// optimization to avoid creating a user pane in wxWindow::Create if we already know
// we will replace it with our own peer
void DontCreatePeer();
// sets the native implementation wrapper, can replace an existing peer, use peer = NULL to
// release existing peer
void SetPeer(wxOSXWidgetImpl* peer); void SetPeer(wxOSXWidgetImpl* peer);
// wraps the already existing peer with the wrapper
void SetWrappingPeer(wxOSXWidgetImpl* wrapper);
#if wxOSX_USE_COCOA_OR_IPHONE #if wxOSX_USE_COCOA_OR_IPHONE
// the NSView or NSWindow of this window: can be used for both child and // the NSView or NSWindow of this window: can be used for both child and
// non-owned windows // non-owned windows
@@ -289,9 +299,6 @@ protected:
mutable wxRegion m_cachedClippedRegion ; mutable wxRegion m_cachedClippedRegion ;
mutable wxRegion m_cachedClippedClientRegion ; mutable wxRegion m_cachedClippedClientRegion ;
// true if is is not a native control but a wxWindow control
bool m_macIsUserPane ;
// insets of the mac control from the wx top left corner // insets of the mac control from the wx top left corner
wxPoint m_macTopLeftInset ; wxPoint m_macTopLeftInset ;
wxPoint m_macBottomRightInset ; wxPoint m_macBottomRightInset ;

View File

@@ -406,7 +406,6 @@ bool wxWebKitCtrl::Create(wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
m_currentURL = strURL; m_currentURL = strURL;
//m_pageTitle = _("Untitled Page"); //m_pageTitle = _("Untitled Page");
@@ -427,6 +426,7 @@ bool wxWebKitCtrl::Create(wxWindow *parent,
} }
*/ */
// now create and attach WebKit view... // now create and attach WebKit view...
DontCreatePeer();
#ifdef __WXCOCOA__ #ifdef __WXCOCOA__
wxControl::Create(parent, m_windowID, pos, sizeInstance, style , validator , name); wxControl::Create(parent, m_windowID, pos, sizeInstance, style , validator , name);
SetSize(pos.x, pos.y, sizeInstance.x, sizeInstance.y); SetSize(pos.x, pos.y, sizeInstance.x, sizeInstance.y);
@@ -445,22 +445,24 @@ bool wxWebKitCtrl::Create(wxWindow *parent,
if(m_parent) m_parent->CocoaAddChild(this); if(m_parent) m_parent->CocoaAddChild(this);
SetInitialFrameRect(pos,sizeInstance); SetInitialFrameRect(pos,sizeInstance);
#else #else
m_macIsUserPane = false; DontCreatePeer();
wxControl::Create(parent, winID, pos, size, style , validator , name); wxControl::Create(parent, winID, pos, size, style , validator , name);
#if wxOSX_USE_CARBON #if wxOSX_USE_CARBON
SetPeer(new wxMacControl(this)); wxMacControl* peer = new wxMacControl(this);
WebInitForCarbon(); WebInitForCarbon();
HIWebViewCreate( GetPeer()->GetControlRefAddr() ); HIWebViewCreate( peer->GetControlRefAddr() );
m_webView = (WebView*) HIWebViewGetWebView( GetPeer()->GetControlRef() ); m_webView = (WebView*) HIWebViewGetWebView( peer->GetControlRef() );
#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_3 #if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_3
if ( UMAGetSystemVersion() >= 0x1030 ) if ( UMAGetSystemVersion() >= 0x1030 )
HIViewChangeFeatures( GetPeer()->GetControlRef() , kHIViewIsOpaque , 0 ) ; HIViewChangeFeatures( peer->GetControlRef() , kHIViewIsOpaque , 0 ) ;
#endif #endif
InstallControlEventHandler( GetPeer()->GetControlRef() , GetwxWebKitCtrlEventHandlerUPP(), InstallControlEventHandler( peer->GetControlRef() , GetwxWebKitCtrlEventHandlerUPP(),
GetEventTypeCount(eventList), eventList, this, GetEventTypeCount(eventList), eventList, this,
(EventHandlerRef *)&m_webKitCtrlEventHandler); (EventHandlerRef *)&m_webKitCtrlEventHandler);
SetPeer(peer);
#else #else
NSRect r = wxOSXGetFrameForControl( this, pos , size ) ; NSRect r = wxOSXGetFrameForControl( this, pos , size ) ;
m_webView = [[WebView alloc] initWithFrame:r frameName:@"webkitFrame" groupName:@"webkitGroup"]; m_webView = [[WebView alloc] initWithFrame:r frameName:@"webkitFrame" groupName:@"webkitGroup"];

View File

@@ -33,7 +33,7 @@ bool wxBitmapButton::Create( wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxBitmapButtonBase::Create(parent, id, pos, size, style, if ( !wxBitmapButtonBase::Create(parent, id, pos, size, style,
validator, name) ) validator, name) )

View File

@@ -56,6 +56,8 @@ bool wxButton::Create(wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
DontCreatePeer();
m_marginX = m_marginX =
m_marginY = 0; m_marginY = 0;
@@ -81,7 +83,6 @@ bool wxButton::Create(wxWindow *parent,
: labelOrig; : labelOrig;
} }
m_macIsUserPane = false ;
if ( !wxButtonBase::Create(parent, id, pos, size, style, validator, name) ) if ( !wxButtonBase::Create(parent, id, pos, size, style, validator, name) )
return false; return false;
@@ -203,8 +204,7 @@ bool wxButton::OSXHandleClicked( double WXUNUSED(timestampsec) )
bool wxDisclosureTriangle::Create(wxWindow *parent, wxWindowID id, const wxString& label, bool wxDisclosureTriangle::Create(wxWindow *parent, wxWindowID id, const wxString& label,
const wxPoint& pos, const wxSize& size, long style,const wxValidator& validator, const wxString& name ) const wxPoint& pos, const wxSize& size, long style,const wxValidator& validator, const wxString& name )
{ {
m_macIsUserPane = false ; DontCreatePeer();
if ( !wxControl::Create(parent, id, pos, size, style, validator, name) ) if ( !wxControl::Create(parent, id, pos, size, style, validator, name) )
return false; return false;

View File

@@ -341,7 +341,7 @@ bool wxComboBox::Create(wxWindow *parent, wxWindowID id,
m_text = NULL; m_text = NULL;
m_choice = NULL; m_choice = NULL;
#if USE_HICOMBOBOX #if USE_HICOMBOBOX
m_macIsUserPane = false; DontCreatePeer();
#endif #endif
if ( !wxControl::Create(parent, id, wxDefaultPosition, wxDefaultSize, style , if ( !wxControl::Create(parent, id, wxDefaultPosition, wxDefaultSize, style ,
wxDefaultValidator, name) ) wxDefaultValidator, name) )

View File

@@ -51,7 +51,6 @@ bool wxFrame::Create(wxWindow *parent,
long style, long style,
const wxString& name) const wxString& name)
{ {
if ( !wxTopLevelWindow::Create(parent, id, title, pos, size, style, name) ) if ( !wxTopLevelWindow::Create(parent, id, title, pos, size, style, name) )
return false; return false;

View File

@@ -655,8 +655,6 @@ bool wxListCtrl::Create(wxWindow *parent,
&& (wxSystemOptions::GetOptionInt( wxMAC_ALWAYS_USE_GENERIC_LISTCTRL ) == 1)) || && (wxSystemOptions::GetOptionInt( wxMAC_ALWAYS_USE_GENERIC_LISTCTRL ) == 1)) ||
(style & wxLC_ICON) || (style & wxLC_SMALL_ICON) || (style & wxLC_LIST) ) (style & wxLC_ICON) || (style & wxLC_SMALL_ICON) || (style & wxLC_LIST) )
{ {
m_macIsUserPane = true;
long paneStyle = style; long paneStyle = style;
paneStyle &= ~wxSIMPLE_BORDER; paneStyle &= ~wxSIMPLE_BORDER;
paneStyle &= ~wxDOUBLE_BORDER; paneStyle &= ~wxDOUBLE_BORDER;
@@ -674,7 +672,7 @@ bool wxListCtrl::Create(wxWindow *parent,
else else
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxWindow::Create(parent, id, pos, size, style & ~(wxHSCROLL | wxVSCROLL), name) ) if ( !wxWindow::Create(parent, id, pos, size, style & ~(wxHSCROLL | wxVSCROLL), name) )
return false; return false;
m_dbImpl = new wxMacDataBrowserListCtrlControl( this, pos, size, style ); m_dbImpl = new wxMacDataBrowserListCtrlControl( this, pos, size, style );

View File

@@ -52,6 +52,7 @@ wxSize wxStaticText::DoGetBestSize() const
GetPeer()->SetData( kControlStaticTextIsMultilineTag, (Boolean)0 ); GetPeer()->SetData( kControlStaticTextIsMultilineTag, (Boolean)0 );
GetPeer()->GetBestRect( &bestsize ) ; GetPeer()->GetBestRect( &bestsize ) ;
GetPeer()->SetData( kControlStaticTextIsMultilineTag, former ); GetPeer()->SetData( kControlStaticTextIsMultilineTag, former );
if ( !EmptyRect( &bestsize ) ) if ( !EmptyRect( &bestsize ) )
{ {
bounds.h = bestsize.right - bestsize.left ; bounds.h = bestsize.right - bestsize.left ;

View File

@@ -836,7 +836,7 @@ wxWidgetImplType* wxWidgetImpl::CreateUserPane( wxWindowMac* wxpeer,
{ {
OSStatus err = noErr; OSStatus err = noErr;
Rect bounds = wxMacGetBoundsForControl( wxpeer , pos , size ) ; Rect bounds = wxMacGetBoundsForControl( wxpeer , pos , size ) ;
wxMacControl* c = new wxMacControl(wxpeer) ; wxMacControl* c = new wxMacControl(wxpeer, false, true) ;
UInt32 features = 0 UInt32 features = 0
| kControlSupportsEmbedding | kControlSupportsEmbedding
| kControlSupportsLiveFeedback | kControlSupportsLiveFeedback

View File

@@ -28,7 +28,7 @@ bool wxCheckBox::Create(wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
m_macIsUserPane = false ; DontCreatePeer();
if ( !wxCheckBoxBase::Create(parent, id, pos, size, style, validator, name) ) if ( !wxCheckBoxBase::Create(parent, id, pos, size, style, validator, name) )
return false; return false;

View File

@@ -57,7 +57,6 @@ bool wxCheckListBox::Create(
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false;
wxASSERT_MSG( !(style & wxLB_MULTIPLE) || !(style & wxLB_EXTENDED), wxASSERT_MSG( !(style & wxLB_MULTIPLE) || !(style & wxLB_EXTENDED),
wxT("only one of listbox selection modes can be specified") ); wxT("only one of listbox selection modes can be specified") );

View File

@@ -66,7 +66,7 @@ bool wxChoice::Create(wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxChoiceBase::Create( parent, id, pos, size, style, validator, name ) ) if ( !wxChoiceBase::Create( parent, id, pos, size, style, validator, name ) )
return false; return false;

View File

@@ -260,7 +260,7 @@ bool wxGLCanvas::Create(wxWindow *parent,
if ( !m_glFormat ) if ( !m_glFormat )
return false; return false;
// m_macIsUserPane = false ; // DontCreatePeer();
if ( !wxWindow::Create(parent, id, pos, size, style, name) ) if ( !wxWindow::Create(parent, id, pos, size, style, name) )
return false; return false;

View File

@@ -988,7 +988,7 @@ void wxWidgetCocoaImpl::mouseEvent(WX_NSEvent event, WXWidget slf, void *_cmd)
if ( !DoHandleMouseEvent(event) ) if ( !DoHandleMouseEvent(event) )
{ {
// for plain NSView mouse events would propagate to parents otherwise // for plain NSView mouse events would propagate to parents otherwise
if (!m_wxPeer->MacIsUserPane()) if (!IsUserPane())
{ {
wxOSX_EventHandlerPtr superimpl = (wxOSX_EventHandlerPtr) [[slf superclass] instanceMethodForSelector:(SEL)_cmd]; wxOSX_EventHandlerPtr superimpl = (wxOSX_EventHandlerPtr) [[slf superclass] instanceMethodForSelector:(SEL)_cmd];
superimpl(slf, (SEL)_cmd, event); superimpl(slf, (SEL)_cmd, event);
@@ -1062,7 +1062,7 @@ bool wxWidgetCocoaImpl::performKeyEquivalent(WX_NSEvent event, WXWidget slf, voi
bool wxWidgetCocoaImpl::acceptsFirstResponder(WXWidget slf, void *_cmd) bool wxWidgetCocoaImpl::acceptsFirstResponder(WXWidget slf, void *_cmd)
{ {
if ( m_wxPeer->MacIsUserPane() ) if ( IsUserPane() )
return m_wxPeer->AcceptsFocus(); return m_wxPeer->AcceptsFocus();
else else
{ {
@@ -2095,7 +2095,7 @@ bool wxWidgetCocoaImpl::DoHandleKeyEvent(NSEvent *event)
// this will fire higher level events, like insertText, to help // this will fire higher level events, like insertText, to help
// us handle EVT_CHAR, etc. // us handle EVT_CHAR, etc.
if ( m_wxPeer->MacIsUserPane() && [event type] == NSKeyDown) if ( IsUserPane() && [event type] == NSKeyDown)
{ {
if ( !result ) if ( !result )
{ {
@@ -2219,7 +2219,7 @@ wxWidgetImpl* wxWidgetImpl::CreateUserPane( wxWindowMac* wxpeer, wxWindowMac* WX
[v registerForDraggedTypes:[NSArray arrayWithObjects: [v registerForDraggedTypes:[NSArray arrayWithObjects:
NSStringPboardType, NSFilenamesPboardType, NSTIFFPboardType, NSPICTPboardType, NSPDFPboardType, nil]]; NSStringPboardType, NSFilenamesPboardType, NSTIFFPboardType, NSPICTPboardType, NSPDFPboardType, nil]];
wxWidgetCocoaImpl* c = new wxWidgetCocoaImpl( wxpeer, v ); wxWidgetCocoaImpl* c = new wxWidgetCocoaImpl( wxpeer, v, false, true );
return c; return c;
} }

View File

@@ -53,11 +53,11 @@ bool wxComboBox::Create(wxWindow *parent, wxWindowID id,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
DontCreatePeer();
m_text = NULL; m_text = NULL;
m_choice = NULL; m_choice = NULL;
m_macIsUserPane = false;
if ( !wxControl::Create( parent, id, pos, size, style, validator, name ) ) if ( !wxControl::Create( parent, id, pos, size, style, validator, name ) )
return false; return false;

View File

@@ -351,7 +351,6 @@ void wxDataViewCtrl::Init()
{ {
m_CustomRendererPtr = NULL; m_CustomRendererPtr = NULL;
m_Deleting = false; m_Deleting = false;
m_macIsUserPane = false;
m_cgContext = NULL; m_cgContext = NULL;
} }
@@ -363,6 +362,7 @@ bool wxDataViewCtrl::Create(wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
DontCreatePeer();
if (!(wxControl::Create(parent,id,pos,size,style,validator,name))) if (!(wxControl::Create(parent,id,pos,size,style,validator,name)))
return false; return false;
SetPeer(::CreateDataView(this,parent,id,pos,size,style,GetExtraStyle())); SetPeer(::CreateDataView(this,parent,id,pos,size,style,GetExtraStyle()));

View File

@@ -26,7 +26,7 @@ bool wxGauge::Create( wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxGaugeBase::Create( parent, id, range, pos, s, style & 0xE0FFFFFF, validator, name ) ) if ( !wxGaugeBase::Create( parent, id, range, pos, s, style & 0xE0FFFFFF, validator, name ) )
return false; return false;

View File

@@ -382,7 +382,7 @@ bool wxGLCanvas::Create(wxWindow *parent,
return false; return false;
*/ */
#if USE_SEPARATE_VIEW #if USE_SEPARATE_VIEW
m_macIsUserPane = false ; DontCreatePeer();
#endif #endif
if ( !wxWindow::Create(parent, id, pos, size, style, name) ) if ( !wxWindow::Create(parent, id, pos, size, style, name) )

View File

@@ -218,7 +218,7 @@ bool wxToolBar::Create(
long style, long style,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false ; DontCreatePeer();
if ( !wxToolBarBase::Create( parent, id, pos, size, style, wxDefaultValidator, name ) ) if ( !wxToolBarBase::Create( parent, id, pos, size, style, wxDefaultValidator, name ) )
return false; return false;

View File

@@ -797,7 +797,7 @@ wxWidgetImpl* wxWidgetImpl::CreateUserPane( wxWindowMac* wxpeer, wxWindowMac* WX
sv.clipsToBounds = YES; sv.clipsToBounds = YES;
sv.contentMode = UIViewContentModeRedraw; sv.contentMode = UIViewContentModeRedraw;
sv.clearsContextBeforeDrawing = NO; sv.clearsContextBeforeDrawing = NO;
wxWidgetIPhoneImpl* c = new wxWidgetIPhoneImpl( wxpeer, v ); wxWidgetIPhoneImpl* c = new wxWidgetIPhoneImpl( wxpeer, v, false, true );
return c; return c;
} }

View File

@@ -71,8 +71,8 @@ bool wxListBox::Create(
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
DontCreatePeer();
m_blockEvents = false; m_blockEvents = false;
m_macIsUserPane = false;
wxASSERT_MSG( !(style & wxLB_MULTIPLE) || !(style & wxLB_EXTENDED), wxASSERT_MSG( !(style & wxLB_MULTIPLE) || !(style & wxLB_EXTENDED),
wxT("only a single listbox selection mode can be specified") ); wxT("only a single listbox selection mode can be specified") );
@@ -327,7 +327,6 @@ int wxListBox::FindString(const wxString& s, bool bCase) const
void wxListBox::OnItemInserted(unsigned int WXUNUSED(pos)) void wxListBox::OnItemInserted(unsigned int WXUNUSED(pos))
{ {
} }
int wxListBox::DoInsertItems(const wxArrayStringsAdapter& items, int wxListBox::DoInsertItems(const wxArrayStringsAdapter& items,

View File

@@ -45,7 +45,7 @@ bool wxNotebook::Create( wxWindow *parent,
long style, long style,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false ; DontCreatePeer();
if (! (style & wxBK_ALIGN_MASK)) if (! (style & wxBK_ALIGN_MASK))
style |= wxBK_TOP; style |= wxBK_TOP;

View File

@@ -98,14 +98,13 @@ bool wxRadioBox::Create( wxWindow *parent,
int majorDim, long style, int majorDim, long style,
const wxValidator& val, const wxString& name ) const wxValidator& val, const wxString& name )
{ {
m_macIsUserPane = false ; DontCreatePeer();
if ( !wxControl::Create( parent, id, pos, size, style, val, name ) ) if ( !wxControl::Create( parent, id, pos, size, style, val, name ) )
return false; return false;
int i; // during construction we must keep this at 0, otherwise GetBestSize fails
m_noItems = 0;
m_noItems = (unsigned int)n;
m_noRowsOrCols = majorDim; m_noRowsOrCols = majorDim;
m_radioButtonCycle = NULL; m_radioButtonCycle = NULL;
@@ -115,7 +114,7 @@ bool wxRadioBox::Create( wxWindow *parent,
SetPeer(wxWidgetImpl::CreateGroupBox( this, parent, id, label, pos, size, style, GetExtraStyle() )); SetPeer(wxWidgetImpl::CreateGroupBox( this, parent, id, label, pos, size, style, GetExtraStyle() ));
for (i = 0; i < n; i++) for (int i = 0; i < n; i++)
{ {
wxRadioButton *radBtn = new wxRadioButton( wxRadioButton *radBtn = new wxRadioButton(
this, this,
@@ -130,7 +129,13 @@ bool wxRadioBox::Create( wxWindow *parent,
// m_radioButtonCycle = radBtn->AddInCycle( m_radioButtonCycle ); // m_radioButtonCycle = radBtn->AddInCycle( m_radioButtonCycle );
} }
// as all radiobuttons have been set-up, set the correct dimensions
m_noItems = (unsigned int)n;
SetMajorDim( majorDim == 0 ? n : majorDim, style );
SetSelection( 0 ); SetSelection( 0 );
InvalidateBestSize();
SetInitialSize( size );
MacPostControlCreate( pos, size ); MacPostControlCreate( pos, size );
return true; return true;

View File

@@ -25,7 +25,7 @@ bool wxRadioButton::Create( wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxControl::Create( parent, id, pos, size, style, validator, name ) ) if ( !wxControl::Create( parent, id, pos, size, style, validator, name ) )
return false; return false;

View File

@@ -35,7 +35,7 @@ bool wxScrollBar::Create( wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxControl::Create( parent, id, pos, size, style, validator, name ) ) if ( !wxControl::Create( parent, id, pos, size, style, validator, name ) )
return false; return false;

View File

@@ -58,7 +58,7 @@ bool wxSlider::Create(wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
m_macIsUserPane = false; DontCreatePeer();
m_macMinimumStatic = NULL; m_macMinimumStatic = NULL;
m_macMaximumStatic = NULL; m_macMaximumStatic = NULL;

View File

@@ -26,8 +26,7 @@ bool wxSpinButton::Create( wxWindow *parent,
wxWindowID id, const wxPoint& pos, const wxSize& size, wxWindowID id, const wxPoint& pos, const wxSize& size,
long style, const wxString& name ) long style, const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxSpinButtonBase::Create( parent, id, pos, size, style, wxDefaultValidator, name ) ) if ( !wxSpinButtonBase::Create( parent, id, pos, size, style, wxDefaultValidator, name ) )
return false; return false;

View File

@@ -229,7 +229,8 @@ bool wxSpinCtrl::Create(wxWindow *parent,
int initial, int initial,
const wxString& name) const wxString& name)
{ {
m_macIsUserPane = true; DontCreatePeer();
if ( !wxControl::Create(parent, id, pos, size, style, if ( !wxControl::Create(parent, id, pos, size, style,
wxDefaultValidator, name) ) wxDefaultValidator, name) )
{ {

View File

@@ -168,7 +168,7 @@ bool wxSearchCtrl::Create(wxWindow *parent, wxWindowID id,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
m_macIsUserPane = false ; DontCreatePeer();
m_editable = true ; m_editable = true ;
if ( ! (style & wxNO_BORDER) ) if ( ! (style & wxNO_BORDER) )

View File

@@ -24,7 +24,7 @@ bool wxStaticBox::Create( wxWindow *parent,
long style, long style,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxControl::Create( parent, id, pos, size, style, wxDefaultValidator, name ) ) if ( !wxControl::Create( parent, id, pos, size, style, wxDefaultValidator, name ) )
return false; return false;

View File

@@ -48,7 +48,7 @@ bool wxStaticLine::Create( wxWindow *parent,
long style, long style,
const wxString &name) const wxString &name)
{ {
m_macIsUserPane = false ; DontCreatePeer();
if ( !wxStaticLineBase::Create(parent, id, pos, size, if ( !wxStaticLineBase::Create(parent, id, pos, size,
style, wxDefaultValidator, name) ) style, wxDefaultValidator, name) )

View File

@@ -36,7 +36,7 @@ bool wxStaticText::Create( wxWindow *parent,
long style, long style,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false; DontCreatePeer();
if ( !wxControl::Create( parent, id, pos, size, style, wxDefaultValidator, name ) ) if ( !wxControl::Create( parent, id, pos, size, style, wxDefaultValidator, name ) )
return false; return false;

View File

@@ -95,7 +95,7 @@ bool wxTextCtrl::Create( wxWindow *parent,
const wxValidator& validator, const wxValidator& validator,
const wxString& name ) const wxString& name )
{ {
m_macIsUserPane = false ; DontCreatePeer();
m_editable = true ; m_editable = true ;
if ( ! (style & wxNO_BORDER) ) if ( ! (style & wxNO_BORDER) )

View File

@@ -47,7 +47,7 @@ bool wxToggleButton::Create(wxWindow *parent, wxWindowID id,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
m_macIsUserPane = FALSE ; DontCreatePeer();
if ( !wxControl::Create(parent, id, pos, size, style, validator, name) ) if ( !wxControl::Create(parent, id, pos, size, style, validator, name) )
return false; return false;
@@ -111,7 +111,7 @@ bool wxBitmapToggleButton::Create(wxWindow *parent, wxWindowID id,
const wxValidator& validator, const wxValidator& validator,
const wxString& name) const wxString& name)
{ {
m_macIsUserPane = FALSE ; DontCreatePeer();
m_bitmap = label; m_bitmap = label;

View File

@@ -87,6 +87,8 @@ END_EVENT_TABLE()
#define wxMAC_DEBUG_REDRAW 0 #define wxMAC_DEBUG_REDRAW 0
#endif #endif
wxWidgetImplType* kOSXNoWidgetImpl = (wxWidgetImplType*) -1L;
// =========================================================================== // ===========================================================================
// implementation // implementation
// =========================================================================== // ===========================================================================
@@ -202,7 +204,6 @@ void wxWindowMac::Init()
m_vScrollBarAlwaysShown = false; m_vScrollBarAlwaysShown = false;
m_growBox = NULL ; m_growBox = NULL ;
m_macIsUserPane = true;
m_clipChildren = false ; m_clipChildren = false ;
m_cachedClippedRectValid = false ; m_cachedClippedRectValid = false ;
m_isNativeWindowWrapper = false; m_isNativeWindowWrapper = false;
@@ -258,21 +259,88 @@ wxWindowMac::~wxWindowMac()
wxDELETE(m_dropTarget); wxDELETE(m_dropTarget);
#endif #endif
delete m_peer ; delete GetPeer() ;
} }
WXWidget wxWindowMac::GetHandle() const WXWidget wxWindowMac::GetHandle() const
{ {
if ( m_peer ) if ( GetPeer() )
return (WXWidget) m_peer->GetWXWidget() ; return (WXWidget) GetPeer()->GetWXWidget() ;
return NULL; return NULL;
} }
wxOSXWidgetImpl* wxWindowMac::GetPeer() const
{
return m_peer == kOSXNoWidgetImpl ? NULL : m_peer ;
}
void wxWindowMac::DontCreatePeer()
{
m_peer = kOSXNoWidgetImpl;
}
void wxWindowMac::SetWrappingPeer(wxOSXWidgetImpl* wrapper)
{
wxOSXWidgetImpl* inner = GetPeer();
wxASSERT_MSG( inner != NULL && inner->IsOk(), "missing or incomplete inner peer" );
wxASSERT_MSG( wrapper != NULL && wrapper->IsOk(), "missing or incomplete wrapper" );
if ( !(inner != NULL && inner->IsOk() && wrapper != NULL && wrapper->IsOk()) )
return;
inner->RemoveFromParent();
wrapper->InstallEventHandler();
wrapper->Embed(inner);
m_peer = wrapper;
}
void wxWindowMac::SetPeer(wxOSXWidgetImpl* peer) void wxWindowMac::SetPeer(wxOSXWidgetImpl* peer)
{ {
if ( GetPeer() )
{
GetPeer()->RemoveFromParent();
wxDELETE(m_peer); wxDELETE(m_peer);
// todo event check handlers }
m_peer = peer; m_peer = peer;
if ( GetPeer() && !GetPeer()->IsRootControl())
{
wxASSERT_MSG( GetPeer()->IsOk() , wxT("The native control must exist already") ) ;
if (!GetParent()->GetChildren().Find((wxWindow*)this))
GetParent()->AddChild( this );
GetPeer()->InstallEventHandler();
GetPeer()->Embed(GetParent()->GetPeer());
GetParent()->MacChildAdded() ;
// adjust font, controlsize etc
DoSetWindowVariant( m_windowVariant ) ;
GetPeer()->SetLabel( wxStripMenuCodes(m_label, wxStrip_Mnemonics), GetFont().GetEncoding() ) ;
// for controls we want to use best size for wxDefaultSize params )
if ( !GetPeer()->IsUserPane() )
SetInitialSize(GetMinSize());
SetCursor( *wxSTANDARD_CURSOR ) ;
}
}
#if WXWIN_COMPATIBILITY_2_8
bool wxWindowMac::MacIsUserPane()
{
return GetPeer() == NULL || GetPeer()->IsUserPane();
}
#endif
bool wxWindowMac::MacIsUserPane() const
{
return GetPeer() == NULL || GetPeer()->IsUserPane();
} }
// --------------------------------------------------------------------------- // ---------------------------------------------------------------------------
@@ -311,9 +379,9 @@ bool wxWindowMac::Create(wxWindowMac *parent,
m_windowVariant = parent->GetWindowVariant() ; m_windowVariant = parent->GetWindowVariant() ;
if ( m_macIsUserPane ) if ( m_peer != kOSXNoWidgetImpl )
{ {
m_peer = wxWidgetImpl::CreateUserPane( this, parent, id, pos, size , style, GetExtraStyle() ); SetPeer(wxWidgetImpl::CreateUserPane( this, parent, id, pos, size , style, GetExtraStyle() ));
MacPostControlCreate(pos, size) ; MacPostControlCreate(pos, size) ;
} }
@@ -350,39 +418,43 @@ void wxWindowMac::MacChildAdded()
void wxWindowMac::MacPostControlCreate(const wxPoint& WXUNUSED(pos), const wxSize& size) void wxWindowMac::MacPostControlCreate(const wxPoint& WXUNUSED(pos), const wxSize& size)
{ {
wxASSERT_MSG( m_peer != NULL && m_peer->IsOk() , wxT("No valid mac control") ) ; // todo remove if refactoring works correctly
#if 0
wxASSERT_MSG( GetPeer() != NULL && GetPeer()->IsOk() , wxT("No valid mac control") ) ;
if (!GetParent()->GetChildren().Find((wxWindow*)this))
GetParent()->AddChild( this ); GetParent()->AddChild( this );
m_peer->InstallEventHandler(); GetPeer()->InstallEventHandler();
m_peer->Embed(GetParent()->GetPeer()); GetPeer()->Embed(GetParent()->GetPeer());
GetParent()->MacChildAdded() ; GetParent()->MacChildAdded() ;
// adjust font, controlsize etc // adjust font, controlsize etc
DoSetWindowVariant( m_windowVariant ) ; DoSetWindowVariant( m_windowVariant ) ;
m_peer->SetLabel( wxStripMenuCodes(m_label, wxStrip_Mnemonics), GetFont().GetEncoding() ) ; GetPeer()->SetLabel( wxStripMenuCodes(m_label, wxStrip_Mnemonics), GetFont().GetEncoding() ) ;
// for controls we want to use best size for wxDefaultSize params ) // for controls we want to use best size for wxDefaultSize params )
if ( !m_macIsUserPane ) if ( !GetPeer()->IsUserPane() )
SetInitialSize(size); SetInitialSize(size);
SetCursor( *wxSTANDARD_CURSOR ) ; SetCursor( *wxSTANDARD_CURSOR ) ;
#endif
} }
void wxWindowMac::DoSetWindowVariant( wxWindowVariant variant ) void wxWindowMac::DoSetWindowVariant( wxWindowVariant variant )
{ {
// Don't assert, in case we set the window variant before // Don't assert, in case we set the window variant before
// the window is created // the window is created
// wxASSERT( m_peer->Ok() ) ; // wxASSERT( GetPeer()->Ok() ) ;
m_windowVariant = variant ; m_windowVariant = variant ;
if (m_peer == NULL || !m_peer->IsOk()) if (GetPeer() == NULL || !GetPeer()->IsOk())
return; return;
m_peer->SetControlSize( variant ); GetPeer()->SetControlSize( variant );
#if wxOSX_USE_CARBON #if wxOSX_USE_CARBON
ControlSize size ; ControlSize size ;
@@ -413,7 +485,7 @@ void wxWindowMac::DoSetWindowVariant( wxWindowVariant variant )
wxFAIL_MSG(wxT("unexpected window variant")); wxFAIL_MSG(wxT("unexpected window variant"));
break ; break ;
} }
m_peer->SetData<ControlSize>(kControlEntireControl, kControlSizeTag, &size ) ; GetPeer()->SetData<ControlSize>(kControlEntireControl, kControlSizeTag, &size ) ;
#endif #endif
@@ -447,8 +519,8 @@ void wxWindowMac::DoSetWindowVariant( wxWindowVariant variant )
void wxWindowMac::MacUpdateControlFont() void wxWindowMac::MacUpdateControlFont()
{ {
if ( m_peer ) if ( GetPeer() )
m_peer->SetFont( GetFont() , GetForegroundColour() , GetWindowStyle() ) ; GetPeer()->SetFont( GetFont() , GetForegroundColour() , GetWindowStyle() ) ;
// do not trigger refreshes upon invisible and possible partly created objects // do not trigger refreshes upon invisible and possible partly created objects
if ( IsShownOnScreen() ) if ( IsShownOnScreen() )
@@ -479,8 +551,8 @@ bool wxWindowMac::SetBackgroundStyle(wxBackgroundStyle style)
if ( !wxWindowBase::SetBackgroundStyle(style) ) if ( !wxWindowBase::SetBackgroundStyle(style) )
return false; return false;
if ( m_peer ) if ( GetPeer() )
m_peer->SetBackgroundStyle(style); GetPeer()->SetBackgroundStyle(style);
return true; return true;
} }
@@ -497,8 +569,8 @@ bool wxWindowMac::SetBackgroundColour(const wxColour& col )
if ( !wxWindowBase::SetBackgroundColour(col) && m_hasBgCol ) if ( !wxWindowBase::SetBackgroundColour(col) && m_hasBgCol )
return false ; return false ;
if ( m_peer ) if ( GetPeer() )
m_peer->SetBackgroundColour( col ) ; GetPeer()->SetBackgroundColour( col ) ;
return true ; return true ;
} }
@@ -526,13 +598,13 @@ void wxWindowMac::SetFocus()
if ( former == this ) if ( former == this )
return ; return ;
m_peer->SetFocus() ; GetPeer()->SetFocus() ;
} }
void wxWindowMac::DoCaptureMouse() void wxWindowMac::DoCaptureMouse()
{ {
wxApp::s_captureWindow = (wxWindow*) this ; wxApp::s_captureWindow = (wxWindow*) this ;
m_peer->CaptureMouse() ; GetPeer()->CaptureMouse() ;
} }
wxWindow * wxWindowBase::GetCapture() wxWindow * wxWindowBase::GetCapture()
@@ -544,7 +616,7 @@ void wxWindowMac::DoReleaseMouse()
{ {
wxApp::s_captureWindow = NULL ; wxApp::s_captureWindow = NULL ;
m_peer->ReleaseMouse() ; GetPeer()->ReleaseMouse() ;
} }
#if wxUSE_DRAG_AND_DROP #if wxUSE_DRAG_AND_DROP
@@ -605,7 +677,7 @@ bool wxWindowMac::MacGetBoundsForControl(
void wxWindowMac::DoGetSize(int *x, int *y) const void wxWindowMac::DoGetSize(int *x, int *y) const
{ {
int width, height; int width, height;
m_peer->GetSize( width, height ); GetPeer()->GetSize( width, height );
if (x) if (x)
*x = width + MacGetLeftBorderSize() + MacGetRightBorderSize() ; *x = width + MacGetLeftBorderSize() + MacGetRightBorderSize() ;
@@ -618,7 +690,7 @@ void wxWindowMac::DoGetPosition(int *x, int *y) const
{ {
int x1, y1; int x1, y1;
m_peer->GetPosition( x1, y1 ) ; GetPeer()->GetPosition( x1, y1 ) ;
// get the wx window position from the native one // get the wx window position from the native one
x1 -= MacGetLeftBorderSize() ; x1 -= MacGetLeftBorderSize() ;
@@ -703,7 +775,7 @@ void wxWindowMac::MacWindowToRootWindow( int *x , int *y ) const
{ {
pt.x -= MacGetLeftBorderSize() ; pt.x -= MacGetLeftBorderSize() ;
pt.y -= MacGetTopBorderSize() ; pt.y -= MacGetTopBorderSize() ;
wxWidgetImpl::Convert( &pt , m_peer , top->m_peer ) ; wxWidgetImpl::Convert( &pt , GetPeer() , top->GetPeer() ) ;
} }
} }
@@ -727,7 +799,7 @@ void wxWindowMac::MacRootWindowToWindow( int *x , int *y ) const
wxNonOwnedWindow* top = MacGetTopLevelWindow(); wxNonOwnedWindow* top = MacGetTopLevelWindow();
if (top) if (top)
{ {
wxWidgetImpl::Convert( &pt , top->m_peer , m_peer ) ; wxWidgetImpl::Convert( &pt , top->GetPeer() , GetPeer() ) ;
pt.x += MacGetLeftBorderSize() ; pt.x += MacGetLeftBorderSize() ;
pt.y += MacGetTopBorderSize() ; pt.y += MacGetTopBorderSize() ;
} }
@@ -747,8 +819,8 @@ wxSize wxWindowMac::DoGetSizeFromClientSize( const wxSize & size ) const
int left, top; int left, top;
int outerwidth, outerheight; int outerwidth, outerheight;
m_peer->GetContentArea( left, top, innerwidth, innerheight ); GetPeer()->GetContentArea( left, top, innerwidth, innerheight );
m_peer->GetSize( outerwidth, outerheight ); GetPeer()->GetSize( outerwidth, outerheight );
sizeTotal.x += outerwidth-innerwidth; sizeTotal.x += outerwidth-innerwidth;
sizeTotal.y += outerheight-innerheight; sizeTotal.y += outerheight-innerheight;
@@ -766,7 +838,7 @@ void wxWindowMac::DoGetClientSize( int *x, int *y ) const
int left, top; int left, top;
m_peer->GetContentArea( left, top, ww, hh ); GetPeer()->GetContentArea( left, top, ww, hh );
#if wxUSE_SCROLLBAR #if wxUSE_SCROLLBAR
if (m_hScrollBar && m_hScrollBar->IsShown() ) if (m_hScrollBar && m_hScrollBar->IsShown() )
hh -= m_hScrollBar->GetSize().y ; hh -= m_hScrollBar->GetSize().y ;
@@ -844,15 +916,15 @@ void wxWindowMac::DoSetToolTip(wxToolTip *tooltip)
if ( m_tooltip ) if ( m_tooltip )
m_tooltip->SetWindow(this); m_tooltip->SetWindow(this);
if (m_peer) if (GetPeer())
m_peer->SetToolTip(tooltip); GetPeer()->SetToolTip(tooltip);
} }
#endif #endif
void wxWindowMac::MacInvalidateBorders() void wxWindowMac::MacInvalidateBorders()
{ {
if ( m_peer == NULL ) if ( GetPeer() == NULL )
return ; return ;
bool vis = IsShownOnScreen() ; bool vis = IsShownOnScreen() ;
@@ -861,7 +933,7 @@ void wxWindowMac::MacInvalidateBorders()
int outerBorder = MacGetLeftBorderSize() ; int outerBorder = MacGetLeftBorderSize() ;
if ( m_peer->NeedsFocusRect() ) if ( GetPeer()->NeedsFocusRect() )
outerBorder += 4 ; outerBorder += 4 ;
if ( outerBorder == 0 ) if ( outerBorder == 0 )
@@ -871,8 +943,8 @@ void wxWindowMac::MacInvalidateBorders()
int tx,ty,tw,th; int tx,ty,tw,th;
m_peer->GetSize( tw, th ); GetPeer()->GetSize( tw, th );
m_peer->GetPosition( tx, ty ); GetPeer()->GetPosition( tx, ty );
wxRect leftupdate( tx-outerBorder,ty,outerBorder,th ); wxRect leftupdate( tx-outerBorder,ty,outerBorder,th );
wxRect rightupdate( tx+tw, ty, outerBorder, th ); wxRect rightupdate( tx+tw, ty, outerBorder, th );
@@ -880,10 +952,10 @@ void wxWindowMac::MacInvalidateBorders()
wxRect bottomupdate( tx-outerBorder, ty + th, tw + 2 * outerBorder, outerBorder ); wxRect bottomupdate( tx-outerBorder, ty + th, tw + 2 * outerBorder, outerBorder );
if (GetParent()) { if (GetParent()) {
GetParent()->m_peer->SetNeedsDisplay(&leftupdate); GetParent()->GetPeer()->SetNeedsDisplay(&leftupdate);
GetParent()->m_peer->SetNeedsDisplay(&rightupdate); GetParent()->GetPeer()->SetNeedsDisplay(&rightupdate);
GetParent()->m_peer->SetNeedsDisplay(&topupdate); GetParent()->GetPeer()->SetNeedsDisplay(&topupdate);
GetParent()->m_peer->SetNeedsDisplay(&bottomupdate); GetParent()->GetPeer()->SetNeedsDisplay(&bottomupdate);
} }
} }
@@ -946,7 +1018,7 @@ void wxWindowMac::DoMoveWindow(int x, int y, int width, int height)
m_cachedClippedRectValid = false ; m_cachedClippedRectValid = false ;
m_peer->Move( bounds.x, bounds.y, bounds.width, bounds.height); GetPeer()->Move( bounds.x, bounds.y, bounds.width, bounds.height);
wxWindowMac::MacSuperChangedPosition() ; // like this only children will be notified wxWindowMac::MacSuperChangedPosition() ; // like this only children will be notified
@@ -974,7 +1046,7 @@ void wxWindowMac::DoMoveWindow(int x, int y, int width, int height)
wxSize wxWindowMac::DoGetBestSize() const wxSize wxWindowMac::DoGetBestSize() const
{ {
if ( m_macIsUserPane || IsTopLevel() ) if ( GetPeer() == NULL || GetPeer()->IsUserPane() || IsTopLevel() )
{ {
return wxWindowBase::DoGetBestSize() ; return wxWindowBase::DoGetBestSize() ;
} }
@@ -982,7 +1054,7 @@ wxSize wxWindowMac::DoGetBestSize() const
{ {
wxRect r ; wxRect r ;
m_peer->GetBestRect(&r); GetPeer()->GetBestRect(&r);
if ( r.GetWidth() == 0 && r.GetHeight() == 0 ) if ( r.GetWidth() == 0 && r.GetHeight() == 0 )
{ {
@@ -1103,7 +1175,7 @@ void wxWindowMac::DoSetSize(int x, int y, int width, int height, int sizeFlags)
wxPoint wxWindowMac::GetClientAreaOrigin() const wxPoint wxWindowMac::GetClientAreaOrigin() const
{ {
int left,top,width,height; int left,top,width,height;
m_peer->GetContentArea( left , top , width , height); GetPeer()->GetContentArea( left , top , width , height);
return wxPoint( left + MacGetLeftBorderSize() , top + MacGetTopBorderSize() ); return wxPoint( left + MacGetLeftBorderSize() , top + MacGetTopBorderSize() );
} }
@@ -1124,7 +1196,7 @@ void wxWindowMac::DoSetClientSize(int clientwidth, int clientheight)
float wxWindowMac::GetContentScaleFactor() const float wxWindowMac::GetContentScaleFactor() const
{ {
return m_peer->GetContentScaleFactor(); return GetPeer()->GetContentScaleFactor();
} }
void wxWindowMac::SetLabel(const wxString& title) void wxWindowMac::SetLabel(const wxString& title)
@@ -1136,8 +1208,8 @@ void wxWindowMac::SetLabel(const wxString& title)
InvalidateBestSize(); InvalidateBestSize();
if ( m_peer && m_peer->IsOk() ) if ( GetPeer() && GetPeer()->IsOk() )
m_peer->SetLabel( wxStripMenuCodes(m_label, wxStrip_Mnemonics), GetFont().GetEncoding() ) ; GetPeer()->SetLabel( wxStripMenuCodes(m_label, wxStrip_Mnemonics), GetFont().GetEncoding() ) ;
// do not trigger refreshes upon invisible and possible partly created objects // do not trigger refreshes upon invisible and possible partly created objects
if ( IsShownOnScreen() ) if ( IsShownOnScreen() )
@@ -1154,8 +1226,8 @@ bool wxWindowMac::Show(bool show)
if ( !wxWindowBase::Show(show) ) if ( !wxWindowBase::Show(show) )
return false; return false;
if ( m_peer ) if ( GetPeer() )
m_peer->SetVisibility( show ) ; GetPeer()->SetVisibility( show ) ;
#ifdef __WXOSX_IPHONE__ #ifdef __WXOSX_IPHONE__
// only when there's no native event support // only when there's no native event support
@@ -1176,7 +1248,7 @@ bool wxWindowMac::OSXShowWithEffect(bool show,
unsigned timeout) unsigned timeout)
{ {
if ( effect == wxSHOW_EFFECT_NONE || if ( effect == wxSHOW_EFFECT_NONE ||
!m_peer || !m_peer->ShowWithEffect(show, effect, timeout) ) !GetPeer() || !GetPeer()->ShowWithEffect(show, effect, timeout) )
return Show(show); return Show(show);
return true; return true;
@@ -1184,7 +1256,7 @@ bool wxWindowMac::OSXShowWithEffect(bool show,
void wxWindowMac::DoEnable(bool enable) void wxWindowMac::DoEnable(bool enable)
{ {
m_peer->Enable( enable ) ; GetPeer()->Enable( enable ) ;
MacInvalidateBorders(); MacInvalidateBorders();
} }
@@ -1202,7 +1274,7 @@ void wxWindowMac::MacHiliteChanged()
void wxWindowMac::MacEnabledStateChanged() void wxWindowMac::MacEnabledStateChanged()
{ {
OnEnabled( m_peer->IsEnabled() ); OnEnabled( GetPeer()->IsEnabled() );
} }
// //
@@ -1211,13 +1283,13 @@ void wxWindowMac::MacEnabledStateChanged()
bool wxWindowMac::MacIsReallyEnabled() bool wxWindowMac::MacIsReallyEnabled()
{ {
return m_peer->IsEnabled() ; return GetPeer()->IsEnabled() ;
} }
bool wxWindowMac::MacIsReallyHilited() bool wxWindowMac::MacIsReallyHilited()
{ {
#if wxOSX_USE_CARBON #if wxOSX_USE_CARBON
return m_peer->IsActive(); return GetPeer()->IsActive();
#else #else
return true; // TODO return true; // TODO
#endif #endif
@@ -1278,30 +1350,30 @@ void wxWindowMac::DoGetTextExtent(const wxString& str,
void wxWindowMac::Refresh(bool WXUNUSED(eraseBack), const wxRect *rect) void wxWindowMac::Refresh(bool WXUNUSED(eraseBack), const wxRect *rect)
{ {
if ( m_peer == NULL ) if ( GetPeer() == NULL )
return ; return ;
if ( !IsShownOnScreen() ) if ( !IsShownOnScreen() )
return ; return ;
m_peer->SetNeedsDisplay( rect ) ; GetPeer()->SetNeedsDisplay( rect ) ;
} }
void wxWindowMac::DoFreeze() void wxWindowMac::DoFreeze()
{ {
#if wxOSX_USE_CARBON #if wxOSX_USE_CARBON
if ( m_peer && m_peer->IsOk() ) if ( GetPeer() && GetPeer()->IsOk() )
m_peer->SetDrawingEnabled( false ) ; GetPeer()->SetDrawingEnabled( false ) ;
#endif #endif
} }
void wxWindowMac::DoThaw() void wxWindowMac::DoThaw()
{ {
#if wxOSX_USE_CARBON #if wxOSX_USE_CARBON
if ( m_peer && m_peer->IsOk() ) if ( GetPeer() && GetPeer()->IsOk() )
{ {
m_peer->SetDrawingEnabled( true ) ; GetPeer()->SetDrawingEnabled( true ) ;
m_peer->InvalidateWithChildren() ; GetPeer()->InvalidateWithChildren() ;
} }
#endif #endif
} }
@@ -1450,8 +1522,8 @@ void wxWindowMac::MacPaintGrowBox()
int tx,ty,tw,th; int tx,ty,tw,th;
m_peer->GetSize( tw, th ); GetPeer()->GetSize( tw, th );
m_peer->GetPosition( tx, ty ); GetPeer()->GetPosition( tx, ty );
Rect rect = { ty,tx, ty+th, tx+tw }; Rect rect = { ty,tx, ty+th, tx+tw };
@@ -1489,13 +1561,13 @@ void wxWindowMac::MacPaintBorders( int WXUNUSED(leftOrigin) , int WXUNUSED(right
if ( IsTopLevel() ) if ( IsTopLevel() )
return ; return ;
bool hasFocus = m_peer->NeedsFocusRect() && HasFocus(); bool hasFocus = GetPeer()->NeedsFocusRect() && HasFocus();
// back to the surrounding frame rectangle // back to the surrounding frame rectangle
int tx,ty,tw,th; int tx,ty,tw,th;
m_peer->GetSize( tw, th ); GetPeer()->GetSize( tw, th );
m_peer->GetPosition( tx, ty ); GetPeer()->GetPosition( tx, ty );
Rect rect = { ty,tx, ty+th, tx+tw }; Rect rect = { ty,tx, ty+th, tx+tw };
@@ -1510,7 +1582,7 @@ void wxWindowMac::MacPaintBorders( int WXUNUSED(leftOrigin) , int WXUNUSED(right
CGContextRef cgContext = (CGContextRef) GetParent()->MacGetCGContextRef() ; CGContextRef cgContext = (CGContextRef) GetParent()->MacGetCGContextRef() ;
wxASSERT( cgContext ) ; wxASSERT( cgContext ) ;
if ( m_peer->NeedsFrame() ) if ( GetPeer()->NeedsFrame() )
{ {
HIThemeFrameDrawInfo info ; HIThemeFrameDrawInfo info ;
memset( &info, 0 , sizeof(info) ) ; memset( &info, 0 , sizeof(info) ) ;
@@ -1626,7 +1698,7 @@ void wxWindowMac::ScrollWindow(int dx, int dy, const wxRect *rect)
// as the native control might be not a 0/0 wx window coordinates, we have to offset // as the native control might be not a 0/0 wx window coordinates, we have to offset
scrollrect.Offset( -MacGetLeftBorderSize() , -MacGetTopBorderSize() ) ; scrollrect.Offset( -MacGetLeftBorderSize() , -MacGetTopBorderSize() ) ;
m_peer->ScrollRect( &scrollrect, dx, dy ); GetPeer()->ScrollRect( &scrollrect, dx, dy );
} }
wxWindowMac *child; wxWindowMac *child;
@@ -1698,13 +1770,13 @@ wxWindow *wxWindowBase::DoFindFocus()
// Raise the window to the top of the Z order // Raise the window to the top of the Z order
void wxWindowMac::Raise() void wxWindowMac::Raise()
{ {
m_peer->Raise(); GetPeer()->Raise();
} }
// Lower the window to the bottom of the Z order // Lower the window to the bottom of the Z order
void wxWindowMac::Lower() void wxWindowMac::Lower()
{ {
m_peer->Lower(); GetPeer()->Lower();
} }
// static wxWindow *gs_lastWhich = NULL; // static wxWindow *gs_lastWhich = NULL;
@@ -1845,8 +1917,8 @@ void wxWindowMac::MacUpdateClippedRects() const
int tx,ty,tw,th; int tx,ty,tw,th;
m_peer->GetSize( tw, th ); GetPeer()->GetSize( tw, th );
m_peer->GetPosition( tx, ty ); GetPeer()->GetPosition( tx, ty );
Rect r = { ty,tx, ty+th, tx+tw }; Rect r = { ty,tx, ty+th, tx+tw };
@@ -2227,10 +2299,10 @@ void wxWindowMac::MacRepositionScrollBars()
bool wxWindowMac::AcceptsFocus() const bool wxWindowMac::AcceptsFocus() const
{ {
if ( MacIsUserPane() ) if ( GetPeer() == NULL || GetPeer()->IsUserPane() )
return wxWindowBase::AcceptsFocus(); return wxWindowBase::AcceptsFocus();
else else
return m_peer->CanFocus(); return GetPeer()->CanFocus();
} }
void wxWindowMac::MacSuperChangedPosition() void wxWindowMac::MacSuperChangedPosition()
@@ -2272,7 +2344,7 @@ long wxWindowMac::MacGetWXBorderSize() const
SInt32 border = 0 ; SInt32 border = 0 ;
if ( m_peer && m_peer->NeedsFrame() ) if ( GetPeer() && GetPeer()->NeedsFrame() )
{ {
if (HasFlag(wxRAISED_BORDER) || HasFlag( wxSUNKEN_BORDER) || HasFlag(wxDOUBLE_BORDER)) if (HasFlag(wxRAISED_BORDER) || HasFlag( wxSUNKEN_BORDER) || HasFlag(wxDOUBLE_BORDER))
{ {
@@ -2304,10 +2376,10 @@ long wxWindowMac::MacGetLeftBorderSize() const
// the wx borders are all symmetric in mac themes // the wx borders are all symmetric in mac themes
long border = MacGetWXBorderSize() ; long border = MacGetWXBorderSize() ;
if ( m_peer ) if ( GetPeer() )
{ {
int left, top, right, bottom; int left, top, right, bottom;
m_peer->GetLayoutInset( left, top, right, bottom ); GetPeer()->GetLayoutInset( left, top, right, bottom );
border -= left; border -= left;
} }
@@ -2320,10 +2392,10 @@ long wxWindowMac::MacGetRightBorderSize() const
// the wx borders are all symmetric in mac themes // the wx borders are all symmetric in mac themes
long border = MacGetWXBorderSize() ; long border = MacGetWXBorderSize() ;
if ( m_peer ) if ( GetPeer() )
{ {
int left, top, right, bottom; int left, top, right, bottom;
m_peer->GetLayoutInset( left, top, right, bottom ); GetPeer()->GetLayoutInset( left, top, right, bottom );
border -= right; border -= right;
} }
@@ -2335,10 +2407,10 @@ long wxWindowMac::MacGetTopBorderSize() const
// the wx borders are all symmetric in mac themes // the wx borders are all symmetric in mac themes
long border = MacGetWXBorderSize() ; long border = MacGetWXBorderSize() ;
if ( m_peer ) if ( GetPeer() )
{ {
int left, top, right, bottom; int left, top, right, bottom;
m_peer->GetLayoutInset( left, top, right, bottom ); GetPeer()->GetLayoutInset( left, top, right, bottom );
border -= top; border -= top;
} }
@@ -2350,10 +2422,10 @@ long wxWindowMac::MacGetBottomBorderSize() const
// the wx borders are all symmetric in mac themes // the wx borders are all symmetric in mac themes
long border = MacGetWXBorderSize() ; long border = MacGetWXBorderSize() ;
if ( m_peer ) if ( GetPeer() )
{ {
int left, top, right, bottom; int left, top, right, bottom;
m_peer->GetLayoutInset( left, top, right, bottom ); GetPeer()->GetLayoutInset( left, top, right, bottom );
border -= bottom; border -= bottom;
} }
@@ -2448,8 +2520,8 @@ bool wxWindowMac::Reparent(wxWindowBase *newParentBase)
if ( !wxWindowBase::Reparent(newParent) ) if ( !wxWindowBase::Reparent(newParent) )
return false; return false;
m_peer->RemoveFromParent(); GetPeer()->RemoveFromParent();
m_peer->Embed( GetParent()->GetPeer() ); GetPeer()->Embed( GetParent()->GetPeer() );
MacChildAdded(); MacChildAdded();
return true; return true;
@@ -2480,9 +2552,9 @@ wxByte wxWindowMac::GetTransparent() const
bool wxWindowMac::IsShownOnScreen() const bool wxWindowMac::IsShownOnScreen() const
{ {
if ( m_peer && m_peer->IsOk() ) if ( GetPeer() && GetPeer()->IsOk() )
{ {
bool peerVis = m_peer->IsVisible(); bool peerVis = GetPeer()->IsVisible();
bool wxVis = wxWindowBase::IsShownOnScreen(); bool wxVis = wxWindowBase::IsShownOnScreen();
if( peerVis != wxVis ) if( peerVis != wxVis )
{ {
@@ -2496,7 +2568,7 @@ bool wxWindowMac::IsShownOnScreen() const
return wxVis; return wxVis;
} }
return m_peer->IsVisible(); return GetPeer()->IsVisible();
} }
return wxWindowBase::IsShownOnScreen(); return wxWindowBase::IsShownOnScreen();
} }