EventBox

Algunos widgets de gtkmm no tienen X-Windows asociadas; dibujan en las ventanas de sus padres. Es por esto que no pueden recibir eventos. Además, si tienen el tamaño incorrecto, no se recortan, por lo que puede aparecer sobrescritura errónea, etc. Para recibir eventos en uno de estos widgets, puede ponerlo dentro de un widget EventBox y después llamar a Gtk::Widget::set_events() en la «EventBox» antes de mostrarlo.

A pesar de que el nombre EventBox hace énfasis en el método de manipulación de eventos, el widget también puede usarse para recortar (y para más cosas; consulte el ejemplo más abajo).

El constructor de Gtk::EventBox es:

Gtk::EventBox();

Se puede agregar un widget hijo a EventBox utilizando:

event_box.add(child_widget);

Referencia

15.1.1. Ejemplo

El siguiente ejemplo demuestra ambos usos de una EventBox: se crea una etiqueta que se adjunta a un pequeño cuadro, configurada de manera que una pulsación del ratón en ella hace que el programa termine. Redimensionar la ventana revelará partes variables de la etiqueta.

Figura 15-1EventBox

Código fuente

File: examplewindow.h (For use with gtkmm 3, not gtkmm 2)

#ifndef GTKMM_EXAMPLEWINDOW_H
#define GTKMM_EXAMPLEWINDOW_H

#include <gtkmm.h>

class ExampleWindow : public Gtk::Window
{
public:
  ExampleWindow();
  virtual ~ExampleWindow();

protected:
  //Signal handlers:
  virtual bool on_eventbox_button_press(GdkEventButton* event);

  //Child widgets:
  Gtk::EventBox m_EventBox;
  Gtk::Label m_Label;
};

#endif //GTKMM_EXAMPLEWINDOW_H

File: examplewindow.cc (For use with gtkmm 3, not gtkmm 2)

#include "examplewindow.h"

ExampleWindow::ExampleWindow()
: m_Label("Click here to quit, quit, quit, quit, quit")
{
  set_title ("EventBox");
  set_border_width(10);

  add(m_EventBox);

  m_EventBox.add(m_Label);

  //Clip the label short:
  m_Label.set_size_request(110, 20);

  //And bind an action to it:
  m_EventBox.set_events(Gdk::BUTTON_PRESS_MASK);
  m_EventBox.signal_button_press_event().connect(
    sigc::mem_fun(*this, &ExampleWindow::on_eventbox_button_press) );

  m_EventBox.set_tooltip_text("Click me!");

  show_all_children();
}

ExampleWindow::~ExampleWindow()
{
}

bool ExampleWindow::on_eventbox_button_press(GdkEventButton*)
{
  hide();
  return true;
}

File: main.cc (For use with gtkmm 3, not gtkmm 2)

#include "examplewindow.h"
#include <gtkmm/application.h>

int main(int argc, char *argv[])
{
  Glib::RefPtr<Gtk::Application> app = Gtk::Application::create(argc, argv, "org.gtkmm.example");

  ExampleWindow window;

  //Shows the window and returns when it is closed.
  return app->run(window);
}