#include "wx/dc.h"
#include "wx/dcclient.h"
-#if !USE_SHARED_LIBRARY
-IMPLEMENT_DYNAMIC_CLASS(wxStatusBarMac, wxStatusBarGeneric);
-
BEGIN_EVENT_TABLE(wxStatusBarMac, wxStatusBarGeneric)
EVT_PAINT(wxStatusBarMac::OnPaint)
END_EVENT_TABLE()
-#endif //USE_SHARED_LIBRARY
+#ifdef __WXMAC__
+#include "wx/mac/private.h"
+#endif
// ============================================================================
// implementation
wxRect rect;
GetFieldRect(i, rect);
+
+ if ( !IsWindowHilited( MAC_WXHWND( MacGetRootWindow() ) ) )
+ {
+ dc.SetTextForeground( wxColour( 0x80 , 0x80 , 0x80 ) ) ;
+ }
wxString text(GetStatusText(i));
DrawFieldText(dc, i);
}
+void wxStatusBarMac::SetStatusText(const wxString& text, int number)
+{
+ wxCHECK_RET( (number >= 0) && (number < m_nFields),
+ _T("invalid status bar field index") );
+
+ m_statusStrings[number] = text;
+ wxRect rect;
+ GetFieldRect(number, rect);
+ Refresh( TRUE , &rect ) ;
+ /*
+ // TODO make clear work again also when using themes
+ wxClientDC dc(this);
+ dc.SetBackground( wxBrush(GetBackgroundColour(), wxSOLID) );
+ dc.SetClippingRegion( rect.x+1, rect.y+1, rect.width-1, rect.height-1 );
+ dc.Clear();
+ dc.DestroyClippingRegion();
+ DrawFieldText( dc, number );
+ */
+
+}
+
void wxStatusBarMac::OnPaint(wxPaintEvent& WXUNUSED(event) )
{
wxPaintDC dc(this);
- wxPen black( wxBLACK , 1 , wxSOLID ) ;
+
+ if ( IsWindowHilited( MAC_WXHWND( MacGetRootWindow() ) ) )
+ {
+ wxPen black( wxBLACK , 1 , wxSOLID ) ;
wxPen white( wxWHITE , 1 , wxSOLID ) ;
dc.SetPen(black);
dc.SetPen(white);
dc.DrawLine(0, 1 ,
m_width , 1);
-
+ }
+ else
+ {
+ dc.SetPen(wxPen(wxColour(0x80,0x80,0x80),1,wxSOLID));
+ dc.DrawLine(0, 0 ,
+ m_width , 0);
+ }
int i;
if ( GetFont().Ok() )
dc.SetFont(wxNullFont);
# endif // MSW
}
+
+void wxStatusBarMac::MacSuperEnabled( bool enabled )
+{
+ Refresh(FALSE) ;
+ wxWindow::MacSuperEnabled( enabled ) ;
+}