- m_needParent = TRUE;
- m_acceptsFocus = TRUE;
-
- m_blockEvent = FALSE;
-
- if (!PreCreation(parent, pos, size) ||
- !CreateBase(parent, id, pos, size, style, validator, name ))
- {
- wxFAIL_MSG(wxT("wxToggleBitmapButton creation failed"));
- return FALSE;
- }
-
- m_bitmap = label;
-
- // Create the gtk widget.
- m_widget = gtk_toggle_button_new();
-
- if (style & wxNO_BORDER)
- gtk_button_set_relief( GTK_BUTTON(m_widget), GTK_RELIEF_NONE );
-
- if (m_bitmap.Ok())
- {
- wxSize newSize = size;
- int border = (style & wxNO_BORDER) ? 4 : 10;
- if (newSize.x == -1)
- newSize.x = m_bitmap.GetWidth()+border;
- if (newSize.y == -1)
- newSize.y = m_bitmap.GetHeight()+border;
- SetSize( newSize.x, newSize.y );
- OnSetBitmap();
- }
-
- gtk_signal_connect(GTK_OBJECT(m_widget), "clicked",
- GTK_SIGNAL_FUNC(gtk_togglebutton_clicked_callback),
- (gpointer *)this);
-
- m_parent->DoAddChild(this);
-
- PostCreation();
- InheritAttributes();
-
- Show( TRUE );
-
- return TRUE;
-}
-
-// void SetValue(bool state)
-// Set the value of the toggle button.
-void wxToggleBitmapButton::SetValue(bool state)
-{
- wxCHECK_RET(m_widget != NULL, wxT("invalid toggle button"));
-
- if (state == GetValue())
- return;
-
- m_blockEvent = TRUE;
-
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(m_widget), state);
-
- m_blockEvent = FALSE;
-}
-
-// bool GetValue() const
-// Get the value of the toggle button.
-bool wxToggleBitmapButton::GetValue() const
-{
- wxCHECK_MSG(m_widget != NULL, FALSE, wxT("invalid toggle button"));
-
- return GTK_TOGGLE_BUTTON(m_widget)->active;
-}
-
-void wxToggleBitmapButton::SetLabel(const wxBitmap& label)
-{
- wxCHECK_RET(m_widget != NULL, wxT("invalid toggle button"));
-
- m_bitmap = label;
-
- OnSetBitmap();
-}
-
-void wxToggleBitmapButton::OnSetBitmap()
-{
- if (!m_bitmap.Ok()) return;
-
- GdkBitmap *mask = (GdkBitmap *) NULL;
- if (m_bitmap.GetMask()) mask = m_bitmap.GetMask()->GetBitmap();
-
- GtkWidget *child = BUTTON_CHILD(m_widget);
- if (child == NULL)
- {
- // initial bitmap
- GtkWidget *pixmap = gtk_pixmap_new(m_bitmap.GetPixmap(), mask);
- gtk_widget_show(pixmap);
- gtk_container_add(GTK_CONTAINER(m_widget), pixmap);
- }
- else
- { // subsequent bitmaps
- GtkPixmap *g_pixmap = GTK_PIXMAP(child);
- gtk_pixmap_set(g_pixmap, m_bitmap.GetPixmap(), mask);
- }
-}
-
-bool wxToggleBitmapButton::Enable(bool enable /*=TRUE*/)
-{
- if (!wxControl::Enable(enable))
- return FALSE;