前面,我们说到了label,这里可以看一下label运行的效果是怎么样的。
大家可以对照上面的结果图,看看我们之前的描述是否正确。
说完了label,可以看看button是怎么设计的。button是gui设计中的一个基本控件。通常我们按下了一个button,意味着此时想处理一个事情。具体是什么事情,完全可以通过设定一个回调函数来编写完成。同样,我们可以用一段demo代码来说明问题。
#include "ftk.h"
#define IDC_TEST_BUTTON 1000
static Ret button_quit_clicked(void* ctx, void* obj)
{
ftk_quit();
return RET_OK;
}
static Ret button_hide_clicked(void* ctx, void* obj)
{
ftk_widget_show(ftk_widget_lookup(ctx, IDC_TEST_BUTTON), 0);
return RET_OK;
}
static Ret button_show_clicked(void* ctx, void* obj)
{
ftk_widget_show(ftk_widget_lookup(ctx, IDC_TEST_BUTTON), 1);
return RET_OK;
}
static Ret button_default_clicked(void* ctx, void* obj)
{
printf("%s: button %s is clicked.\n", __func__, ftk_widget_get_text(obj));
return RET_OK;
}
int FTK_MAIN(int argc, char* argv[])
{
int width = 0;
int height = 0;
FtkWidget* win = NULL;
FtkWidget* button = NULL;
ftk_init(argc, argv);
win = ftk_app_window_create();
width = ftk_widget_width(win);
height = ftk_widget_height(win);
width = width/3 - 10;
button = ftk_button_create(win, 0, 30, width, 50);
ftk_widget_set_text(button, "show");
ftk_button_set_clicked_listener(button, button_show_clicked, win);
button = ftk_button_create(win, width + 10, 30, width, 50);
ftk_widget_set_text(button, "hide");
ftk_button_set_clicked_listener(button, button_hide_clicked, win);
button = ftk_button_create(win, 2*(width + 10), 30, width, 50);
ftk_widget_set_text(button, "按钮测试");
ftk_widget_set_id(button, IDC_TEST_BUTTON);
ftk_button_set_clicked_listener(button, button_default_clicked, win);
button = ftk_button_create(win, 0, 130, width, 40);
ftk_widget_set_text(button, "yes");
ftk_button_set_clicked_listener(button, button_default_clicked, win);
button = ftk_button_create(win, 2*(width + 10), 130, width, 40);
ftk_widget_set_text(button, "no");
ftk_button_set_clicked_listener(button, button_default_clicked, win);
button = ftk_button_create(win, width + 10, height/2, width, 60);
ftk_widget_set_text(button, "quit");
ftk_button_set_clicked_listener(button, button_quit_clicked, win);
ftk_window_set_focus(win, button);
ftk_widget_set_text(win, "button demo");
ftk_widget_show_all(win, 1);
ftk_widget_set_attr(win, FTK_ATTR_QUIT_WHEN_CLOSE);
ftk_run();
return 0;
}
上面的代码有80行左右,但是流程不复杂。同样,代码在创建了一个win控件后,创建了六个button控件。它们依次是show、hide、按钮测试、yes、no、quit。当然,在创建button的时候,我们还得配置相应的回调函数,这里有四个回调函数。button_quit_clicked是quit使用,而button_default_clicked是缺省使用的回调函数。主要的两个函数还是button_show_clicked和button_hide_clicked,一个是显示button,一个是隐藏button,其中隐藏的button就是我们之前创建的“按钮测试”这个button。
想看看运行效果的朋友,敬请期待下面一篇博文。
标签:widget,set,clicked,win,button,学习,ftk From: https://blog.51cto.com/feixiaoxing/5880825