您尚未登录。

楼主 #1 2019-09-20 13:15:05

Jmhh247
会员
注册时间: 2018-12-21
已发帖子: 262
积分: 262

[原创开源]emwin导航界面支持Awesome图标字体

关键字: emwin, awesome图标字体


最近整理电脑资料,发现角落很多代码,不如整理一下分享出来,还能发挥点余热。


这是一个用emwin写的导航界面,emwin仿真环境用的是codeblocks。

##### 程序本身没什么技术含量,唯一值得分享的亮点是awesome图标字体在emwin中的应用。

在这里要特别感谢安富莱给力的史诗级emwin教程。


部分APP运行截图

---
加载页

FluxBB bbcode 测试

启动页

FluxBB bbcode 测试

导航页

FluxBB bbcode 测试

图中的导航按钮使用的就是awesome图标。

---
#### awesome图标字体简介

awesome图标字体,是一套开源免费的矢量图标,最新版是4.7.0,一共有675个图标。awesome图标字体提供多种格式,可以用到多种开发场合,web开发应该是主流。

awesome图标字体中文官网在这:- [FontAwesome中文网](http://www.fontawesome.com.cn/)

官网截图

---

FluxBB bbcode 测试


FluxBB bbcode 测试

#### emwin使用awesome字体

awesome图标字体有提供ttf格式,而emwin是支持ttf格式的,所以emwin可以直接使用。


emwin使用图标的常规方法,无非就是2D绘图,直接贴图等。

awesome图标字体ttf格式大小只有162KB,不到200KB就有675个矢量图标,显然是很适合嵌入式的,使用方法也简单的多。

FluxBB bbcode 测试

所以在一些场合中使用awesome图标字体优势非常大。



- 简单使用示例

创建字体后,直接当成普通字体来显示即可:

GUI_SetFont(&Font48);

GUI_DispStringInRect("\uf085", &rect, GUI_TA_HCENTER | GUI_TA_TOP);

上面的“f085”是从索引页查出图标对应的unicode。我把图标的索引页生成了一个PDF文档,后面会给出该文档。



- 进阶使用示例

就是本次导航按钮使用图标字体的实现方法,原理就是用emwin系统的皮肤设置函数+按钮私有数据。

1. 在emwin创建awesome图标字体;

        ttf_init();

        // 篇幅限制,只列出部分,具体看工程源码
	/* 创建6种字体 */
	GUI_TTF_CreateFontAA(&awefont16, &awefont_Cs0);
	GUI_TTF_CreateFontAA(&awefont24, &awefont_Cs1);
	GUI_TTF_CreateFontAA(&awefont32, &awefont_Cs2);
	GUI_TTF_CreateFontAA(&awefont48, &awefont_Cs3);
	GUI_TTF_CreateFontAA(&awefont72, &awefont_Cs4);
	GUI_TTF_CreateFontAA(&awefont120, &awefont_Cs5);

---
2. 增加按钮的私有数据,这里是记录图标字体等信息


// 按钮私有数据,记录图标
// ok
static BTN_USER_SKIN BtnSkinData[] = {
    {GUI_DARKCYAN, GUI_DARKMAGENTA, &awefont48, "\uf0f6"},
    {GUI_DARKCYAN, GUI_DARKGRAY, &awefont48, "\uf030"},
    {GUI_DARKCYAN, GUI_DARKGREEN, &awefont48, "\uf008"},
    {GUI_DARKCYAN, GUI_DARKRED, &awefont48, "\uf226"},
    {GUI_DARKCYAN, GUI_ORANGE, &awefont48, "\uf144"},
    {GUI_DARKCYAN, GUI_GRAY_9A, &awefont48, "\uf2b5"},
};

// ok
static BTN_USER_SKIN *pBtnUser[GUI_COUNTOF(BtnSkinData)];

然后一定记得给按钮设置私有数据的字节数:

FluxBB bbcode 测试

---
3. 使用系统函数设置皮肤即可


    for (int i = 0; i < GUI_COUNTOF(BtnSkinData); i++) {

        hItem = WM_GetDialogItem(pMsg->hWin, ID_BUTTON_0 + i);

        BUTTON_SetFont(hItem, &Font16);

        // 设置皮肤函数
        BUTTON_SetSkin(hItem, button_drawskin_awefont);

        pBtnUser[i] = &BtnSkinData[i];

        // 设置私有数据
        BUTTON_SetUserData(hItem, &pBtnUser[i], sizeof(pBtnUser[i]));
    }

---

4. 最后是自定义皮肤函数的实现,核心代码


/* 按钮绘制图标字体皮肤 ok*/
int button_drawskin_awefont(const WIDGET_ITEM_DRAW_INFO* pItem)
{
    BTN_USER_SKIN *pUsr;
    GUI_RECT rect;
    char acBuf[20];


	switch (pItem->Cmd)
	{
    case WIDGET_ITEM_DRAW_TEXT:

            BUTTON_GetText(pItem->hWin, acBuf, sizeof(acBuf));

            rect.x0 = pItem->x0;
            rect.x1 = pItem->x1;
            rect.y0 = pItem->y0;
            rect.y1 = pItem->y1;


            GUI_SetFont(BUTTON_GetFont(pItem->hWin));
            GUI_SetTextMode(GUI_TM_TRANS);
            GUI_SetColor(GUI_WHITE);

            rect.y1 -= rect.y1 / 6;
			GUI_DispStringInRect(acBuf, &rect, GUI_TA_HCENTER | GUI_TA_BOTTOM);


        break;

	case WIDGET_ITEM_DRAW_BACKGROUND:

		    BUTTON_GetUserData(pItem->hWin, &pUsr, sizeof(pUsr));

			if (BUTTON_IsPressed(pItem->hWin))
			{
                GUI_SetColor(pUsr->colorPressed);
			}
			else
			{
                GUI_SetColor(pUsr->colorUnPress);
			}

			GUI_AA_FillRoundedRect(pItem->x0, pItem->y0, pItem->x1, pItem->y1, 0);


            rect.x0 = pItem->x0;
            rect.x1 = pItem->x1;
            rect.y0 = pItem->y0;
            rect.y1 = pItem->y1;



            // 图形字体
            GUI_SetColor(GUI_WHITE);
            GUI_SetTextMode(GUI_TM_TRANS);


            rect.y0 += rect.y1 / 6;

            if (pUsr->iconFont) {
                GUI_SetFont(pUsr->iconFont);
                GUI_DispStringInRect(pUsr->iconName, &rect, GUI_TA_HCENTER);

            }


        break;

	default:
		{
			return BUTTON_DrawSkinFlex(pItem);
		}
	}
	return 0;
}

---

最后,相关资料:

1. codeblocks(16或17都可)工程源码 emwin-uidemo5-cbprj.zip                       
2. font-awesome-4.7.0.zip           font-awesome-4_7_0.zip
3. 可执行程序demo                       demo.zip
4. 索引手册PDF                            图形字体图标字体矢量版 – Font Awesome 中文网

离线

楼主 #2 2019-09-20 13:15:49

Jmhh247
会员
注册时间: 2018-12-21
已发帖子: 262
积分: 262

Re: [原创开源]emwin导航界面支持Awesome图标字体

排版用了快一个小时,难哭了。。。

离线

#3 2019-09-20 13:31:51

晕哥
管理员
所在地: 微信 whycan_cn
注册时间: 2017-09-06
已发帖子: 9,223
积分: 9197

Re: [原创开源]emwin导航界面支持Awesome图标字体

好帖好帖,谢谢大楼主,楼主辛苦了!





在线

#4 2019-09-20 14:52:33

我思故我在
会员
注册时间: 2019-09-03
已发帖子: 244
积分: 243.5

Re: [原创开源]emwin导航界面支持Awesome图标字体

codeblock_emwin1.png

感谢楼主分享, 挺好用的。


这里 http://www.codeblocks.org/downloads/26 下载 codeblocks-17.12mingw-nosetup.zip

最近编辑记录 我思故我在 (2019-09-20 14:59:02)

离线

楼主 #5 2019-09-20 16:07:09

Jmhh247
会员
注册时间: 2018-12-21
已发帖子: 262
积分: 262

Re: [原创开源]emwin导航界面支持Awesome图标字体

速度真快!

我思故我在 说:

https://whycan.cn/files/members/1947/codeblock_emwin1.png

感谢楼主分享, 挺好用的。


这里 http://www.codeblocks.org/downloads/26 下载 codeblocks-17.12mingw-nosetup.zip

离线

#6 2019-11-04 14:26:45

szchen2006
会员
注册时间: 2019-10-09
已发帖子: 216
积分: 166.5

Re: [原创开源]emwin导航界面支持Awesome图标字体

感谢楼主分享!

离线

#7 2019-11-04 21:50:55

Lvy
会员
注册时间: 2017-11-25
已发帖子: 107
积分: 96.5

Re: [原创开源]emwin导航界面支持Awesome图标字体

感谢楼主分享的enwin开源系列

离线

#8 2019-11-06 09:02:17

szchen2006
会员
注册时间: 2019-10-09
已发帖子: 216
积分: 166.5

Re: [原创开源]emwin导航界面支持Awesome图标字体

感谢楼主分享!顶一下。

离线

#9 2019-12-04 09:11:44

晕哥
管理员
所在地: 微信 whycan_cn
注册时间: 2017-09-06
已发帖子: 9,223
积分: 9197

在线

#10 2020-02-11 15:55:49

sea18c
会员
注册时间: 2019-08-05
已发帖子: 230
积分: 222.5

Re: [原创开源]emwin导航界面支持Awesome图标字体

感谢楼主分享!

离线

#11 2020-04-12 01:52:16

fyyy4030
会员
注册时间: 2020-04-12
已发帖子: 1
积分: 1

Re: [原创开源]emwin导航界面支持Awesome图标字体

感谢分享!!!!!!!!!!!

离线

#12 2020-04-16 19:03:31

liuchangyin
会员
注册时间: 2020-03-17
已发帖子: 204
积分: 199

Re: [原创开源]emwin导航界面支持Awesome图标字体

深入研究

离线

#13 2020-04-28 10:20:52

ggk1989
会员
注册时间: 2018-12-19
已发帖子: 8
积分: 3

Re: [原创开源]emwin导航界面支持Awesome图标字体

这个图标库可以随便使用吗

离线

楼主 #14 2020-04-28 11:23:27

Jmhh247
会员
注册时间: 2018-12-21
已发帖子: 262
积分: 262

Re: [原创开源]emwin导航界面支持Awesome图标字体

开源免费,也有收费版本,图标多几倍。

ggk1989 说:

这个图标库可以随便使用吗

离线

#15 2020-04-28 11:35:48

novice
会员
注册时间: 2019-07-26
已发帖子: 112
积分: 93

Re: [原创开源]emwin导航界面支持Awesome图标字体

为啥要“wait 10 seconds”?

应该是用了FreeType显示矢量字体来做图标吧?

矢量字体可以上IconMoon网站(https://icomoon.io/app/#/select)免费定制,非常方便。
在主页点击右上角的“IcoMoon App"就进入编辑界面,默认进入”IcoMoon Free“免费图标集,也可以选择其他免费图标集,选择好需要的图标点击”Generate Font“就可以生成TTF字体文件。

离线

#16 2020-05-13 09:32:46

642242855
会员
注册时间: 2019-10-31
已发帖子: 191
积分: 98

Re: [原创开源]emwin导航界面支持Awesome图标字体

感谢感谢!!正好可以学习

离线

#17 2020-09-02 08:53:08

歌以咏志
会员
注册时间: 2019-09-21
已发帖子: 219
积分: 210

Re: [原创开源]emwin导航界面支持Awesome图标字体

楼主给力!

离线

#18 2020-09-02 11:21:10

szchen2006
会员
注册时间: 2019-10-09
已发帖子: 216
积分: 166.5

Re: [原创开源]emwin导航界面支持Awesome图标字体

学习了,楼主好给力!

离线

#19 2020-09-02 17:49:55

szchen2006
会员
注册时间: 2019-10-09
已发帖子: 216
积分: 166.5

Re: [原创开源]emwin导航界面支持Awesome图标字体

请问,你用个是什么编译器呢?谢谢!


我思故我在 说:

https://whycan.cn/files/members/1947/codeblock_emwin1.png

感谢楼主分享, 挺好用的。


这里 http://www.codeblocks.org/downloads/26 下载 codeblocks-17.12mingw-nosetup.zip

离线

页脚

工信部备案:粤ICP备20025096号 Powered by FluxBB

感谢为中文互联网持续输出优质内容的各位老铁们。 QQ: 516333132, 微信(wechat): whycan_cn (哇酷网/挖坑网/填坑网) service@whycan.cn