Fixed resize behaviour under certain circumstances.
Disabled GUI threading when using GTK < 1.2.4, better than crashing. Typos corrected. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@5421 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -210,9 +210,9 @@ void MyTopLabels::OnPaint( wxPaintEvent &event )
|
|||||||
{
|
{
|
||||||
wxPaintDC dc(this);
|
wxPaintDC dc(this);
|
||||||
m_owner->PrepareDC( dc );
|
m_owner->PrepareDC( dc );
|
||||||
dc.DrawText( "Colummn 1", 5, 5 );
|
dc.DrawText( "Column 1", 5, 5 );
|
||||||
dc.DrawText( "Colummn 2", 105, 5 );
|
dc.DrawText( "Column 2", 105, 5 );
|
||||||
dc.DrawText( "Colummn 3", 205, 5 );
|
dc.DrawText( "Column 3", 205, 5 );
|
||||||
}
|
}
|
||||||
|
|
||||||
// MyRightLabels
|
// MyRightLabels
|
||||||
|
@@ -558,7 +558,17 @@ void wxApp::CleanUp()
|
|||||||
int wxEntry( int argc, char *argv[] )
|
int wxEntry( int argc, char *argv[] )
|
||||||
{
|
{
|
||||||
#if wxUSE_THREADS
|
#if wxUSE_THREADS
|
||||||
|
/* GTK 1.2 up to version 1.2.3 has broken threads */
|
||||||
|
if ((gtk_major_version == 1) &&
|
||||||
|
(gtk_minor_version == 2) &&
|
||||||
|
(gtk_micro_version < 4))
|
||||||
|
{
|
||||||
|
printf( "wxWindows warning: Disabled GUI threading due to outdated GTK version\n" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
g_thread_init(NULL);
|
g_thread_init(NULL);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gtk_set_locale();
|
gtk_set_locale();
|
||||||
|
@@ -1707,6 +1707,20 @@ gtk_window_realized_callback( GtkWidget *WXUNUSED(m_widget), wxWindow *win )
|
|||||||
// "size_allocate"
|
// "size_allocate"
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static
|
||||||
|
void gtk_window_size_callback( GtkWidget *widget,
|
||||||
|
GtkAllocation *alloc,
|
||||||
|
wxWindow *win )
|
||||||
|
{
|
||||||
|
if (g_isIdle)
|
||||||
|
wxapp_install_idle_handler();
|
||||||
|
|
||||||
|
wxSizeEvent event( win->GetSize(), win->GetId() );
|
||||||
|
event.SetEventObject( win );
|
||||||
|
win->GetEventHandler()->ProcessEvent( event );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef HAVE_XIM
|
#ifdef HAVE_XIM
|
||||||
#define WXUNUSED_UNLESS_XIM(param) param
|
#define WXUNUSED_UNLESS_XIM(param) param
|
||||||
#else
|
#else
|
||||||
@@ -1718,7 +1732,7 @@ gtk_window_realized_callback( GtkWidget *WXUNUSED(m_widget), wxWindow *win )
|
|||||||
static
|
static
|
||||||
void gtk_wxwindow_size_callback( GtkWidget* WXUNUSED_UNLESS_XIM(widget),
|
void gtk_wxwindow_size_callback( GtkWidget* WXUNUSED_UNLESS_XIM(widget),
|
||||||
GtkAllocation* WXUNUSED_UNLESS_XIM(alloc),
|
GtkAllocation* WXUNUSED_UNLESS_XIM(alloc),
|
||||||
wxFrame * WXUNUSED_UNLESS_XIM(win) )
|
wxWindow* WXUNUSED_UNLESS_XIM(win) )
|
||||||
{
|
{
|
||||||
if (g_isIdle)
|
if (g_isIdle)
|
||||||
wxapp_install_idle_handler();
|
wxapp_install_idle_handler();
|
||||||
@@ -2211,6 +2225,10 @@ void wxWindow::PostCreation()
|
|||||||
|
|
||||||
if (m_wxwindow)
|
if (m_wxwindow)
|
||||||
{
|
{
|
||||||
|
/* Catch native resize events. */
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "size_allocate",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_window_size_callback), (gpointer)this );
|
||||||
|
|
||||||
/* Initialize XIM support. */
|
/* Initialize XIM support. */
|
||||||
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "realize",
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "realize",
|
||||||
GTK_SIGNAL_FUNC(gtk_wxwindow_realized_callback), (gpointer) this );
|
GTK_SIGNAL_FUNC(gtk_wxwindow_realized_callback), (gpointer) this );
|
||||||
|
@@ -558,7 +558,17 @@ void wxApp::CleanUp()
|
|||||||
int wxEntry( int argc, char *argv[] )
|
int wxEntry( int argc, char *argv[] )
|
||||||
{
|
{
|
||||||
#if wxUSE_THREADS
|
#if wxUSE_THREADS
|
||||||
|
/* GTK 1.2 up to version 1.2.3 has broken threads */
|
||||||
|
if ((gtk_major_version == 1) &&
|
||||||
|
(gtk_minor_version == 2) &&
|
||||||
|
(gtk_micro_version < 4))
|
||||||
|
{
|
||||||
|
printf( "wxWindows warning: Disabled GUI threading due to outdated GTK version\n" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
g_thread_init(NULL);
|
g_thread_init(NULL);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gtk_set_locale();
|
gtk_set_locale();
|
||||||
|
@@ -1707,6 +1707,20 @@ gtk_window_realized_callback( GtkWidget *WXUNUSED(m_widget), wxWindow *win )
|
|||||||
// "size_allocate"
|
// "size_allocate"
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static
|
||||||
|
void gtk_window_size_callback( GtkWidget *widget,
|
||||||
|
GtkAllocation *alloc,
|
||||||
|
wxWindow *win )
|
||||||
|
{
|
||||||
|
if (g_isIdle)
|
||||||
|
wxapp_install_idle_handler();
|
||||||
|
|
||||||
|
wxSizeEvent event( win->GetSize(), win->GetId() );
|
||||||
|
event.SetEventObject( win );
|
||||||
|
win->GetEventHandler()->ProcessEvent( event );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef HAVE_XIM
|
#ifdef HAVE_XIM
|
||||||
#define WXUNUSED_UNLESS_XIM(param) param
|
#define WXUNUSED_UNLESS_XIM(param) param
|
||||||
#else
|
#else
|
||||||
@@ -1718,7 +1732,7 @@ gtk_window_realized_callback( GtkWidget *WXUNUSED(m_widget), wxWindow *win )
|
|||||||
static
|
static
|
||||||
void gtk_wxwindow_size_callback( GtkWidget* WXUNUSED_UNLESS_XIM(widget),
|
void gtk_wxwindow_size_callback( GtkWidget* WXUNUSED_UNLESS_XIM(widget),
|
||||||
GtkAllocation* WXUNUSED_UNLESS_XIM(alloc),
|
GtkAllocation* WXUNUSED_UNLESS_XIM(alloc),
|
||||||
wxFrame * WXUNUSED_UNLESS_XIM(win) )
|
wxWindow* WXUNUSED_UNLESS_XIM(win) )
|
||||||
{
|
{
|
||||||
if (g_isIdle)
|
if (g_isIdle)
|
||||||
wxapp_install_idle_handler();
|
wxapp_install_idle_handler();
|
||||||
@@ -2211,6 +2225,10 @@ void wxWindow::PostCreation()
|
|||||||
|
|
||||||
if (m_wxwindow)
|
if (m_wxwindow)
|
||||||
{
|
{
|
||||||
|
/* Catch native resize events. */
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "size_allocate",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_window_size_callback), (gpointer)this );
|
||||||
|
|
||||||
/* Initialize XIM support. */
|
/* Initialize XIM support. */
|
||||||
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "realize",
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "realize",
|
||||||
GTK_SIGNAL_FUNC(gtk_wxwindow_realized_callback), (gpointer) this );
|
GTK_SIGNAL_FUNC(gtk_wxwindow_realized_callback), (gpointer) this );
|
||||||
|
Reference in New Issue
Block a user