GtkGrid demo5.c

  • 结合GtkEventBox使用
#include <gtk/gtk.h>

#define EVENTS_MASK (GDK_ENTER_NOTIFY_MASK | GDK_LEAVE_NOTIFY_MASK)

static GtkWidget *create_window(const gint, const gint);
static void load_css(void);
static GtkWidget *createChild(gchar *, gint, gint, gint, gchar *);

gboolean enter_cb(GtkWidget *widget, GdkEvent *event);
gboolean leave_cb(GtkWidget *widget, GdkEvent *event);

int main(void)
{
    GtkWidget *window;
    GtkWidget *grid;
    GtkWidget *child1;
    GtkWidget *child2;
    GtkWidget *child3;
    GtkWidget *child4;

    gtk_init(NULL, NULL);
    load_css();

    window = create_window(400, 400);
    g_signal_connect(window, "destroy", G_CALLBACK(gtk_main_quit), NULL);

    grid = gtk_grid_new();
    gtk_container_add(GTK_CONTAINER(window), grid);

    child1 = createChild("myChild", 3, 100, 100, "1");
    child2 = createChild("myChild", 3, 100, 100, "2");
    child3 = createChild("myChild", 3, 100, 100, "3");
    child4 = createChild("myChild", 3, 100, 100, "4");

    gtk_grid_attach(GTK_GRID(grid), child4, 0, 0, 1, 1);
    gtk_grid_insert_row(GTK_GRID(grid), 0);

    gtk_grid_attach(GTK_GRID(grid), child3, 1, 0, 1, 1);
    gtk_grid_insert_row(GTK_GRID(grid), 0);

    gtk_grid_attach(GTK_GRID(grid), child2, 2, 0, 1, 1);
    gtk_grid_insert_row(GTK_GRID(grid), 0);

    gtk_grid_attach(GTK_GRID(grid), child1, 3, 0, 1, 1);

    gtk_widget_show_all(window);
    gtk_main();

    return 0;
}

static GtkWidget *create_window(const gint w, const gint h)
{
    GtkWidget *window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
    gtk_window_set_default_size(GTK_WINDOW(window), w, h);
    gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER);
    gtk_window_set_title(GTK_WINDOW(window), "Hello Grid");

    return window;
}

static void load_css(void)
{
    GtkCssProvider *provider;
    GdkDisplay *display;
    GdkScreen *screen;

    const char *css_style_file = "style.css";
    GFile *css_fp = g_file_new_for_path(css_style_file);
    GError *error = 0;

    provider = gtk_css_provider_new();
    display = gdk_display_get_default();
    screen = gdk_display_get_default_screen(display);

    gtk_style_context_add_provider_for_screen(screen, GTK_STYLE_PROVIDER(provider), GTK_STYLE_PROVIDER_PRIORITY_APPLICATION);
    gtk_css_provider_load_from_file(provider, css_fp, &error);

    g_object_unref(provider);
}

static GtkWidget *createChild(gchar *name, gint spacing, gint width, gint height, gchar *text)
{

    GtkWidget *child = gtk_grid_new();
    GtkWidget *eventBox = gtk_event_box_new();
    GtkWidget *label = gtk_label_new(NULL);

    // set events and catch the enter and leave signals
    gtk_widget_set_events(eventBox, EVENTS_MASK);
    g_signal_connect_swapped(eventBox, "enter_notify_event", G_CALLBACK(enter_cb), child);
    g_signal_connect_swapped(eventBox, "leave_notify_event", G_CALLBACK(leave_cb), child);

    gtk_container_add(GTK_CONTAINER(child), eventBox);
    gtk_container_add(GTK_CONTAINER(eventBox), label);

    g_object_set(label,
                 "label", text,
                 "name", "myLabel",
                 "margin", 40,
                 "selectable", TRUE, // 先前不怎么懂这个函数,用这个测试了一下,稍微懂了
                 "tooltip-text", text,
                 NULL);

    gtk_widget_set_name(child, name);
    gtk_widget_set_size_request(child, width, height);
    gtk_container_set_border_width(GTK_CONTAINER(child), spacing);

    return child;
}

gboolean enter_cb(GtkWidget *widget, GdkEvent *event)
{
    if (event->type == GDK_ENTER_NOTIFY)
    {
        g_print("Enter\n");
        gtk_widget_set_name(widget, "HOVER");
        return TRUE;
    }

    return FALSE;
}

gboolean leave_cb(GtkWidget *widget, GdkEvent *event)
{
    if (event->type == GDK_LEAVE_NOTIFY)
    {
        g_print("Leave\n");
        gtk_widget_set_name(widget, "myChild");
        return TRUE;
    }

    return FALSE;
}
// style.css
window {
    background-color:bisque;
}


grid {
    background-color: coral;
}

#myChild {
    background-color:blueviolet
}

#HOVER {
background-color: cadetblue;
}
  • 效果:

在这里插入图片描述
当鼠标进入到四个矩形之后会变色,试一下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值