WhyCan Forum

人过留名,雁过留声,感谢各位朋友不离不弃地支持。 QQ: 516333132 (挖坑网/填坑网) admin@whycan.cn

您尚未登录。

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

晕哥
Administrator
注册时间: 2017-09-06
累计积分: 8,216

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
注册时间: 2017-09-06
累计积分: 8,216

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
累计积分: 48

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

晕哥 说:

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

https://whycan.cn/files/members/3/QQ20180222110833.png

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

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

离线

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

晕哥
Administrator
注册时间: 2017-09-06
累计积分: 8,216

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
注册时间: 2017-09-06
累计积分: 8,216

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
累计积分: 18

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

标记一下

离线

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

775624981
会员
注册时间: 2018-05-05
累计积分: 18

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

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

离线

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

晕哥
Administrator
注册时间: 2017-09-06
累计积分: 8,216

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

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

在线

#9 2018-09-04 16:09:30

a32425262
会员
注册时间: 2018-05-06
累计积分: 32

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

必须要这种用数组的吗,可以像qt一样使用系统自带的ttf字体那种的吗

离线

#10 2018-09-04 16:11:33

daydayup
会员
注册时间: 2017-10-09
累计积分: 301

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

a32425262 说:

必须要这种用数组的吗,可以像qt一样使用系统自带的ttf字体那种的吗

可以可以, 用数组的原因是简化系统.
如果Qt那样的, 你是不是需要文件系统, ttf解析库等。
littlevlg面向就是单片机,资源受限。

离线

#11 2018-09-04 16:46:09

晕哥
Administrator
注册时间: 2017-09-06
累计积分: 8,216

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

a32425262 说:

必须要这种用数组的吗,可以像qt一样使用系统自带的ttf字体那种的吗

你想到的已经有人做好了.

看下这个帖子: @assert 分享的在littlevgl 调用freetye显示文字, 而不用通过字模软件生成

在线

#12 2019-11-07 13:49:43

silong1126
会员
注册时间: 2019-11-07
累计积分: 32

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

mark一下,后续学习。

离线

页脚