extern bool g_blockEventsOnDrag;
//-----------------------------------------------------------------------------
-// wxButton
+// "clicked"
//-----------------------------------------------------------------------------
-IMPLEMENT_DYNAMIC_CLASS(wxButton,wxControl)
-
static void gtk_button_clicked_callback( GtkWidget *WXUNUSED(widget), wxButton *button )
{
if (!button->HasVMT()) return;
button->GetEventHandler()->ProcessEvent(event);
}
+//-----------------------------------------------------------------------------
+// wxButton
//-----------------------------------------------------------------------------
+IMPLEMENT_DYNAMIC_CLASS(wxButton,wxControl)
+
wxButton::wxButton(void)
{
}
gtk_label_set( g_label, GetLabel() );
}
+void wxButton::Enable( bool enable )
+{
+ wxControl::Enable( enable );
+ GtkButton *bin = GTK_BUTTON( m_widget );
+ GtkWidget *label = bin->child;
+ gtk_widget_set_sensitive( label, enable );
+}
+
+void wxButton::SetFont( const wxFont &font )
+{
+ if (((wxFont*)&font)->Ok())
+ m_font = font;
+ else
+ m_font = *wxSWISS_FONT;
+
+ GtkButton *bin = GTK_BUTTON( m_widget );
+ GtkWidget *label = bin->child;
+
+ GtkStyle *style = (GtkStyle*) NULL;
+ if (!m_hasOwnStyle)
+ {
+ m_hasOwnStyle = TRUE;
+ style = gtk_style_copy( gtk_widget_get_style( label ) );
+ }
+ else
+ {
+ style = gtk_widget_get_style( label );
+ }
+
+ gdk_font_unref( style->font );
+ style->font = gdk_font_ref( m_font.GetInternalFont( 1.0 ) );
+
+ gtk_widget_set_style( label, style );
+}