挖坑网/填坑网 DebugDump Forum

别人挖坑默默填上,自己挖坑含泪填上。天下没有填不了的坑,只有不会填坑的人。来吧,加入我们,挖坑行,填坑你更行! 站长QQ: 516333132 点击这里给我发消息

您尚未登录。

#1 2018-02-22 10:51:47

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,544

step by step 制作 littlevgl gui的字库

step by step 制作 littlevgl gui的字库

参考网址1: font-converter
参考网址2: littlevgl/lv_utils

1. 下载install_bmfont_1.13.exe字体生成文件, 安装, 打开.

QQ20180222104950.pngQQ20180222104955.png

按上面的设置选项,导出选项,
然后执行 Options -> Export 导出文件.

2. 下载python脚本, 把上面生成的文件转为C:

wget https://raw.githubusercontent.com/littlevgl/lv_utils/master/font_conv/fnt2c.py
python fnt2c.py -f test -s 19969 -e 20223

hexing@ubuntu:/tmp$ python fnt2c.py -f test -s 19969 -e 20223
-----------------
Font converter for LittlevGL (BMFont .fnt -> .c .h)
Version: 2018-12-20 (based on Lars Ole Pontoppidan's script)
-----------------
Reading font description: test.fnt
Reading font bitmap: test_0.png
SETTINGS
Font: test
Output: test
Heght: 64
First unicode: 19969
Last unicode: 20223
Auto increment: OFF
-----------------
Writing output: test.c
Writing output: test.h
-----------------
RAEDY!

3. 把生成的 test.c, test.h 添加到Makefile,
   工程的入口main函数改为 lv_tutorial_fonts.c 的 lv_tutorial_fonts()

void lv_tutorial_fonts(void)
{
    /*Add the cyrillic character set to the ASCII*/
    lv_font_add(&font_test, NULL);

    /*Create a style and use the new font*/
    static lv_style_t style1;
    lv_style_copy(&style1, &lv_style_plain);
    style1.text.font = &font_test;

    /*Create a label and set new text*/
    lv_obj_t *label = lv_label_create(lv_scr_act(), NULL);
    lv_obj_set_pos(label, 10, 10);
    lv_label_set_style(label, &style1);
    lv_label_set_text(label, "万丁三今介仿份");      /*Use ASCII and Cyrillic letters together*/
}

离线

#2 2018-02-22 11:10:03

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,544

Re: step by step 制作 littlevgl gui的字库

https://github.com/littlevgl/lvgl/issues/78
这个帖子作者说要做一个font 的回调函数实现离散汉字字库
我觉得没什么必要,

QQ20180222110833.png

离线

#3 2018-02-22 16:46:35

qwert1213131
会员
注册时间: 2018-01-08
累计发帖: 22

Re: step by step 制作 littlevgl gui的字库

晕哥 说:

https://github.com/littlevgl/lvgl/issues/78
这个帖子作者说要做一个font 的回调函数实现离散汉字字库
我觉得没什么必要,

https://debugdump.com/files/members/3/QQ20180222110833.png

那个issue估计是考虑到单片机内存过小,选用一些固定的几个汉字,减少内存占用
如果只用某几个汉字,有没有其他什么好的办法可以实现

最近编辑记录 qwert1213131 (2018-02-22 16:47:45)

离线

#4 2018-02-22 19:13:25

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,544

Re: step by step 制作 littlevgl gui的字库

qwert1213131 说:

那个issue估计是考虑到单片机内存过小,选用一些固定的几个汉字,减少内存占用
如果只用某几个汉字,有没有其他什么好的办法可以实现

QQ20180222110833.png
我的办法就是这样,
用 code[] 代替 first_ascii, last_ascii,
如同 bitmap[], map[], width[] 那几个field,
通过查 code[]这个数组来定位 bitmap, map, width.
个人觉得这个方法最简便。

first_ascii, last_ascii,
这种方式不太适合东亚的字符集。

离线

#5 2018-02-22 19:52:45

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,544

Re: step by step 制作 littlevgl gui的字库

改成这样:

typedef struct _lv_font_struct
{
    uint32_t first_ascii;//delete
    uint32_t last_ascii;//delete
    const uint32_t *code;//insert
    uint8_t height_row;
    const uint8_t * bitmap;
    const uint32_t * map;
    const uint8_t * width;
    struct _lv_font_struct * next_page;    /*Pointer to a font extension*/
}lv_font_t;

这样就把离散的中文字体装入进去.

离线

#6 2018-05-05 21:52:53

775624981
会员
注册时间: 2018-05-05
累计发帖: 16

Re: step by step 制作 littlevgl gui的字库

标记一下

离线

#7 2018-05-07 14:58:07

775624981
会员
注册时间: 2018-05-05
累计发帖: 16

Re: step by step 制作 littlevgl gui的字库

晕哥,上面的工具链接都失效了啊,下载不了啊

离线

#8 2018-05-07 15:01:57

晕哥
Administrator
注册时间: 1970-01-01
累计发帖: 2,544

Re: step by step 制作 littlevgl gui的字库

现在已经改成这样了: 使用 php 的 lv_utils 工具生成字库.

离线

页脚