#include "wx/frame.h"
#include "wx/gtk/win_gtk.h"
+//-----------------------------------------------------------------------------
+// data
+//-----------------------------------------------------------------------------
+
+extern bool g_blockEventsOnDrag;
+
//-----------------------------------------------------------------------------
// wxRadioBox
//-----------------------------------------------------------------------------
-void gtk_radiobutton_clicked_callback( GtkWidget *WXUNUSED(widget), gpointer data )
+static void gtk_radiobutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxRadioBox *rb )
{
- wxRadioBox *rb = (wxRadioBox*)data;
+ if (!rb->HasVMT()) return;
+ if (g_blockEventsOnDrag) return;
+
+ if (rb->m_alreadySent)
+ {
+ rb->m_alreadySent = FALSE;
+ return;
+ }
+
+ rb->m_alreadySent = TRUE;
+
wxCommandEvent event( wxEVT_COMMAND_RADIOBOX_SELECTED, rb->GetId() );
event.SetInt( rb->GetSelection() );
wxString tmp( rb->GetStringSelection() );
event.SetString( WXSTRINGCAST(tmp) );
event.SetEventObject( rb );
- rb->ProcessEvent(event);
+ rb->GetEventHandler()->ProcessEvent(event);
};
//-----------------------------------------------------------------------------
{
};
-wxRadioBox::wxRadioBox( wxWindow *parent, const wxWindowID id, const wxString& title,
- const wxPoint &pos, const wxSize &size,
- const int n, const wxString choices[],
- const int majorDim, const long style,
+wxRadioBox::wxRadioBox( wxWindow *parent, wxWindowID id, const wxString& title,
+ const wxPoint &pos, const wxSize &size,
+ int n, const wxString choices[],
+ int majorDim, long style,
const wxString &name )
{
Create( parent, id, title, pos, size, n, choices, majorDim, style, name );
};
-bool wxRadioBox::Create( wxWindow *parent, const wxWindowID id, const wxString& title,
- const wxPoint &pos, const wxSize &size,
- const int n, const wxString choices[],
- const int WXUNUSED(majorDim), const long style,
+bool wxRadioBox::Create( wxWindow *parent, wxWindowID id, const wxString& title,
+ const wxPoint &pos, const wxSize &size,
+ int n, const wxString choices[],
+ int WXUNUSED(majorDim), long style,
const wxString &name )
{
+ m_alreadySent = FALSE;
m_needParent = TRUE;
PreCreation( parent, id, pos, size, style, name );
for (int i = 0; i < n; i++)
{
if (i) radio_button_group = gtk_radio_button_group( GTK_RADIO_BUTTON(m_radio) );
+
m_radio = GTK_RADIO_BUTTON( gtk_radio_button_new_with_label( radio_button_group, choices[i] ) );
if (!i) gtk_toggle_button_set_state( GTK_TOGGLE_BUTTON(m_radio), TRUE );
return TRUE;
};
-bool wxRadioBox::Show( const bool show )
+bool wxRadioBox::Show( bool show )
{
wxWindow::Show( show );
return TRUE;
};
-int wxRadioBox::FindString( const wxString& WXUNUSED(s) ) const
+int wxRadioBox::FindString( const wxString &s ) const
{
- return 0;
+ GSList *item = gtk_radio_button_group( m_radio );
+
+ int count = g_slist_length(item)-1;
+
+ while (item)
+ {
+ GtkButton *b = GTK_BUTTON( item->data );
+ GtkLabel *l = GTK_LABEL( b->child );
+ if (s == l->label) return count;
+ count--;
+ item = item->next;
+ };
+
+ return -1;
};
-void wxRadioBox::SetSelection( const int WXUNUSED(n) )
+void wxRadioBox::SetSelection( int n )
{
+ GSList *item = gtk_radio_button_group( m_radio );
+ item = g_slist_nth( item, g_slist_length(item)-n-1 );
+ if (!item) return;
+
+ GtkToggleButton *button = GTK_TOGGLE_BUTTON( item->data );
+
+ gtk_toggle_button_set_state( button, 1 );
};
int wxRadioBox::GetSelection(void) const
return -1;
};
-wxString wxRadioBox::GetString( const int WXUNUSED(n) ) const
+wxString wxRadioBox::GetString( int n ) const
{
- return "";
+ GSList *item = gtk_radio_button_group( m_radio );
+
+ item = g_slist_nth( item, g_slist_length(item)-n-1 );
+ if (!item) return "";
+
+ GtkToggleButton *button = GTK_TOGGLE_BUTTON( item->data );
+
+ GtkLabel *label = GTK_LABEL( GTK_BUTTON(button)->child );
+
+ return wxString( label->label );
};
wxString wxRadioBox::GetLabel(void) const
void wxRadioBox::SetLabel( const wxString& WXUNUSED(label) )
{
+ wxFAIL_MSG("wxRadioBox::SetLabel not implemented.");
};
-void wxRadioBox::SetLabel( const int WXUNUSED(item), const wxString& WXUNUSED(label) )
+void wxRadioBox::SetLabel( int WXUNUSED(item), const wxString& WXUNUSED(label) )
{
+ wxFAIL_MSG("wxRadioBox::SetLabel not implemented.");
};
-void wxRadioBox::SetLabel( const int WXUNUSED(item), wxBitmap *WXUNUSED(bitmap) )
+void wxRadioBox::SetLabel( int WXUNUSED(item), wxBitmap *WXUNUSED(bitmap) )
{
+ wxFAIL_MSG("wxRadioBox::SetLabel not implemented.");
};
-wxString wxRadioBox::GetLabel( const int WXUNUSED(item) ) const
+wxString wxRadioBox::GetLabel( int WXUNUSED(item) ) const
{
+ wxFAIL_MSG("wxRadioBox::GetLabel not implemented.");
return "";
};
-void wxRadioBox::Enable( const bool WXUNUSED(enable) )
+void wxRadioBox::Enable( bool WXUNUSED(enable) )
{
+ wxFAIL_MSG("wxRadioBox::Enable not implemented.");
};
-void wxRadioBox::Enable( const int WXUNUSED(item), const bool WXUNUSED(enable) )
+void wxRadioBox::Enable( int WXUNUSED(item), bool WXUNUSED(enable) )
{
+ wxFAIL_MSG("wxRadioBox::Enable not implemented.");
};
-void wxRadioBox::Show( const int WXUNUSED(item), const bool WXUNUSED(show) )
+void wxRadioBox::Show( int WXUNUSED(item), bool WXUNUSED(show) )
{
+ wxFAIL_MSG("wxRadioBox::Show not implemented.");
};
wxString wxRadioBox::GetStringSelection(void) const
return "";
};
-bool wxRadioBox::SetStringSelection( const wxString& WXUNUSED(s) )
+bool wxRadioBox::SetStringSelection( const wxString&s )
{
+ int res = FindString( s );
+ if (res == -1) return FALSE;
+ SetSelection( res );
return TRUE;
};
return 1;
};
-void wxRadioBox::SetNumberOfRowsOrCols( const int WXUNUSED(n) )
+void wxRadioBox::SetNumberOfRowsOrCols( int WXUNUSED(n) )
{
+ wxFAIL_MSG("wxRadioBox::SetNumberOfRowsOrCols not implemented.");
};