X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d786bf877e3568473ac2c295261f17e82199fdd8..4cb1706ae52c02214a4540c6c4b6882bed5af416:/src/gtk/frame.cpp diff --git a/src/gtk/frame.cpp b/src/gtk/frame.cpp index 9cae95648b..97e19ac404 100644 --- a/src/gtk/frame.cpp +++ b/src/gtk/frame.cpp @@ -332,7 +332,7 @@ gtk_frame_map_callback( GtkWidget * WXUNUSED(widget), GdkEvent * WXUNUSED(event), wxFrame *win ) { - win->m_isIconized = FALSE; + win->SetIconizeState(FALSE); } //----------------------------------------------------------------------------- @@ -344,7 +344,7 @@ gtk_frame_unmap_callback( GtkWidget * WXUNUSED(widget), GdkEvent * WXUNUSED(event), wxFrame *win ) { - win->m_isIconized = TRUE; + win->SetIconizeState(TRUE); } //----------------------------------------------------------------------------- @@ -356,8 +356,8 @@ static int gtk_window_expose_callback( GtkWidget *widget, GdkEventExpose *gdk_ev GtkPizza *pizza = GTK_PIZZA(widget); gtk_paint_flat_box (win->m_widget->style, pizza->bin_window, GTK_STATE_NORMAL, - GTK_SHADOW_NONE, &gdk_event->area, win->m_widget, "base", 0, 0, -1, -1); - + GTK_SHADOW_NONE, &gdk_event->area, win->m_widget, "base", 0, 0, -1, -1); + return TRUE; } @@ -370,8 +370,8 @@ static void gtk_window_draw_callback( GtkWidget *widget, GdkRectangle *rect, wxW { GtkPizza *pizza = GTK_PIZZA(widget); - gtk_paint_flat_box (win->m_widget->style, pizza->bin_window, GTK_STATE_NORMAL, - GTK_SHADOW_NONE, rect, win->m_widget, "base", 0, 0, -1, -1); + gtk_paint_flat_box (win->m_widget->style, pizza->bin_window, GTK_STATE_NORMAL, + GTK_SHADOW_NONE, rect, win->m_widget, "base", 0, 0, -1, -1); } // ---------------------------------------------------------------------------- @@ -455,12 +455,24 @@ void wxFrame::Init() bool wxFrame::Create( wxWindow *parent, wxWindowID id, - const wxString &title, - const wxPoint &pos, - const wxSize &size, + const wxString& title, + const wxPoint& pos, + const wxSize& sizeOrig, long style, const wxString &name ) { + // always create a frame of some reasonable, even if arbitrary, size (at + // least for MSW compatibility) + wxSize size = sizeOrig; + if ( size.x == -1 || size.y == -1 ) + { + wxSize sizeDpy = wxGetDisplaySize(); + if ( size.x == -1 ) + size.x = sizeDpy.x / 3; + if ( size.y == -1 ) + size.y = sizeDpy.y / 5; + } + wxTopLevelWindows.Append( this ); m_needParent = FALSE; @@ -477,7 +489,7 @@ bool wxFrame::Create( wxWindow *parent, m_insertCallback = (wxInsertChildFunction) wxInsertChildInFrame; GtkWindowType win_type = GTK_WINDOW_TOPLEVEL; - + if (style & wxFRAME_TOOL_WINDOW) win_type = GTK_WINDOW_POPUP; @@ -525,7 +537,7 @@ bool wxFrame::Create( wxWindow *parent, #endif /* we donm't allow the frame to get the focus as otherwise - the frame will grabit at arbitrary fcous changes. */ + the frame will grab it at arbitrary focus changes. */ GTK_WIDGET_UNSET_FLAGS( m_wxwindow, GTK_CAN_FOCUS ); if (m_parent) m_parent->AddChild( this ); @@ -589,24 +601,24 @@ bool wxFrame::ShowFullScreen(bool show, long style ) if (show == m_fsIsShowing) return FALSE; // return what? m_fsIsShowing = show; - + if (show) { m_fsSaveStyle = m_windowStyle; m_fsSaveFlag = style; GetPosition( &m_fsSaveFrame.x, &m_fsSaveFrame.y ); GetSize( &m_fsSaveFrame.width, &m_fsSaveFrame.height ); - + gtk_widget_hide( m_widget ); gtk_widget_unrealize( m_widget ); - + m_windowStyle = wxSIMPLE_BORDER; - + int x; int y; wxDisplaySize( &x, &y ); SetSize( 0, 0, x, y ); - + gtk_widget_realize( m_widget ); gtk_widget_show( m_widget ); } @@ -614,15 +626,15 @@ bool wxFrame::ShowFullScreen(bool show, long style ) { gtk_widget_hide( m_widget ); gtk_widget_unrealize( m_widget ); - + m_windowStyle = m_fsSaveStyle; - + SetSize( m_fsSaveFrame.x, m_fsSaveFrame.y, m_fsSaveFrame.width, m_fsSaveFrame.height ); - + gtk_widget_realize( m_widget ); gtk_widget_show( m_widget ); } - + return TRUE; } @@ -1204,3 +1216,23 @@ bool wxFrame::IsIconized() const { return m_isIconized; } + +void wxFrame::SetIconizeState(bool iconize) +{ + if ( iconize != m_isIconized ) + { + m_isIconized = iconize; + (void)SendIconizeEvent(iconize); + } + else + { + // this is not supposed to happen if we're called only from + // gtk_frame_(un)map_callback! + + // RR: I don't understand this test. Upon startup, the frame is + // not iconized by default, it has just not been created + // yet. + ///wxFAIL_MSG( _T("unexpected call to SendIconizeEvent ignored") ); + } +} +