merged 2.4 branch into the trunk
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@18040 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -278,6 +278,10 @@ bool wxToolBar::Create( wxWindow *parent,
|
||||
#ifdef __WXGTK20__
|
||||
m_toolbar = GTK_TOOLBAR( gtk_toolbar_new() );
|
||||
GtkSetStyle();
|
||||
|
||||
// Doesn't work this way.
|
||||
// GtkToolbarSpaceStyle space_style = GTK_TOOLBAR_SPACE_EMPTY;
|
||||
// gtk_widget_style_set (GTK_WIDGET (m_toolbar), "space_style", &space_style, NULL);
|
||||
#else
|
||||
GtkOrientation orient;
|
||||
GtkToolbarStyle gtkStyle;
|
||||
@@ -374,37 +378,44 @@ bool wxToolBar::DoInsertTool(size_t pos, wxToolBarToolBase *toolBase)
|
||||
{
|
||||
wxToolBarTool *tool = (wxToolBarTool *)toolBase;
|
||||
|
||||
#ifndef __WXGTK20__
|
||||
// if we have inserted a space before all the tools we must change the GTK
|
||||
// index by 1
|
||||
size_t posGtk = m_xMargin > 1 ? pos + 1 : pos;
|
||||
#else
|
||||
size_t posGtk = pos;
|
||||
#endif
|
||||
|
||||
if ( tool->IsButton() )
|
||||
{
|
||||
wxBitmap bitmap = tool->GetNormalBitmap();
|
||||
if ( !HasFlag(wxTB_NOICONS) )
|
||||
{
|
||||
wxBitmap bitmap = tool->GetNormalBitmap();
|
||||
|
||||
wxCHECK_MSG( bitmap.Ok(), FALSE,
|
||||
wxT("invalid bitmap for wxToolBar icon") );
|
||||
wxCHECK_MSG( bitmap.Ok(), FALSE,
|
||||
wxT("invalid bitmap for wxToolBar icon") );
|
||||
|
||||
wxCHECK_MSG( bitmap.GetBitmap() == NULL, FALSE,
|
||||
wxT("wxToolBar doesn't support GdkBitmap") );
|
||||
wxCHECK_MSG( bitmap.GetBitmap() == NULL, FALSE,
|
||||
wxT("wxToolBar doesn't support GdkBitmap") );
|
||||
|
||||
wxCHECK_MSG( bitmap.GetPixmap() != NULL, FALSE,
|
||||
wxT("wxToolBar::Add needs a wxBitmap") );
|
||||
wxCHECK_MSG( bitmap.GetPixmap() != NULL, FALSE,
|
||||
wxT("wxToolBar::Add needs a wxBitmap") );
|
||||
|
||||
GtkWidget *tool_pixmap = (GtkWidget *)NULL;
|
||||
GtkWidget *tool_pixmap = (GtkWidget *)NULL;
|
||||
|
||||
GdkPixmap *pixmap = bitmap.GetPixmap();
|
||||
GdkPixmap *pixmap = bitmap.GetPixmap();
|
||||
|
||||
GdkBitmap *mask = (GdkBitmap *)NULL;
|
||||
if ( bitmap.GetMask() )
|
||||
mask = bitmap.GetMask()->GetBitmap();
|
||||
GdkBitmap *mask = (GdkBitmap *)NULL;
|
||||
if ( bitmap.GetMask() )
|
||||
mask = bitmap.GetMask()->GetBitmap();
|
||||
|
||||
tool_pixmap = gtk_pixmap_new( pixmap, mask );
|
||||
gtk_pixmap_set_build_insensitive( GTK_PIXMAP(tool_pixmap), TRUE );
|
||||
tool_pixmap = gtk_pixmap_new( pixmap, mask );
|
||||
gtk_pixmap_set_build_insensitive( GTK_PIXMAP(tool_pixmap), TRUE );
|
||||
|
||||
gtk_misc_set_alignment( GTK_MISC(tool_pixmap), 0.5, 0.5 );
|
||||
gtk_misc_set_alignment( GTK_MISC(tool_pixmap), 0.5, 0.5 );
|
||||
|
||||
tool->m_pixmap = tool_pixmap;
|
||||
tool->m_pixmap = tool_pixmap;
|
||||
}
|
||||
}
|
||||
|
||||
switch ( tool->GetStyle() )
|
||||
@@ -464,7 +475,7 @@ bool wxToolBar::DoInsertTool(size_t pos, wxToolBarToolBase *toolBase)
|
||||
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
|
||||
gtk_signal_connect( GTK_OBJECT(tool->m_item),
|
||||
"enter_notify_event",
|
||||
GTK_SIGNAL_FUNC(gtk_toolbar_tool_callback),
|
||||
@@ -587,8 +598,10 @@ void wxToolBar::SetMargins( int x, int y )
|
||||
wxCHECK_RET( GetToolsCount() == 0,
|
||||
wxT("wxToolBar::SetMargins must be called before adding tools.") );
|
||||
|
||||
#ifndef __WXGTK20__
|
||||
if (x > 1)
|
||||
gtk_toolbar_append_space( m_toolbar ); // oh well
|
||||
#endif
|
||||
|
||||
m_xMargin = x;
|
||||
m_yMargin = y;
|
||||
|
Reference in New Issue
Block a user