X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e1e955e14c1ce17f97fb559923ded1b1d0cdd6b8..520e470fdd0daef09c77938db642e4583933c90d:/src/gtk/combobox.cpp diff --git a/src/gtk/combobox.cpp b/src/gtk/combobox.cpp index 196b32a371..9db6be50b8 100644 --- a/src/gtk/combobox.cpp +++ b/src/gtk/combobox.cpp @@ -46,29 +46,16 @@ static void gtk_combo_clicked_callback( GtkWidget *WXUNUSED(widget), wxComboBox combo->GetEventHandler()->ProcessEvent(event); } -//----------------------------------------------------------------------------- -// size - -/* -static gint gtk_combo_size_callback( GtkCombo *widget, GtkAllocation* alloc, wxComboBox *win ) -{ - if (!win->HasVMT()) return FALSE; - if (g_blockEventsOnDrag) return FALSE; - if (!widget->button) return FALSE; - - widget->button->allocation.x = - alloc->width - widget->button->allocation.width; - - return FALSE; -} -*/ - //----------------------------------------------------------------------------- // wxComboBox //----------------------------------------------------------------------------- IMPLEMENT_DYNAMIC_CLASS(wxComboBox,wxControl) +BEGIN_EVENT_TABLE(wxComboBox, wxControl) + EVT_SIZE(wxComboBox::OnSize) +END_EVENT_TABLE() + bool wxComboBox::Create(wxWindow *parent, wxWindowID id, const wxString& value, const wxPoint& pos, const wxSize& size, int n, const wxString choices[], @@ -107,11 +94,8 @@ bool wxComboBox::Create(wxWindow *parent, wxWindowID id, const wxString& value, PostCreation(); -/* - gtk_signal_connect( GTK_OBJECT(m_widget), "size_allocate", - GTK_SIGNAL_FUNC(gtk_combo_size_callback), (gpointer)this ); -*/ - + ConnectWidget( GTK_COMBO(m_widget)->button ); + if (!value.IsNull()) SetValue( value ); Show( TRUE ); @@ -136,8 +120,15 @@ void wxComboBox::Append( const wxString &item, char *clientData ) { GtkWidget *list = GTK_COMBO(m_widget)->list; - GtkWidget *list_item; - list_item = gtk_list_item_new_with_label( item ); + GtkWidget *list_item = gtk_list_item_new_with_label( item ); + + if (m_hasOwnStyle) + { + GtkBin *bin = GTK_BIN( list_item ); + gtk_widget_set_style( bin->child, + gtk_style_ref( + gtk_widget_get_style( m_widget ) ) ); + } gtk_signal_connect( GTK_OBJECT(list_item), "select", GTK_SIGNAL_FUNC(gtk_combo_clicked_callback), (gpointer)this ); @@ -309,19 +300,31 @@ void wxComboBox::SetValue( const wxString& value ) void wxComboBox::Copy(void) { GtkWidget *entry = GTK_COMBO(m_widget)->entry; +#if (GTK_MINOR_VERSION == 1) + gtk_editable_copy_clipboard( GTK_EDITABLE(entry) ); +#else gtk_editable_copy_clipboard( GTK_EDITABLE(entry), 0 ); +#endif } void wxComboBox::Cut(void) { GtkWidget *entry = GTK_COMBO(m_widget)->entry; +#if (GTK_MINOR_VERSION == 1) + gtk_editable_cut_clipboard( GTK_EDITABLE(entry) ); +#else gtk_editable_cut_clipboard( GTK_EDITABLE(entry), 0 ); +#endif } void wxComboBox::Paste(void) { GtkWidget *entry = GTK_COMBO(m_widget)->entry; +#if (GTK_MINOR_VERSION == 1) + gtk_editable_paste_clipboard( GTK_EDITABLE(entry) ); +#else gtk_editable_paste_clipboard( GTK_EDITABLE(entry), 0 ); +#endif } void wxComboBox::SetInsertionPoint( long pos ) @@ -368,10 +371,58 @@ void wxComboBox::Remove(long from, long to) void wxComboBox::SetSelection( long WXUNUSED(from), long WXUNUSED(to) ) { + wxFAIL_MSG( "wxComboBox::SetSelection not implemented" ); } void wxComboBox::SetEditable( bool WXUNUSED(editable) ) { + wxFAIL_MSG( "wxComboBox::SetEditable not implemented" ); +} + +void wxComboBox::OnSize( wxSizeEvent &event ) +{ + wxControl::OnSize( event ); + + int w = 22; + + gtk_widget_set_usize( GTK_COMBO(m_widget)->entry, m_width-w-1, m_height ); + + gtk_widget_set_uposition( GTK_COMBO(m_widget)->button, m_x+m_width-w, m_y ); + gtk_widget_set_usize( GTK_COMBO(m_widget)->button, w, m_height ); +} + +void wxComboBox::SetFont( const wxFont &font ) +{ + wxWindow::SetFont( font ); + + GtkWidget *entry = GTK_COMBO(m_widget)->entry; + + gtk_widget_set_style( entry, + gtk_style_ref( + gtk_widget_get_style( m_widget ) ) ); + + GtkWidget *list = GTK_COMBO(m_widget)->list; + + GList *child = GTK_LIST(list)->children; + while (child) + { + GtkBin *bin = (GtkBin*) child->data; + gtk_widget_set_style( bin->child, + gtk_style_ref( + gtk_widget_get_style( m_widget ) ) ); + + child = child->next; + } +} + +GtkWidget* wxComboBox::GetConnectWidget(void) +{ + return GTK_COMBO(m_widget)->entry; +} + +bool wxComboBox::IsOwnGtkWindow( GdkWindow *window ) +{ + return ( (window == GTK_ENTRY( GTK_COMBO(m_widget)->entry )->text_area) || + (window == GTK_COMBO(m_widget)->button->window ) ); } -