Επισκόπηση
Όποτε πατάτε ή απελευθερώνετε ένα πλήκτρο, εκπέμπεται ένα συμβάν. Μπορείτε να συνδέσετε έναν χειριστή σήματος για να επεξεργαστεί τέτοια συμβάντα.
Για να δεχτείτε τα συμβάντα του πληκτρολογίου, πρέπει πρώτα να; καλέσετε τη συνάρτηση Gtk::Widget::add_events() με λίγη μάσκα των συμβάντων που ενδιαφέρεστε. Το συμβάν χειριστή σήματος θα δεχτεί ένα όρισμα που εξαρτάται από τον τύπο του συμβάντος. Για συμβάντα πληκτρολογίου είναι ένας GdkEventKey*. Όπως περιγράφτηκε στο παράρτημα, ο χειριστής σήματος συμβάντος επιστρέφει μια τιμή Μπουλ, για να δείξει ότι το σήμα επεξεργάστηκε πλήρως (true) ή να επιτρέψει τη διάδοση του συμβάντος (false).
Για να προσδιορίσετε ποιο πλήκτρο πατήθηκε ή απελευθερώθηκε διαβάζετε την τιμή της GdkEventKey::keyval και την συγκρίνετε με μια σταθερά στο αρχείο κεφαλίδας <gdk/gdkkeysyms.h>. Οι καταστάσεις των πλήκτρων τροποποίησης (Shift, Ctrl, κλπ.) είναι διαθέσιμες ως σημαίες δυαδικών ψηφίων στη GdkEventKey::state.
Here's a simple example:
bool on_key_press_or_release_event(GdkEventKey* event)
{
if (event->type == GDK_KEY_PRESS &&
event->keyval == GDK_KEY_1 &&
(event->state & (GDK_SHIFT_MASK | GDK_CONTROL_MASK | GDK_MOD1_MASK)) == GDK_MOD1_MASK)
{
handle_alt_1_press(); // GDK_MOD1_MASK is normally the Alt key
return true;
}
return false;
}
Gtk::Entry m_entry; // in a class definition
// in the class constructor
m_entry.signal_key_press_event().connect( sigc::ptr_fun(&on_key_press_or_release_event) );
m_entry.signal_key_release_event().connect( sigc::ptr_fun(&on_key_press_or_release_event) );
m_entry.add_events(Gdk::KEY_PRESS_MASK | Gdk::KEY_RELEASE_MASK);
- 23.1.1. Παράδειγμα
23.1.1. Παράδειγμα
Σε αυτό το παράδειγμα υπάρχουν τρεις συντομεύσεις πληκτρολογίου: η Alt+1 επιλέγει το πρώτο ραδιοπλήκτρο, η Alt+2 επιλέγει το δεύτερο και το πλήκτρο Esc κρύβει (κλείνει) το παράθυρο. Ο προεπιλεγμένος χειριστής σήματος αντικαθίσταται, όπως περιγράφεται στην ενότητα Αντικατάσταση προεπιλεγμένων χειριστών σημάτων στο παράρτημα.
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();
private:
//Override default signal handler:
virtual bool on_key_press_event(GdkEventKey* event);
Gtk::Grid m_container;
Gtk::RadioButton m_first;
Gtk::RadioButton m_second;
};
#endif //GTKMM_EXAMPLEWINDOW_H
File: examplewindow.cc (For use with gtkmm 3, not gtkmm 2)
#include "examplewindow.h"
ExampleWindow::ExampleWindow()
{
set_title("Keyboard Events");
set_border_width(10);
add(m_container);
// Radio buttons:
m_first.set_label("First");
m_second.set_label("Second");
Gtk::RadioButton::Group group = m_first.get_group();
m_second.set_group(group);
m_first.set_active();
// Main Container:
m_container.add(m_first);
m_container.add(m_second);
// Events.
// We override the default event signal handler.
add_events(Gdk::KEY_PRESS_MASK);
show_all_children();
}
bool ExampleWindow::on_key_press_event(GdkEventKey* event)
{
//GDK_MOD1_MASK -> the 'alt' key(mask)
//GDK_KEY_1 -> the '1' key
//GDK_KEY_2 -> the '2' key
//select the first radio button, when we press alt + 1
if((event->keyval == GDK_KEY_1) &&
(event->state &(GDK_SHIFT_MASK | GDK_CONTROL_MASK | GDK_MOD1_MASK)) == GDK_MOD1_MASK)
{
m_first.set_active();
//returning true, cancels the propagation of the event
return true;
}
else if((event->keyval == GDK_KEY_2) &&
(event->state & (GDK_SHIFT_MASK | GDK_CONTROL_MASK | GDK_MOD1_MASK)) == GDK_MOD1_MASK)
{
//and the second radio button, when we press alt + 2
m_second.set_active();
return true;
}
else if(event->keyval == GDK_KEY_Escape)
{
//close the window, when the 'esc' key is pressed
hide();
return true;
}
//if the event has not been handled, call the base class
return Gtk::Window::on_key_press_event(event);
}
ExampleWindow::~ExampleWindow()
{
}
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);
}
