gtk + 3.x键绑定 - 挣扎

时间:2013-07-26 16:37:58

标签: c gtk

我已经尝试了一些事情,可能已经接近解决方案但是这里......

在一个(可能实现的)小部件上,有没有人有一个好的例子说 GtkEntry小部件接收 ALT + 向下 CTRL + n 按键将会引发 一个“新的”信号,例如小部件上的SIG-NEW。我知道如何抓住g_signal_connect

1 个答案:

答案 0 :(得分:1)

我附上了一个最小的工作示例。

重点是将key-press-event - GtkEntry实例连接到合适的回调。在该回调中,您必须提取GdkEventKey结构,该结构是GdkEvent结构的成员,该结构是回调函数的参数。

GdkEventKey包含检查按下了哪个键+修饰符所需的所有信息。

由于我使用gtk+-3.0测试了代码,您可能需要修改小部件的GdkEventMask以接收key-press-event。对于gtk+-3.0,它似乎已经是默认设置。如果未调用回调,则应使用gdk_window_set_events ()启用它(当然,您必须在窗口小部件的gdk窗口中调用它)。

#include <gtk/gtk.h>
#include <glib.h>

gboolean
key_press_event_cb (GtkWidget * widget, GdkEvent * event,
                    gpointer data)
{
    GdkEventKey key = event->key;

    /* check modifier key */
    /* on most keyboards GDK_MOD1_MASK is the Alt key */
    if (key.state == GDK_MOD1_MASK) {

        /* check for key that was pressed */
        switch (key.keyval) {
            case GDK_KEY_d:
                g_print
                    ("`Alt-d` deletes the content in the entry box\n");
                gtk_entry_set_text (GTK_ENTRY (widget), "");
                break;
        }

    }

    /* check for unmodified key presses */
    switch (key.keyval) {
        case GDK_KEY_x:
            g_print
                ("`x` deletes the content in the entry box\n");
            gtk_entry_set_text (GTK_ENTRY (widget), "");
            return TRUE;
            break;
    }

    return FALSE;
}

int
main (int argc, char *argv[])
{
    GtkWidget *window;
    GtkWidget *entry;

    gtk_init (&argc, &argv);

    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
    entry = gtk_entry_new ();

    gtk_container_add (GTK_CONTAINER (window), entry);
    gtk_widget_show_all (window);

    g_signal_connect (window, "destroy",
                      G_CALLBACK (gtk_main_quit), NULL);
    g_signal_connect (entry, "key-press-event",
                      G_CALLBACK (key_press_event_cb), NULL);

    gtk_main ();

    return 0;
}