git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@70765
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
// event handlers
void OnActivate(wxActivateEvent& event);
void OnSysColourChanged(wxSysColourChangedEvent& event);
// event handlers
void OnActivate(wxActivateEvent& event);
void OnSysColourChanged(wxSysColourChangedEvent& event);
- void OnSize(wxSizeEvent& event);
// Toolbar
#if wxUSE_TOOLBAR
// Toolbar
#if wxUSE_TOOLBAR
+ // internal response to size events
+ virtual void MacOnInternalSize() { PositionBars(); }
protected:
// common part of all ctors
protected:
// common part of all ctors
float GetContentScaleFactor() const ;
float GetContentScaleFactor() const ;
+ // internal response to size events
+ virtual void MacOnInternalSize() {}
+
protected:
// For controls like radio buttons which are genuinely composite
wxList m_subControls;
protected:
// For controls like radio buttons which are genuinely composite
wxList m_subControls;
BEGIN_EVENT_TABLE(wxFrame, wxFrameBase)
EVT_ACTIVATE(wxFrame::OnActivate)
EVT_SYS_COLOUR_CHANGED(wxFrame::OnSysColourChanged)
BEGIN_EVENT_TABLE(wxFrame, wxFrameBase)
EVT_ACTIVATE(wxFrame::OnActivate)
EVT_SYS_COLOUR_CHANGED(wxFrame::OnSysColourChanged)
- EVT_SIZE(wxFrame::OnSize)
END_EVENT_TABLE()
#define WX_MAC_STATUSBAR_HEIGHT 18
END_EVENT_TABLE()
#define WX_MAC_STATUSBAR_HEIGHT 18
-
-void wxFrame::OnSize(wxSizeEvent& event)
-{
- PositionBars();
-
- event.Skip();
-}
-
#if wxUSE_MENUS
void wxFrame::DetachMenuBar()
{
#if wxUSE_MENUS
void wxFrame::DetachMenuBar()
{
SetInitialSize( wxSize(m_minWidth, m_minHeight));
SendSizeEventToParent();
SetInitialSize( wxSize(m_minWidth, m_minHeight));
SendSizeEventToParent();
+ wxWindow * const parent = GetParent();
+ if ( parent && !parent->IsBeingDeleted() )
+ parent->MacOnInternalSize();
wxUnusedVar(progress);
m_win->SendSizeEvent();
wxUnusedVar(progress);
m_win->SendSizeEvent();
+ m_win->MacOnInternalSize();
}
- (void)animationDidEnd:(NSAnimation*)animation
}
- (void)animationDidEnd:(NSAnimation*)animation
// refresh it once again after the end to ensure that everything is in
// place
win->SendSizeEvent();
// refresh it once again after the end to ensure that everything is in
// place
win->SendSizeEvent();
+ win->MacOnInternalSize();
}
[anim setDelegate:nil];
}
[anim setDelegate:nil];
{
// as apps expect a size event to occur when the window is shown,
// generate one when it is shown with effect too
{
// as apps expect a size event to occur when the window is shown,
// generate one when it is shown with effect too
wxSizeEvent event(GetSize(), m_windowId);
event.SetEventObject(this);
HandleWindowEvent(event);
wxSizeEvent event(GetSize(), m_windowId);
event.SetEventObject(this);
HandleWindowEvent(event);
void wxNonOwnedWindow::HandleResized( double timestampsec )
{
void wxNonOwnedWindow::HandleResized( double timestampsec )
{
wxSizeEvent wxevent( GetSize() , GetId());
wxevent.SetTimestamp( (int) (timestampsec * 1000) );
wxevent.SetEventObject( this );
wxSizeEvent wxevent( GetSize() , GetId());
wxevent.SetTimestamp( (int) (timestampsec * 1000) );
wxevent.SetEventObject( this );
if ( show )
{
// because apps expect a size event to occur at this moment
if ( show )
{
// because apps expect a size event to occur at this moment
wxSizeEvent event(GetSize() , m_windowId);
event.SetEventObject(this);
HandleWindowEvent(event);
wxSizeEvent event(GetSize() , m_windowId);
event.SetEventObject(this);
HandleWindowEvent(event);
if ( doResize )
{
MacRepositionScrollBars() ;
if ( doResize )
{
MacRepositionScrollBars() ;
wxSize size(actualWidth, actualHeight);
wxSizeEvent event(size, m_windowId);
event.SetEventObject(this);
wxSize size(actualWidth, actualHeight);
wxSizeEvent event(size, m_windowId);
event.SetEventObject(this);
if (sizeFlags & wxSIZE_FORCE_EVENT)
{
if (sizeFlags & wxSIZE_FORCE_EVENT)
{
wxSizeEvent event( wxSize(width,height), GetId() );
event.SetEventObject( this );
HandleWindowEvent( event );
wxSizeEvent event( wxSize(width,height), GetId() );
event.SetEventObject( this );
HandleWindowEvent( event );
MacRepositionScrollBars() ;
if ( triggerSizeEvent )
{
MacRepositionScrollBars() ;
if ( triggerSizeEvent )
{
wxSizeEvent event(GetSize(), m_windowId);
event.SetEventObject(this);
HandleWindowEvent(event);
wxSizeEvent event(GetSize(), m_windowId);
event.SetEventObject(this);
HandleWindowEvent(event);