首页 > 其他分享 >ftk学习记(icon篇)

ftk学习记(icon篇)

时间:2022-11-23 12:04:32浏览次数:44  
标签:win button 学习 item ftk icon view



    在开始今天的文章之前,我们还是先看一下上一节的效果图。


ftk学习记(icon篇)_#define


    大家可以参照上一节的讲解,是不是存在这样的button,是不是存在这样的wait_box控件,同样是不是可以看到wait_box活动的情形。当然,有条件的朋友最好自己编译一下这个demo代码,按步骤调试每一行代码。


    今天,如标题所示,我们所学习的是icon的内容。简单一点说,此次主要的目的就是想在窗口上显示icon图像的内容。至于如何显示,大家可以跟着我一起看一下demo代码是如何编写的。



#include "ftk.h"

#define IDC_TEST_BUTTON 1000
static Ret button_quit_clicked(void* ctx, void* obj)
{
ftk_quit();

return RET_OK;
}

static int i = 0;
static Ret button_more_clicked(void* ctx, void* obj)
{
int j = 0;
FtkIconViewItem item;
FtkWidget* icon_view = ftk_widget_lookup(ctx, 100);
item.icon = ftk_theme_load_image(ftk_default_theme(), "flag-32.png");

for(j=0; j < 4; j++)
{
char text[100] = {0};
ftk_snprintf(text, sizeof(text), "%d", i);
item.text = text;
ftk_bitmap_ref(item.icon);
item.user_data = (void*)i;
ftk_icon_view_add(icon_view, &item);
i+=1000;
}
ftk_bitmap_unref(item.icon);

return RET_OK;
}

static Ret item_clicked(void* ctx, void* obj)
{
FtkIconViewItem* item = obj;

ftk_logd("%s: %s: user_data=%d\n", __func__, item->text, item->user_data);

return RET_OK;
}

int FTK_MAIN(int argc, char* argv[])
{
int width = 0;
int height = 0;
FtkWidget* win = NULL;
FtkWidget* button = NULL;
FtkWidget* icon_view = NULL;
FtkIconViewItem item;
ftk_init(argc, argv);

win = ftk_app_window_create();
width = ftk_widget_width(win);
height = ftk_widget_height(win);

button = ftk_button_create(win, 10, 0, width/3-10, 60);
ftk_widget_set_text(button, "more");
ftk_button_set_clicked_listener(button, button_more_clicked, win);
ftk_window_set_focus(win, button);

button = ftk_button_create(win, 2*width/3, 0, width/3-10, 60);
ftk_widget_set_text(button, "quit");
ftk_button_set_clicked_listener(button, button_quit_clicked, win);
ftk_window_set_focus(win, button);

item.icon = ftk_theme_load_image(ftk_default_theme(), "flag-32.png");
icon_view = ftk_icon_view_create(win, 5, 70, width-10, height-80);
ftk_widget_set_id(icon_view, 100);
ftk_icon_view_set_clicked_listener(icon_view, item_clicked, win);
for(; i < 4; i++)
{
char text[100] = {0};
ftk_snprintf(text, sizeof(text), "%d", i);
item.text = text;
item.user_data = (void*)i;
ftk_icon_view_add(icon_view, &item);
}

ftk_bitmap_unref(item.icon);
ftk_widget_set_text(win, "icon view demo");
ftk_widget_show_all(win, 1);
ftk_widget_set_attr(win, FTK_ATTR_QUIT_WHEN_CLOSE);

ftk_run();

return 0;
}

 

icon_view、item等对象。button对象,我们之前已经讨论过很多次了,这次忽略不考虑。此次主要学习的是icon_view这个对象,它的主要目的就是在window中创建一片icon_view空间,创建成功之后,我们就可以通过函数ftk_icon_view_add向里面添加item对象了。是不是很简单呢?那button这里是起什么作用呢,我们可以继续往下看。如果仔细看一下,大家可以发现button_more_clicked中的内容和main函数中的内容差不多,无非就是向icon_view对象中多添加了几个item而已。当然,每个item在被选中的时候,系统都会调用call back函数item_clicked进行必要的额外操作。


    欲看效果如何,且听下回分解。




标签:win,button,学习,item,ftk,icon,view
From: https://blog.51cto.com/feixiaoxing/5880815

相关文章

  • ftk学习记(waitbox篇)
      前面说到了脚本,那么就看看ftk中demo与script搭配的效果是什么样的?  上面的效果图就类似于一个通讯录的输入功能,大家可以和之前的脚本对照起来看,检查一下是不是这......
  • ftk学习记(对话框篇)
      前面谈到了输入法,首先看一看效果。  上面有4个输入框,大家可以分别试试,看看效果如何。  今天,我们要说的是对话框。直接看demo代码好了,#include"ftk.h"static......
  • ftk学习记(输入法篇)
      前面说的是全屏设置,还是请大家看一下效果图。  想看全屏效果的,可以单击一下左边的button。如果恢复到原来的结果呢,单击一下右边的button。  所以这个demo其实......
  • ftk学习记(窗口全屏设置篇)
         好久不写博客了,今天续上。但是,我们还是看一下上一期的运行结果,  上面窗口中有5个button,有机会的朋友可以编译、运行一把。  今天,我们的文章比较简单,也......
  • ftk学习记(消息框篇)
      上一篇说到了输入框。闲话不多说,首先看结果显示,  大家看看效果是不是和我们之前说的一样。今天,我们谈一下消息狂。这种消息框其实应用得特别多,有警告用的,有提问的......
  • ftk学习记(进度条篇)
      首先,在开始今天的文章之前,我们还是给朋友们展示一下前面一段代码的运行效果。效果如下,  有兴趣的朋友可以找到这段代码,看一下运行的效果如何。  今天,我们可以......
  • ftk学习记(button篇)
      前面,我们说到了label,这里可以看一下label运行的效果是怎么样的。  大家可以对照上面的结果图,看看我们之前的描述是否正确。  说完了label,可以看看button是怎......
  • ftk学习记(首篇)
        很早之前就知道ftk了,当时主要是因为买了李先静的书,所以知道了这么一个项目。因为对这种gui的代码很感兴趣,所以在我闲暇的时候也会拿来看一看。从整个工程来看,代码......
  • ftk学习记(label篇)
      还是接着上面的一篇博文。之前曾经答应过大家,让大家看一下最简单的ftk程序是怎么运行的。所以,这里我们上传一下图片。  因为还是编辑模式,所以暂时还不能看到图片......
  • MarkDown学习
    Markdown学习标题一级标题#+标题名二级标题##+标题名三级标题###+标题名字体正常字体Hello,World!Hello,World!文字两边加双星号为加粗字体Hello,World!......