1 /////////////////////////////////////////////////////////////////////////////
4 // Author: Robert Roebling
6 // Copyright: (c) 1998 Robert Roebling
7 // Licence: wxWindows licence
8 /////////////////////////////////////////////////////////////////////////////
10 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
11 #pragma implementation "button.h"
14 // For compilers that support precompilation, includes "wx.h".
15 #include "wx/wxprec.h"
21 #include "wx/button.h"
23 #include "wx/gtk/private.h"
25 //-----------------------------------------------------------------------------
27 //-----------------------------------------------------------------------------
31 //-----------------------------------------------------------------------------
33 //-----------------------------------------------------------------------------
35 extern void wxapp_install_idle_handler();
38 //-----------------------------------------------------------------------------
40 //-----------------------------------------------------------------------------
42 extern bool g_blockEventsOnDrag
;
44 //-----------------------------------------------------------------------------
46 //-----------------------------------------------------------------------------
48 static void gtk_button_clicked_callback( GtkWidget
*WXUNUSED(widget
), wxButton
*button
)
51 wxapp_install_idle_handler();
53 if (!button
->m_hasVMT
) return;
54 if (g_blockEventsOnDrag
) return;
56 wxCommandEvent
event(wxEVT_COMMAND_BUTTON_CLICKED
, button
->GetId());
57 event
.SetEventObject(button
);
58 button
->GetEventHandler()->ProcessEvent(event
);
61 //-----------------------------------------------------------------------------
63 //-----------------------------------------------------------------------------
65 IMPLEMENT_DYNAMIC_CLASS(wxButton
,wxControl
)
75 bool wxButton::Create( wxWindow
*parent
, wxWindowID id
, const wxString
&label
,
76 const wxPoint
&pos
, const wxSize
&size
,
77 long style
, const wxValidator
& validator
, const wxString
&name
)
80 m_acceptsFocus
= TRUE
;
82 if (!PreCreation( parent
, pos
, size
) ||
83 !CreateBase( parent
, id
, pos
, size
, style
, validator
, name
))
85 wxFAIL_MSG( wxT("wxButton creation failed") );
90 wxString label2( label );
91 for (size_t i = 0; i < label2.Len(); i++)
93 if (label2.GetChar(i) == wxT('&'))
94 label2.SetChar(i,wxT('_'));
97 GtkWidget *accel_label = gtk_accel_label_new( label2.mb_str() );
98 gtk_widget_show( accel_label );
100 m_widget = gtk_button_new();
101 gtk_container_add( GTK_CONTAINER(m_widget), accel_label );
103 gtk_accel_label_set_accel_widget( GTK_ACCEL_LABEL(accel_label), m_widget );
105 guint accel_key = gtk_label_parse_uline (GTK_LABEL(accel_label), label2.mb_str() );
106 gtk_accel_label_refetch( GTK_ACCEL_LABEL(accel_label) );
108 wxControl::SetLabel( label );
112 m_widget
= gtk_button_new_with_mnemonic("");
114 m_widget
= gtk_button_new_with_label("");
117 float x_alignment
= 0.5;
118 if (HasFlag(wxBU_LEFT
))
120 else if (HasFlag(wxBU_RIGHT
))
123 float y_alignment
= 0.5;
124 if (HasFlag(wxBU_TOP
))
126 else if (HasFlag(wxBU_BOTTOM
))
129 gtk_misc_set_alignment (GTK_MISC (BUTTON_CHILD (m_widget
)),
130 x_alignment
, y_alignment
);
134 if (style
& wxNO_BORDER
)
135 gtk_button_set_relief( GTK_BUTTON(m_widget
), GTK_RELIEF_NONE
);
137 gtk_signal_connect( GTK_OBJECT(m_widget
), "clicked",
138 GTK_SIGNAL_FUNC(gtk_button_clicked_callback
), (gpointer
*)this );
140 m_parent
->DoAddChild( this );
147 void wxButton::SetDefault()
149 wxWindow
*parent
= GetParent();
150 wxCHECK_RET( parent
, _T("button without parent?") );
152 parent
->SetDefaultItem(this);
154 GTK_WIDGET_SET_FLAGS( m_widget
, GTK_CAN_DEFAULT
);
155 gtk_widget_grab_default( m_widget
);
157 SetSize( m_x
, m_y
, m_width
, m_height
);
161 wxSize
wxButton::GetDefaultSize()
163 return wxSize(80,26);
166 void wxButton::SetLabel( const wxString
&label
)
168 wxCHECK_RET( m_widget
!= NULL
, wxT("invalid button") );
170 wxControl::SetLabel( label
);
173 wxString label2
= PrepareLabelMnemonics( label
);
174 gtk_button_set_label( GTK_BUTTON(m_widget
), wxGTK_CONV(label2
) );
176 gtk_label_set( GTK_LABEL( BUTTON_CHILD(m_widget
) ), wxGTK_CONV( GetLabel() ) );
180 bool wxButton::Enable( bool enable
)
182 if ( !wxControl::Enable( enable
) )
185 gtk_widget_set_sensitive( BUTTON_CHILD(m_widget
), enable
);
190 bool wxButton::IsOwnGtkWindow( GdkWindow
*window
)
193 return GTK_BUTTON(m_widget
)->event_window
;
195 return (window
== m_widget
->window
);
199 void wxButton::DoApplyWidgetStyle(GtkRcStyle
*style
)
201 gtk_widget_modify_style(m_widget
, style
);
202 gtk_widget_modify_style(BUTTON_CHILD(m_widget
), style
);
205 wxSize
wxButton::DoGetBestSize() const
207 // the default button in wxGTK is bigger than the other ones because of an
208 // extra border around it, but we don't want to take it into account in
209 // our size calculations (otherwsie the result is visually ugly), so
210 // always return the size of non default button from here
211 const bool isDefault
= GTK_WIDGET_HAS_DEFAULT(m_widget
);
214 // temporarily unset default flag
215 GTK_WIDGET_UNSET_FLAGS( m_widget
, GTK_CAN_DEFAULT
);
218 wxSize
ret( wxControl::DoGetBestSize() );
223 GTK_WIDGET_SET_FLAGS( m_widget
, GTK_CAN_DEFAULT
);
227 ret
.x
+= 10; // add a few pixels for sloppy (but common) themes
230 if (!HasFlag(wxBU_EXACTFIT
))
232 if (ret
.x
< 80) ret
.x
= 80;
240 wxButton::GetClassDefaultAttributes(wxWindowVariant
WXUNUSED(variant
))
242 return GetDefaultAttributesFromGTKWidget(gtk_button_new
);
245 #endif // wxUSE_BUTTON