GTK Label响应点击事件

GtkWidget*m_label_yjdx_title = gtk_label_new(_c("点击查看更多"));
GtkWidget*m_eventbox_yjdx = gtk_event_box_new();
gtk_container_add(GTK_CONTAINER(m_eventbox_yjdx), m_label_yjdx_title);
gtk_widget_set_events(m_eventbox_yjdx, GDK_BUTTON_PRESS_MASK);
g_signal_connect(G_OBJECT(m_eventbox_yjdx), "button-press-event", G_CALLBACK(on_label_clicked), this);
gtk_box_pack_start(GTK_BOX(m_hbox_yjdx), m_eventbox_yjdx, TRUE, TRUE, 0);
//gtk_box_set_center_widget(GTK_BOX(m_hbox_query), m_eventbox_yjdx);//居中显示
gtk_widget_set_halign(m_eventbox_yjdx, GTK_ALIGN_CENTER);//居中显示
SetWidgetStyle(m_label_yjdx_title, "yjdx");//设置label css样式

//点击事件响应函数
gboolean on_label_clicked(GtkWidget* widget, GdkEventButton* event, gpointer user_data)
{
    int i = 0;
    return FALSE;
}

借助event box实现label点击事件,将label放在envent box中,将event box放在水平布局中并居中显示


上面的居中显示方式有问题,因为eventbox会填满整个水平布局,空白处也会响应点击事件,使用GtkAlignment则不存在这个问题:

// 创建 GtkAlignment 容器
GtkWidget* alignment = gtk_alignment_new(0.5, 0.5, 0, 0);
// 将控件添加到 GtkAlignment 容器
gtk_container_add(GTK_CONTAINER(alignment), m_eventbox_yjdx);
gtk_box_pack_start(GTK_BOX(m_hbox_query), alignment, TRUE, FALSE, 0);

将eventbox添加到alignment中,然后将alignment添加到水平布局中即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

vegetablesssss

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值