美文网首页
Android-Iconics使用自定义的矢量图标库字体

Android-Iconics使用自定义的矢量图标库字体

作者: 过眼云烟梦 | 来源:发表于2017-05-12 19:02 被阅读0次
    • 1 打开链接 www.iconfont.cn/plus/home/index ,进入阿里巴巴矢量图标库,选择我们喜欢的图标点击购物车图标,添加入库。

    • 2 选择好后,进入购物车,点击添加至项目。


    • 3 点击右边图标,添加一个新项目 animal,完成选择下载到本地

    • 4 解压下载完成得文件,得到下图目录的文件


    • 5 在项目中使用 android - iconics开源库 github.com/mikepenz/Android-Iconics 由于我们是直接使用的自己的icon,所以我们只需引用
      compile"com.mikepenz:iconics-core:2.8.4@aar"

    • 6 在项目中新建 assets文件夹,将 ttf 格式的字体文件拷贝进其中


    • 7 在MyApplication中进行初始化和注册

    public class MyApplication extends Application
    {
        @Override
        public void onCreate()
        {
            super.onCreate();
            Iconics.init(getApplicationContext());
            Iconics.registerFont(new MyIconFont());
        }
    
    • 8 创建MyIconFont类,实现ITypeface接口,并实现其中的13个方法
    public class MyIconFont implements ITypeface
    {
        // 字体库的名字,在assets目录下
        private static final String TTF_FILE = "iconfont.ttf";
        private static Typeface typeface = null;
        private static HashMap<String, Character> mChars;
    
        @Override
        public IIcon getIcon(String key)
        {
            return Icon.valueOf(key);
        }
    
        @Override
        public HashMap<String, Character> getCharacters()
        {
            if (mChars == null)
            {
                HashMap<String, Character> aChars = new HashMap<String, Character>();
                for (Icon v : Icon.values())
                {
                    aChars.put(v.name(), v.character);
                }
                mChars = aChars;
            }
            return mChars;
        }
        // icon名字的前缀
        @Override
        public String getMappingPrefix()
        {
            return "lbw";
        }
        @Override
        public String getFontName()
        {
            return "MyIconFont";
        }
        @Override
        public String getVersion()
        {
            return "1.0.0";
        }
        @Override
        public int getIconCount()
        {
            return mChars.size();
        }
    
        @Override
        public Collection<String> getIcons()
        {
            Collection<String> icons = new LinkedList<String>();
            for (Icon value : Icon.values())
            {
                icons.add(value.name());
            }
            return icons;
        }
        @Override
        public String getAuthor()
        {
            return "字库作者";
        }
        @Override
        public String getUrl()
        {
            return "字库URL下载地址";
        }
        @Override
        public String getDescription()
        {
            return "字库简介";
        }
        @Override
        public String getLicense()
        {
            return "字库许可证";
        }
        @Override
        public String getLicenseUrl()
        {
            return "许可证地址";
        }
        @Override
        public Typeface getTypeface(Context context)
        {
            if (typeface == null)
            {
                try
                {
                    // 创建一个typeface,从asstes目录中读取
                    typeface = Typeface.createFromAsset(context.getAssets(), TTF_FILE);
                } catch (Exception e)
                {
                    return null;
                }
            }
            return typeface;
        }
    
        public enum Icon implements IIcon
        {
           // 对应编码的获取方法下面有讲到
            lbw_number_0('\ue621'),
            lbw_number_1('\ue622'),
            lbw_number_2('\ue62e'),
            lbw_number_3('\ue600'),
            lbw_number_4('\ue630'),
            lbw_number_5('\ue69b'),
            lbw_number_6('\ue70e'),
            lbw_number_7('\ue601'),
            lbw_number_8('\ue69e'),
            lbw_number_9('\ue62a');
    
            char character;
            Icon(char character)
            {
                this.character = character;
            }
    
            public String getFormattedName()
            {
                return "{" + name() + "}";
            }
    
            public char getCharacter()
            {
                return character;
            }
    
            public String getName()
            {
                return name();
            }
    
            private static ITypeface typeface;
    
            public ITypeface getTypeface()
            {
                if (typeface == null)
                {
                    typeface = new MyIconFont();
                }
                return typeface;
            }
        }
    }
    
    • 9 enum Icon中,各图标对应的Unicode获得方式,在下载解压的字体包文件中,找到后缀为.css的文件,用editplus打开它,就能看到我们下载的图标名字,以及对应的编码
    • 10 在需要使用的activity和fragment中,添加如下代码和重写attachBaseContext 方法
     @Override
        protected void onCreate(Bundle savedInstanceState)
        {
            // 添加如下代码
            LayoutInflaterCompat.setFactory(getLayoutInflater(), new IconicsLayoutInflater(getDelegate()));
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
        }
       // 重写此方法
        @Override
        protected void attachBaseContext(Context newBase)
        {
          super.attachBaseContext(IconicsContextWrapper.wrap(newBase));
        }
    
    • 11 在xml布局文件中使用
    <Button
            android:layout_width="120dp"
            android:layout_height="60dp"
            android:text="{lbw-number-7} Button"/>
    
       <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            app:ico_color="@color/colorPrimary"
            app:ico_icon="lbw-number-2"
            app:ico_size="48dp"/>
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="80dp"
            android:text="{lbw-number-6}双击666"
            android:textColor="@android:color/black"
            android:textSize="50sp"/>
    
    • 12 在代码中使用
      • 获取到对应的drawable,在imageview中使用
    IconicsDrawable iconicsDrawable = new IconicsDrawable(this)
                    .icon(MyIconFont.Icon.lbw_number_0)
                    .color(Color.YELLOW)
                    .sizeDp(50);
            ImageView iv_font = (ImageView) findViewById(R.id.image_myfont);
            iv_font.setImageDrawable(iconicsDrawable);
    
    • 在textview中使用
     TextView tv_font = (TextView) findViewById(R.id.text_font);
            tv_font.setText("{lbw-number-6}{lbw-number-6}{lbw-number-6}");
            tv_font.setTextSize(100);
            tv_font.setTextColor(Color.YELLOW);
    
    • 注意要点
      • 在布局文件中使用的时候,会提示如下红线警告

    可以不用管它,运行是没有问题的,如果看着不开心,可以在根布局加上 ```
    tools:ignore="MissingPrefix"

    相关文章

      网友评论

          本文标题:Android-Iconics使用自定义的矢量图标库字体

          本文链接:https://www.haomeiwen.com/subject/mpttxxtx.html