GtkRevealer(1)

GtkRevealer

GtkRevealer — Hide and show with animation

Description

The GtkRevealer widget is a container which animates the transition of its child from invisible to visible.

Object Hierarchy

在这里插入图片描述

📚 学习官网

这一篇 的学习目标是实现:点击按钮后,若输入框的状态是隐藏的,则显示输入框;否则,反之。

#include <gtk/gtk.h>

static GtkWidget *create_window(const gint, const gint, const gchar *);

void show_revealer_child(GtkButton *button, gpointer data)
{
	g_return_if_fail(GTK_IS_BUTTON(button));

	GtkRevealer *revealer = data;
	/// *** 获取button中的label
	GtkWidget *label = gtk_bin_get_child(GTK_BIN(button));

	/// *** 如果entry隐藏了,则点击按钮时会显示entry;否则,反之。
	gboolean flag = gtk_revealer_get_child_revealed(GTK_REVEALER(revealer));
	if (!flag)
	{
		if (label != NULL && GTK_IS_LABEL(label))
			gtk_label_set_label(GTK_LABEL(label), "隐藏entry");
		gtk_revealer_set_reveal_child(GTK_REVEALER(revealer), TRUE);
	}
	else
	{
		if (label != NULL && GTK_IS_LABEL(label))
			gtk_label_set_label(GTK_LABEL(label), "显示entry");
		gtk_revealer_set_reveal_child(GTK_REVEALER(revealer), FALSE);
	}
}

int main(int argc, char *argv[])
{
	gtk_init(&argc, &argv);

	GtkWidget *window;
	GtkWidget *grid;
	GtkWidget *revealer;
	GtkWidget *button;
	GtkWidget *entry;

	/// *** Create a Window
	window = create_window(400, 500, "Hello GTK3");
	/// *** grid
	grid = gtk_grid_new();
	gtk_grid_set_column_homogeneous(GTK_GRID(grid), FALSE);
	gtk_grid_set_row_homogeneous(GTK_GRID(grid), FALSE);
	gtk_container_add(GTK_CONTAINER(window), grid);
	/// *** revealer
	revealer = gtk_revealer_new();
	gtk_grid_attach(GTK_GRID(grid), revealer, 0, 1, 1, 1);
	/// *** button
	button = gtk_button_new_with_label("点击");
	gtk_grid_attach(GTK_GRID(grid), button, 0, 0, 1, 1);
	/// *** entry
	entry = gtk_entry_new();
	g_object_set(entry, "parent", revealer, "margin-top", 5, NULL);

	/// *** 设置entry的显示类型
	g_object_set(revealer, "transition-type", GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN, NULL);
	/// *** 隐藏entry
	gtk_revealer_set_reveal_child(GTK_REVEALER(revealer), FALSE);

	/// *** signals
	g_signal_connect(button, "clicked", G_CALLBACK(show_revealer_child), revealer);

	gtk_widget_show_all(window);
	gtk_main();
}

static GtkWidget *create_window(const gint w, const gint h, const gchar *title)
{
	GtkWidget *window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
	g_signal_connect(window, "destroy", G_CALLBACK(gtk_main_quit), NULL);
	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), title);
	gtk_container_set_border_width(GTK_CONTAINER(window), 50);

	return window;
}
  • 运行效果

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值