大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。
【声明:版权全部。欢迎转载,请勿用于商业用途。】
在上周末的博客中,我们谈到了list view,今天能够看看效果图怎样。
假设大家细心一点,能够发现list中的item有点差异,有兴趣的朋友能够思考一下原因是什么,事实上能够代码中看出来的。
今天,我们聊的是多窗体的问题。
大多数app。非常少是一个窗体上完毕全部的功能的。
闲话不多说,先看代码。
#include "ftk.h"
static void create_app_window(void);
static Ret button_open_clicked(void* ctx, void* obj)
{
create_app_window();
return RET_OK;
}
static Ret button_close_clicked(void* ctx, void* obj)
{
FtkWidget* win = ctx;
ftk_logd("%s: close window %s\n", __func__, ftk_widget_get_text(win));
ftk_widget_unref(win);
return RET_OK;
}
static int g_index = 0;
static void on_window_close(void* user_data)
{
g_index--;
ftk_logd("%s: g_index=%d\n", __func__, g_index);
if(g_index == 0)
{
ftk_quit();
}
return ;
}
static void create_app_window(void)
{
char title[32] = {0};
int width = 0;
int height = 0;
FtkWidget* win = ftk_app_window_create();
FtkWidget* label = NULL;
FtkWidget* button = NULL;
width = ftk_widget_width(win);
height = ftk_widget_height(win);
button = ftk_button_create(win, 0, height/6, width/3, 50);
ftk_widget_set_text(button, "创建窗体");
ftk_button_set_clicked_listener(button, button_open_clicked, win);
button = ftk_button_create(win, 2*width/3, height/6, width/3, 50);
ftk_widget_set_text(button, "关闭窗体");
ftk_button_set_clicked_listener(button, button_close_clicked, win);
snprintf(title, sizeof(title), "window%02d", g_index++);
label = ftk_label_create(win, width/4, height/2, width/2, 30);
ftk_widget_set_text(label, title);
ftk_widget_set_text(win, title);
ftk_widget_show_all(win, 1);
ftk_widget_set_user_data(win, on_window_close, win);
return;
}
int main(int argc, char* argv[])
{
ftk_init(argc, argv);
create_app_window();
ftk_run();
return 0;
}
从代码中。大家能够发现出现了流程中出现了一个create_app_window这个函数。
这个函数不仅出如今系统初始的流程中,并且出如今button_open_clicked这个函数中。这说明系统在初始执行的时候,就会创建一个窗体,并且以后每次单击“创建窗体”按钮的时候,也会在当前的窗体之上添加一个窗体。
当然假设想关闭当前窗体,直接单击“关闭窗体”这个按钮就能够了。
闲话不多说,下次上效果图。
版权声明:本文博主原创文章,博客,未经同意不得转载。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/117025.html原文链接:https://javaforall.cn