X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/15475ced8819ab9fe6ababa609811399bfb45a43..b1d7de5ae0c53162b57ac20cfed04264f0f27b30:/src/gtk1/window.cpp diff --git a/src/gtk1/window.cpp b/src/gtk1/window.cpp index a6d5457225..5eee285dc3 100644 --- a/src/gtk1/window.cpp +++ b/src/gtk1/window.cpp @@ -1365,6 +1365,7 @@ static gint gtk_window_key_release_callback( GtkWidget *widget, event.m_rightDown = (gdk_event->state & GDK_BUTTON3_MASK); \ if (event.GetEventType()==wxEVT_MOUSEWHEEL) \ { \ + event.m_linesPerAction = 3; \ if (((GdkEventButton*)gdk_event)->button == 4) \ event.m_wheelRotation = 120; \ else if (((GdkEventButton*)gdk_event)->button == 5) \ @@ -1537,7 +1538,8 @@ static gint gtk_window_button_press_callback( GtkWidget *widget, wxEventType event_type = wxEVT_NULL; -#ifdef __WXGTK20__ + // GdkDisplay is a GTK+ 2.1.0 thing +#if defined(__WXGTK20__) && GTK_CHECK_VERSION(2, 1, 0) if ( gdk_event->type == GDK_2BUTTON_PRESS && gdk_event->button >= 1 && gdk_event->button <= 3 ) { @@ -1850,6 +1852,7 @@ static gint gtk_window_wheel_callback (GtkWidget * widget, event.m_leftDown = (gdk_event->state & GDK_BUTTON1_MASK); event.m_middleDown = (gdk_event->state & GDK_BUTTON2_MASK); event.m_rightDown = (gdk_event->state & GDK_BUTTON3_MASK); + event.m_linesPerAction = 3; if (gdk_event->direction == GDK_SCROLL_UP) event.m_wheelRotation = 120; else @@ -2789,10 +2792,8 @@ bool wxWindowGTK::PreCreation( wxWindowGTK *parent, const wxPoint &pos, const w { wxCHECK_MSG( !m_needParent || parent, FALSE, wxT("Need complete parent.") ); - // This turns -1 into 30 so that a minimal window is - // visible even although -1,-1 has been given as the - // size of the window. the same trick is used in other - // ports and should make debugging easier. + // Use either the given size, or the default if -1 is given. + // See wxWindowBase for these functions. m_width = WidthDefault(size.x) ; m_height = HeightDefault(size.y); @@ -3003,18 +3004,22 @@ void wxWindowGTK::DoSetSize( int x, int y, int width, int height, int sizeFlags m_x = x + pizza->xoffset; m_y = y + pizza->yoffset; } - if (width != -1) m_width = width; - if (height != -1) m_height = height; - if ((sizeFlags & wxSIZE_AUTO_WIDTH) == wxSIZE_AUTO_WIDTH) + // calculate the best size if we should auto size the window + if ( (sizeFlags & wxSIZE_AUTO_WIDTH) || + (sizeFlags & wxSIZE_AUTO_HEIGHT) ) { - if (width == -1) m_width = 80; + const wxSize sizeBest = GetBestSize(); + if ( sizeFlags & wxSIZE_AUTO_WIDTH ) + width = sizeBest.x; + if ( sizeFlags & wxSIZE_AUTO_HEIGHT ) + height = sizeBest.y; } - if ((sizeFlags & wxSIZE_AUTO_HEIGHT) == wxSIZE_AUTO_HEIGHT) - { - if (height == -1) m_height = 26; - } + if (width != -1) + m_width = width; + if (height != -1) + m_height = height; int minWidth = GetMinWidth(), minHeight = GetMinHeight(), @@ -3994,7 +3999,8 @@ void wxWindowGTK::DoSetToolTip( wxToolTip *tip ) void wxWindowGTK::ApplyToolTip( GtkTooltips *tips, const wxChar *tip ) { - gtk_tooltips_set_tip( tips, GetConnectWidget(), wxConvCurrent->cWX2MB(tip), (gchar*) NULL ); + wxString tmp( tip ); + gtk_tooltips_set_tip( tips, GetConnectWidget(), wxGTK_CONV(tmp), (gchar*) NULL ); } #endif // wxUSE_TOOLTIPS