don't use negative windows sizes

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@41051 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Paul Cornett 2006-09-07 17:06:29 +00:00
parent 4322f94f29
commit 9cf7a6c06b
2 changed files with 14 additions and 0 deletions

View File

@ -384,6 +384,8 @@ void wxFrame::GtkOnSize()
int xx = m_miniEdge; int xx = m_miniEdge;
int yy = m_miniEdge + m_miniTitle; int yy = m_miniEdge + m_miniTitle;
int ww = m_width - 2*m_miniEdge; int ww = m_width - 2*m_miniEdge;
if (ww < 0)
ww = 0;
int hh = m_menuBarHeight; int hh = m_menuBarHeight;
if (m_menuBarDetached) hh = wxPLACE_HOLDER; if (m_menuBarDetached) hh = wxPLACE_HOLDER;
m_frameMenuBar->m_x = xx; m_frameMenuBar->m_x = xx;
@ -423,6 +425,8 @@ void wxFrame::GtkOnSize()
ww = m_toolBarDetached ? wxPLACE_HOLDER ww = m_toolBarDetached ? wxPLACE_HOLDER
: m_frameToolBar->m_width; : m_frameToolBar->m_width;
hh = m_height - 2*m_miniEdge; hh = m_height - 2*m_miniEdge;
if (hh < 0)
hh = 0;
client_area_x_offset += ww; client_area_x_offset += ww;
} }
@ -445,6 +449,10 @@ void wxFrame::GtkOnSize()
int client_y = client_area_y_offset + m_miniEdge + m_miniTitle; int client_y = client_area_y_offset + m_miniEdge + m_miniTitle;
int client_w = m_width - client_area_x_offset - 2*m_miniEdge; int client_w = m_width - client_area_x_offset - 2*m_miniEdge;
int client_h = m_height - client_area_y_offset- 2*m_miniEdge - m_miniTitle; int client_h = m_height - client_area_y_offset- 2*m_miniEdge - m_miniTitle;
if (client_w < 0)
client_w = 0;
if (client_h < 0)
client_h = 0;
gtk_pizza_set_size( GTK_PIZZA(m_mainWidget), gtk_pizza_set_size( GTK_PIZZA(m_mainWidget),
m_wxwindow, m_wxwindow,
client_x, client_y, client_w, client_h ); client_x, client_y, client_w, client_h );
@ -461,6 +469,8 @@ void wxFrame::GtkOnSize()
int xx = 0 + m_miniEdge; int xx = 0 + m_miniEdge;
int yy = m_height - wxSTATUS_HEIGHT - m_miniEdge - client_area_y_offset; int yy = m_height - wxSTATUS_HEIGHT - m_miniEdge - client_area_y_offset;
int ww = m_width - 2*m_miniEdge; int ww = m_width - 2*m_miniEdge;
if (ww < 0)
ww = 0;
int hh = wxSTATUS_HEIGHT; int hh = wxSTATUS_HEIGHT;
m_frameStatusBar->m_x = xx; m_frameStatusBar->m_x = xx;
m_frameStatusBar->m_y = yy; m_frameStatusBar->m_y = yy;

View File

@ -1021,6 +1021,10 @@ void wxTopLevelWindowGTK::GtkOnSize()
int client_y = m_miniEdge + m_miniTitle; int client_y = m_miniEdge + m_miniTitle;
int client_w = m_width - 2*m_miniEdge; int client_w = m_width - 2*m_miniEdge;
int client_h = m_height - 2*m_miniEdge - m_miniTitle; int client_h = m_height - 2*m_miniEdge - m_miniTitle;
if (client_w < 0)
client_w = 0;
if (client_h < 0)
client_h = 0;
gtk_pizza_set_size( GTK_PIZZA(m_mainWidget), gtk_pizza_set_size( GTK_PIZZA(m_mainWidget),
m_wxwindow, m_wxwindow,