IconFont的制作及在Android的使用

本文介绍的内容对应的Github项目地址:IconFontApp

上一节提到,如果项目中很多自定义的图标,或者是各种不同来源的图标,我们可以通过对Iconify进行扩展来实现,但是在扩展之前我们需要制作自己的图标字体文件,那么图标字体文件该如何制作呢?这个可以试试Fontello、Icomoon或者IconFont吧!

(制作图标字体的方法有很多,可以参考这里,本文主要介绍的是如何快速利用已有的图标制作字体文件然后在应用中使用)

1.Fontello: icon font generator

Fontello网址:http://fontello.com/
Github地址:https://github.com/fontello/fontello

Fontello是个图标字体生成器,通过它可以把一些图标作成字体放到自己的项目中。在Fontello主页上可以访问大量专业级的开源图标,并支持添加自定义的图标(SVG格式),而且可以在网站上选择不同来源的图标合并到单个字体文件中。此外,它还可以自定义每个图标的名称以及对应的Unicode码,一切配置好了之后可以将图标字体下载下来放到项目中使用。如下图所示,我添加了两个Custom Icons,从Fontelico中选了6个图标,从Font Awesome中选了3个图标等,最终导出得到的图标字体文件就会包含这些我需要的图标。

fontello

自定义图标名称和对应的Unicode:在页面顶部的配置中可以选择设置图标名称的前缀,例如fe-

fontello-name

fontello-code

下载之后得到一个zip文件,解压之后打开demo.html可以看到该图标字体中的所有图标的名称和对应的Unicode

fontello-nocode

fontello-showcode

同时,在解压后的font文件夹中有我们需要的ttf字体文件fontello.ttf,下面介绍下详细的扩展实现步骤。

(1)新建一个Android Studio项目,在app中添加对Iconify的依赖

compile 'com.joanzapata.iconify:android-iconify:2.2.2'

(2)新建assets文件夹,并将字体文件fontello.ttf拷贝到文件夹下
(3)新建FontelloModule类,实现IconFontDescriptor接口,内容如下:

public class FontelloModule implements IconFontDescriptor {

    @Override
    public String ttfFileName() {
        return "fontello.ttf";
    }

    @Override
    public Icon[] characters() {
        return FontelloIcons.values();
    }
}

(4)新建FontelloIcons枚举,实现Icon接口,内容如下:

public enum FontelloIcons implements Icon {
    fe_spin1('\uE800'),
    fe_spin2('\uE801'),
    fe_spin3('\uE802'),
    fe_spin4('\uE803'),
    fe_spin5('\uE804'),
    fe_github('\uE816');//注:这里我并没有把所有的图标都加上

    char character;

    FontelloIcons(char character) {
        this.character = character;
    }

    @Override
    public String key() {
        return name().replace('_', '-');
    }

    @Override
    public char character() {
        return character;
    }
}

(5)测试:在activity_main.xml布局文件中添加一个IconTextView

<com.joanzapata.iconify.widget.IconTextView
    android:id="@+id/iconTextView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    android:layout_centerHorizontal="true"
    android:text="{fe-github} {fe-spin1 spin} {fe-spin2 spin} {fe-spin3 spin} {fe-spin4 spin} {fe-spin5 spin}"
    android:textSize="20sp"
    android:textColor="@android:color/black"/>

然后在MainActivityonCreate方法最后添加初始化操作

Iconify.with(new FontelloModule());

运行应用看到效果见文章末尾的截图,图标可以设置为旋转效果的哟,有点炫啊!

2.IcoMoon

IcoMoon网址:https://icomoon.io/app/
IcoMoon和Fontello一样,既可以添加自己的图标,又可以从其他的图标库中选择图片,而且也支持设置图标的名称和Unicode,最终还能导出得到图标字体文件。IcoMoon导出得到的zip文件和Fontello导出的结果类似,使用它的ttf文件对Iconify进行扩展的方式也一样。

3.IconFont

IconFont网址:http://www.iconfont.cn/
IconFont可是中文的图标字体制作网站哟!该网站是阿里的UED团队做的吧,在该网站可以方便地管理图标和制作图标字体文件。网站的帮助中Android端应用教程介绍了如何使用下载得到的IconFont,这个比较简单。但是,需要注意的是,下载下来的demo.html中看到的图标对应的编码用的是UTF-8表示的,并不是Unicode编码。此外,TextView的setText方法在使用的时候,如果传递的参数是R.string.xxx的形式的话,最终显示的时候对应的字符串会自动转成Unicode编码;但是如果传递的参数是某个字符串的话,该字符串默认会被视为Unicode编码,也就是说如果它原来不是Unicode编码这个时候显示就会出现异常!

看下下面的代码就清楚了,下面显示了4中不同的调用方式,并给出了不同方式下的显示结果


iconfontapp-code

关于如何将UTF-8编码的形式改成Unicode编码的形式可以参考其他的文档,但是这里的转换比较简单,只要抽取出其中的16位表示形式就行了,例如UTF-8编码的对应的Unicode编码就是\ue601,其中的16位表示形式是e601,其他的同理。

项目IconFontApp运行起来的效果如下图所示:

iconfontapp

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容