androd 自定义矢量图,和使用矢量图

简介: androd 自定义矢量图,和使用矢量图

自定义矢量图


首先 添加依赖:


//字体图标
//因为这个库的版本 和当前 项目的版本不兼容,所以加入
//exclude group:表示只要包含com.android.support的都排除
api ('com.joanzapata.iconify:android-iconify-ionicons:2.2.2'){
    exclude group:'com.android.support'
}
api ('com.joanzapata.iconify:android-iconify-fontawesome:2.2.2'){
    exclude group:'com.android.support'
}


1,在 网上 下载 .ttf 文件,然后新建一个assets 文件夹,将 .ttf 文件放进去。


网址为 :


https://www.iconfont.cn/


http://code.zoomla.cn/boot/font.html


0a2653c851af460fa595bd959398a8f1.png


然后选择添加到购物车,然后打开购物车,在右上角,


2d65d23f6d4748949b924e4057485923.png


点击下载代码,完成后解压


4cebaac233b3433da32a72337a77fc60.png


将第一个打开,第二个.ttf文件进行保存,如下图


6de278e6d6694ce5bb08e7e842b7e74b.png


网页文件打开如下图


8ec4f2997fb246878c34ecd6d122b7c6.png


记住这个号,下面将会使用


2,创建枚举类,继承自 Icon,实现方法,


public enum EcIcons implements Icon {
    //这个号 就是网页里对应的东西,前面的icon_scan 可以随便起,但是注意必须加 _
    icon_scan('\ue694'),
    private char character;
    EcIcons(char character) {
        this.character = character;
    }
    //图标的键,例如'fa-ok'
    @Override
    public String key() {
        return name().replace('_', '-');
    }
    //与字体中的键匹配的字符
    @Override
    public char character() {
        return character;
    }
}


构造器要传入的值 在下载的文件中 有个.xml 的文件,打开后 找对应的就行


3,创建类 继承自 IconFontDescriptor ,然后加载文件,和 刚才定义的枚举对象。


public class FontEcModule implements IconFontDescriptor {
    @Override
    public String ttfFileName() {
        return "iconfont.ttf";
    }
    @Override
    public Icon[] characters() {
        return EcIcons.values();
    }
}


4,定义一个类,继承自Application ,然后对字体进行初始化,注意一定要在清单文件中 设置name 的属性 等于 继承自 Application的类。


public class ExampleApp extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
     /*   Latte.init(this)
                .WithApiHost("127.0.0.1")
                .withIcon(new FontAwesomeModule())
                .withIcon(new FontEcModule())
                .configure();*/
        Iconify.IconifyInitializer initializer = Iconify.with(new  FontEcModule());
    }
}


上面注释的 地方是我分装的,没有注释的则是 正常使用的。


还有就是设置清单文件


0a2653c851af460fa595bd959398a8f1.png


上面在 application中进行了初始化,然后进行使用就好了。


5,使用如下,布局中使用IconTextView ,text属性对应的值就是 EcIons 枚举类中对应的值,注意中间的下划线必须改为 -,也就是减号。


android:id="@+id/icon_test"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="{fa-coffee}"
    tools:ignore="HardcodedText" />


直接使用自带的,不需要自定义这个麻烦,如下所示


Iconify.IconifyInitializer initializer = Iconify.with(new FontAwesomeModule());


在上面进行初始化,创建一个类继承自application ,进行初始化,和上面的一样。


可以点进去看一下:


2d65d23f6d4748949b924e4057485923.png


这个已经是别人写好的,直接用就可以了,点击第二个方法里面 返回的类,就是对应的矢量图,复制前面的字段,使用的使用将下划线改为中划线就ok,


如下所示:


4cebaac233b3433da32a72337a77fc60.png


这些都可以在上面第二个网址里面找到。



相关文章
|
6月前
|
前端开发
css特效——Photoshop选区(动感的虚线选框,支持不规则的选框)
css特效——Photoshop选区(动感的虚线选框,支持不规则的选框)
41 1
|
移动开发 前端开发 HTML5
前端 HTML5 Svg 画板(支持视频、图片上涂鸦,支持缩放、修改、颜色、复选...)
前端 HTML5 Svg 画板(支持视频、图片上涂鸦,支持缩放、修改、颜色、复选...)
260 0
Photoshop绘制立体风格的拾色器图标
Photoshop绘制立体风格的拾色器图标
66 0
|
XML 前端开发 JavaScript
推荐一个C#操作SVG图形矢量图的开源项目
一个支持.Net Framework 与 .Net Core版本的SVG图形操作库。这个项目集成了SVG各项API,让开发人员可以在.Net很轻松的实现SVG图形的操作,通过SVG文件转换为图片文件。
463 0
推荐一个C#操作SVG图形矢量图的开源项目
|
XML 图形学 数据格式
SVG 可缩放矢量图形
SVG 可缩放矢量图形
108 0
|
JSON 前端开发 JavaScript
Threejs引入字体,实现3D文字,Canvas画布作为纹理贴图实现滚动字幕
Threejs引入字体,实现3D文字,Canvas画布作为纹理贴图实现滚动字幕
978 0
|
前端开发 数据可视化 开发工具
Tooltips提示框的视觉效果:SVG方案实现
Tooltips常被称为提示框(或信息提示框),提示框能够以较强的交互性、自由度为用户提供相应的提示信息。
Tooltips提示框的视觉效果:SVG方案实现
|
Windows
利用Adorner制作用于图像裁切的选择框
原文:利用Adorner制作用于图像裁切的选择框 前天,我写了一篇“使用Adorner显示WPF控件的边界点”的文章。这次,使用从Adorner继承来写一个用于图像裁切的选择框。
783 0
|
C#
【WPF】ImageMagick调节图片的颜色
原文:【WPF】ImageMagick调节图片的颜色 需求:打开一张图片后,自由调节图片的颜色(色调)。 思路:读取显示一张图片后,用ColorPicker取色器选择一种颜色,之后将图片的色调调节为该颜色。
1567 0