Bunch of GTK theme changes.
Make wxStatusBar use themes. SetStatusText() now uses Refresh() since I don't know why it shouldn't. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@15228 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -85,6 +85,9 @@ bool wxStatusBarGeneric::Create(wxWindow *parent,
|
|||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
style | wxTAB_TRAVERSAL, name);
|
style | wxTAB_TRAVERSAL, name);
|
||||||
|
|
||||||
|
// The status bar should have a themed background
|
||||||
|
SetThemeEnabled( TRUE );
|
||||||
|
|
||||||
// Don't wish this to be found as a child
|
// Don't wish this to be found as a child
|
||||||
#ifndef __WXMAC__
|
#ifndef __WXMAC__
|
||||||
parent->GetChildren().DeleteObject(this);
|
parent->GetChildren().DeleteObject(this);
|
||||||
@@ -127,27 +130,10 @@ void wxStatusBarGeneric::SetStatusText(const wxString& text, int number)
|
|||||||
|
|
||||||
m_statusStrings[number] = text;
|
m_statusStrings[number] = text;
|
||||||
|
|
||||||
#ifdef __WXMAC__
|
|
||||||
int major,minor;
|
|
||||||
wxGetOsVersion( &major, &minor );
|
|
||||||
|
|
||||||
if (major >= 10)
|
|
||||||
{
|
|
||||||
Refresh();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
wxRect rect;
|
wxRect rect;
|
||||||
GetFieldRect(number, rect);
|
GetFieldRect(number, rect);
|
||||||
wxClientDC dc(this);
|
|
||||||
|
Refresh( TRUE, &rect );
|
||||||
dc.SetBackground( wxBrush(GetBackgroundColour(), wxSOLID) );
|
|
||||||
dc.SetClippingRegion( rect.x+1, rect.y+1, rect.width-1, rect.height-1 );
|
|
||||||
dc.Clear();
|
|
||||||
dc.DestroyClippingRegion();
|
|
||||||
dc.SetFont(GetFont());
|
|
||||||
DrawFieldText( dc, number );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxStatusBarGeneric::GetStatusText(int n) const
|
wxString wxStatusBarGeneric::GetStatusText(int n) const
|
||||||
|
@@ -1569,9 +1569,7 @@ void wxWindowDC::Clear()
|
|||||||
|
|
||||||
if (m_owner)
|
if (m_owner)
|
||||||
{
|
{
|
||||||
int width,height;
|
m_owner->Clear();
|
||||||
m_owner->GetSize( &width, &height );
|
|
||||||
gdk_draw_rectangle( m_window, m_bgGC, TRUE, 0, 0, width, height );
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -3467,8 +3467,43 @@ void wxWindowGTK::GtkSendPaintEvents()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// widget to draw on
|
||||||
|
GtkPizza *pizza = GTK_PIZZA (m_wxwindow);
|
||||||
|
|
||||||
|
// Clip to paint region in wxClientDC
|
||||||
m_clipPaintRegion = TRUE;
|
m_clipPaintRegion = TRUE;
|
||||||
|
|
||||||
|
if (GetThemeEnabled())
|
||||||
|
{
|
||||||
|
// find ancestor from which to steal background
|
||||||
|
wxWindow *parent = GetParent();
|
||||||
|
while (parent && !parent->IsTopLevel())
|
||||||
|
parent = parent->GetParent();
|
||||||
|
if (!parent)
|
||||||
|
parent = this;
|
||||||
|
|
||||||
|
wxRegionIterator upd( m_updateRegion );
|
||||||
|
while (upd)
|
||||||
|
{
|
||||||
|
GdkRectangle rect;
|
||||||
|
rect.x = upd.GetX();
|
||||||
|
rect.y = upd.GetY();
|
||||||
|
rect.width = upd.GetWidth();
|
||||||
|
rect.height = upd.GetHeight();
|
||||||
|
|
||||||
|
gtk_paint_flat_box( parent->m_widget->style,
|
||||||
|
pizza->bin_window,
|
||||||
|
GTK_STATE_NORMAL,
|
||||||
|
GTK_SHADOW_NONE,
|
||||||
|
&rect,
|
||||||
|
parent->m_widget,
|
||||||
|
(char *)"base",
|
||||||
|
0, 0, -1, -1 );
|
||||||
|
|
||||||
|
upd ++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
// if (!m_clearRegion.IsEmpty()) // always send an erase event
|
// if (!m_clearRegion.IsEmpty()) // always send an erase event
|
||||||
{
|
{
|
||||||
wxWindowDC dc( (wxWindow*)this );
|
wxWindowDC dc( (wxWindow*)this );
|
||||||
@@ -3481,46 +3516,16 @@ void wxWindowGTK::GtkSendPaintEvents()
|
|||||||
{
|
{
|
||||||
if (!g_eraseGC)
|
if (!g_eraseGC)
|
||||||
{
|
{
|
||||||
g_eraseGC = gdk_gc_new( GTK_PIZZA(m_wxwindow)->bin_window );
|
g_eraseGC = gdk_gc_new( pizza->bin_window );
|
||||||
gdk_gc_set_fill( g_eraseGC, GDK_SOLID );
|
gdk_gc_set_fill( g_eraseGC, GDK_SOLID );
|
||||||
}
|
}
|
||||||
gdk_gc_set_foreground( g_eraseGC, m_backgroundColour.GetColor() );
|
gdk_gc_set_foreground( g_eraseGC, m_backgroundColour.GetColor() );
|
||||||
|
|
||||||
// widget to draw on
|
|
||||||
GtkPizza *pizza = GTK_PIZZA (m_wxwindow);
|
|
||||||
|
|
||||||
// find ancestor from which to steal background
|
|
||||||
wxWindow *parent = GetParent();
|
|
||||||
while (parent && !parent->IsTopLevel())
|
|
||||||
parent = parent->GetParent();
|
|
||||||
if (!parent)
|
|
||||||
parent = this;
|
|
||||||
|
|
||||||
wxRegionIterator upd( m_clearRegion );
|
wxRegionIterator upd( m_clearRegion );
|
||||||
while (upd)
|
while (upd)
|
||||||
{
|
{
|
||||||
if (GetThemeEnabled())
|
gdk_draw_rectangle( pizza->bin_window, g_eraseGC, 1,
|
||||||
{
|
upd.GetX(), upd.GetY(), upd.GetWidth(), upd.GetHeight() );
|
||||||
GdkRectangle rect;
|
|
||||||
rect.x = upd.GetX();
|
|
||||||
rect.y = upd.GetY();
|
|
||||||
rect.width = upd.GetWidth();
|
|
||||||
rect.height = upd.GetHeight();
|
|
||||||
|
|
||||||
gtk_paint_flat_box( parent->m_widget->style,
|
|
||||||
pizza->bin_window,
|
|
||||||
GTK_STATE_NORMAL,
|
|
||||||
GTK_SHADOW_NONE,
|
|
||||||
&rect,
|
|
||||||
parent->m_widget,
|
|
||||||
(char *)"base",
|
|
||||||
0, 0, -1, -1 );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
gdk_draw_rectangle( pizza->bin_window, g_eraseGC, 1,
|
|
||||||
upd.GetX(), upd.GetY(), upd.GetWidth(), upd.GetHeight() );
|
|
||||||
}
|
|
||||||
upd ++;
|
upd ++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -3543,8 +3548,6 @@ void wxWindowGTK::GtkSendPaintEvents()
|
|||||||
// being redrawn because the wxWindows class is allowed to
|
// being redrawn because the wxWindows class is allowed to
|
||||||
// paint over the window-less widgets.
|
// paint over the window-less widgets.
|
||||||
|
|
||||||
GtkPizza *pizza = GTK_PIZZA(m_wxwindow);
|
|
||||||
|
|
||||||
GList *children = pizza->children;
|
GList *children = pizza->children;
|
||||||
while (children)
|
while (children)
|
||||||
{
|
{
|
||||||
@@ -3629,12 +3632,9 @@ void wxWindowGTK::GtkSetBackgroundColour( const wxColour &colour )
|
|||||||
// We need the pixel value e.g. for background clearing.
|
// We need the pixel value e.g. for background clearing.
|
||||||
m_backgroundColour.CalcPixel( gdk_window_get_colormap( window ) );
|
m_backgroundColour.CalcPixel( gdk_window_get_colormap( window ) );
|
||||||
|
|
||||||
if ((m_wxwindow) &&
|
if (m_wxwindow)
|
||||||
(m_backgroundColour != wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE)))
|
|
||||||
{
|
{
|
||||||
/* wxMSW doesn't clear the window here. I don't do that either to
|
// wxMSW doesn't clear the window here, either.
|
||||||
provide compatibility. call Clear() to do the job. */
|
|
||||||
|
|
||||||
gdk_window_set_background( window, m_backgroundColour.GetColor() );
|
gdk_window_set_background( window, m_backgroundColour.GetColor() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1569,9 +1569,7 @@ void wxWindowDC::Clear()
|
|||||||
|
|
||||||
if (m_owner)
|
if (m_owner)
|
||||||
{
|
{
|
||||||
int width,height;
|
m_owner->Clear();
|
||||||
m_owner->GetSize( &width, &height );
|
|
||||||
gdk_draw_rectangle( m_window, m_bgGC, TRUE, 0, 0, width, height );
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -3467,8 +3467,43 @@ void wxWindowGTK::GtkSendPaintEvents()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// widget to draw on
|
||||||
|
GtkPizza *pizza = GTK_PIZZA (m_wxwindow);
|
||||||
|
|
||||||
|
// Clip to paint region in wxClientDC
|
||||||
m_clipPaintRegion = TRUE;
|
m_clipPaintRegion = TRUE;
|
||||||
|
|
||||||
|
if (GetThemeEnabled())
|
||||||
|
{
|
||||||
|
// find ancestor from which to steal background
|
||||||
|
wxWindow *parent = GetParent();
|
||||||
|
while (parent && !parent->IsTopLevel())
|
||||||
|
parent = parent->GetParent();
|
||||||
|
if (!parent)
|
||||||
|
parent = this;
|
||||||
|
|
||||||
|
wxRegionIterator upd( m_updateRegion );
|
||||||
|
while (upd)
|
||||||
|
{
|
||||||
|
GdkRectangle rect;
|
||||||
|
rect.x = upd.GetX();
|
||||||
|
rect.y = upd.GetY();
|
||||||
|
rect.width = upd.GetWidth();
|
||||||
|
rect.height = upd.GetHeight();
|
||||||
|
|
||||||
|
gtk_paint_flat_box( parent->m_widget->style,
|
||||||
|
pizza->bin_window,
|
||||||
|
GTK_STATE_NORMAL,
|
||||||
|
GTK_SHADOW_NONE,
|
||||||
|
&rect,
|
||||||
|
parent->m_widget,
|
||||||
|
(char *)"base",
|
||||||
|
0, 0, -1, -1 );
|
||||||
|
|
||||||
|
upd ++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
// if (!m_clearRegion.IsEmpty()) // always send an erase event
|
// if (!m_clearRegion.IsEmpty()) // always send an erase event
|
||||||
{
|
{
|
||||||
wxWindowDC dc( (wxWindow*)this );
|
wxWindowDC dc( (wxWindow*)this );
|
||||||
@@ -3481,46 +3516,16 @@ void wxWindowGTK::GtkSendPaintEvents()
|
|||||||
{
|
{
|
||||||
if (!g_eraseGC)
|
if (!g_eraseGC)
|
||||||
{
|
{
|
||||||
g_eraseGC = gdk_gc_new( GTK_PIZZA(m_wxwindow)->bin_window );
|
g_eraseGC = gdk_gc_new( pizza->bin_window );
|
||||||
gdk_gc_set_fill( g_eraseGC, GDK_SOLID );
|
gdk_gc_set_fill( g_eraseGC, GDK_SOLID );
|
||||||
}
|
}
|
||||||
gdk_gc_set_foreground( g_eraseGC, m_backgroundColour.GetColor() );
|
gdk_gc_set_foreground( g_eraseGC, m_backgroundColour.GetColor() );
|
||||||
|
|
||||||
// widget to draw on
|
|
||||||
GtkPizza *pizza = GTK_PIZZA (m_wxwindow);
|
|
||||||
|
|
||||||
// find ancestor from which to steal background
|
|
||||||
wxWindow *parent = GetParent();
|
|
||||||
while (parent && !parent->IsTopLevel())
|
|
||||||
parent = parent->GetParent();
|
|
||||||
if (!parent)
|
|
||||||
parent = this;
|
|
||||||
|
|
||||||
wxRegionIterator upd( m_clearRegion );
|
wxRegionIterator upd( m_clearRegion );
|
||||||
while (upd)
|
while (upd)
|
||||||
{
|
{
|
||||||
if (GetThemeEnabled())
|
gdk_draw_rectangle( pizza->bin_window, g_eraseGC, 1,
|
||||||
{
|
upd.GetX(), upd.GetY(), upd.GetWidth(), upd.GetHeight() );
|
||||||
GdkRectangle rect;
|
|
||||||
rect.x = upd.GetX();
|
|
||||||
rect.y = upd.GetY();
|
|
||||||
rect.width = upd.GetWidth();
|
|
||||||
rect.height = upd.GetHeight();
|
|
||||||
|
|
||||||
gtk_paint_flat_box( parent->m_widget->style,
|
|
||||||
pizza->bin_window,
|
|
||||||
GTK_STATE_NORMAL,
|
|
||||||
GTK_SHADOW_NONE,
|
|
||||||
&rect,
|
|
||||||
parent->m_widget,
|
|
||||||
(char *)"base",
|
|
||||||
0, 0, -1, -1 );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
gdk_draw_rectangle( pizza->bin_window, g_eraseGC, 1,
|
|
||||||
upd.GetX(), upd.GetY(), upd.GetWidth(), upd.GetHeight() );
|
|
||||||
}
|
|
||||||
upd ++;
|
upd ++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -3543,8 +3548,6 @@ void wxWindowGTK::GtkSendPaintEvents()
|
|||||||
// being redrawn because the wxWindows class is allowed to
|
// being redrawn because the wxWindows class is allowed to
|
||||||
// paint over the window-less widgets.
|
// paint over the window-less widgets.
|
||||||
|
|
||||||
GtkPizza *pizza = GTK_PIZZA(m_wxwindow);
|
|
||||||
|
|
||||||
GList *children = pizza->children;
|
GList *children = pizza->children;
|
||||||
while (children)
|
while (children)
|
||||||
{
|
{
|
||||||
@@ -3629,12 +3632,9 @@ void wxWindowGTK::GtkSetBackgroundColour( const wxColour &colour )
|
|||||||
// We need the pixel value e.g. for background clearing.
|
// We need the pixel value e.g. for background clearing.
|
||||||
m_backgroundColour.CalcPixel( gdk_window_get_colormap( window ) );
|
m_backgroundColour.CalcPixel( gdk_window_get_colormap( window ) );
|
||||||
|
|
||||||
if ((m_wxwindow) &&
|
if (m_wxwindow)
|
||||||
(m_backgroundColour != wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE)))
|
|
||||||
{
|
{
|
||||||
/* wxMSW doesn't clear the window here. I don't do that either to
|
// wxMSW doesn't clear the window here, either.
|
||||||
provide compatibility. call Clear() to do the job. */
|
|
||||||
|
|
||||||
gdk_window_set_background( window, m_backgroundColour.GetColor() );
|
gdk_window_set_background( window, m_backgroundColour.GetColor() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user