React-native开发之图标库react-native-vector-icons 的集成使用

RN开发中难免会用到图标,今天我们来集成github上比较受欢迎的一个强大的icons库。

先上效果图

源码已分享之码云:https://git.oschina.net/osczaizai/RNWeiBo

更多分享请看http://cherylgood.cn

可通过下面链接直接搜索你想要的icons

Browse all.

Entypoby Daniel Bruce (411 icons)

EvilIconsby Alexander Madyankin & Roman Shamin (v1.8.0, 70 icons)

FontAwesomeby Dave Gandy (v4.7.0, 675 icons)

Foundationby ZURB, Inc. (v3.0, 283 icons)

Ioniconsby Ben Sperry (v3.0.0, 859 icons)

MaterialIconsby Google, Inc. (v3.0.1, 932 icons)

MaterialCommunityIconsby MaterialDesignIcons.com (v1.7.22, 1722 icons)

Octiconsby Github, Inc. (v5.0.1, 176 icons)

Zocialby Sam Collins (v1.0, 100 icons)

SimpleLineIconsby Sabbir & Contributors (v2.4.1, 189 icons)

废话不多说,现在开始集成:

第一步:在react-native 工程目录下通过npm安装react-native-vector-icons

npm install react-native-vector-icons --save

第二步:分别为android和ios做一些相应的配置

Android:

在android/app/build.gradle

中增加如下脚本:

project.ext.vectoricons = [

iconFontNames: [ 'MaterialIcons.ttf', 'EvilIcons.ttf' ] // Name of the font files you want to copy

]

apply from: "../../node_modules/react-native-vector-icons/fonts.gradle"

在node-modules 中找到

react-native-vector-icons库,将Fonts 文件夹拷贝到android/app/src/main/assets/fonts

如果没有assets/fonts 新建即可

在android/settings.gradle中增加如下脚本,

include ':react-native-vector-icons'

project(':react-native-vector-icons').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-vector-icons/android')

include ':react-native-vector-icons'的作用时在编译android项目的时候

react-native-vector-icons会作为一个module加入编译。

project(':react-native-vector-icons').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-vector-icons/android')是指定

react-native-vector-icons的具体路径在android/app/build.gradle添加:compile project(':react-native-vector-icons')

apply plugin: 'com.android.application'

android {

...

}

dependencies {

compile fileTree(dir: 'libs', include: ['*.jar'])

compile "com.android.support:appcompat-v7:23.0.1"

compile "com.facebook.react:react-native:+"  // From node_modules

....

compile project(':react-native-vector-icons')

}

最后一步:在android/app/src/main/java/你的包/MainApplication.java中添加

import com.oblador.vectoricons.VectorIconsPackage;

new VectorIconsPackage()

代码如下:

package com.myapp;

import com.oblador.vectoricons.VectorIconsPackage;

....

@Override

protected List getPackages() {

return Arrays.asList(

new MainReactPackage()

, new VectorIconsPackage()

);

}

}

然后在此运行项目即可。

IOS集成:

通过,拷贝Fonts到xcode的Images.xcassets中然后在Info.plist中添加如下代码

Information Property List 添加一个Item

即可,编译一下,然后运行项目。

一下是我的使用demo代码:

创建一个使用该库来实现icon的TabIcon

import React, {

PropTypes,

Component

} from 'react';

import {

Text,

View,

StyleSheet

} from 'react-native';

import Icon from 'react-native-vector-icons/Ionicons';

export default class TabIcon extends Component {

render() {

return (

{this.props.tabTitle}

);

}

}

TabIcon.propTypes = {

selected: PropTypes.bool,

tabTitle: PropTypes.string.isRequired,

iconName: PropTypes.string

};

const styles = StyleSheet.create({

container: {

flexDirection: 'column',

alignItems: 'center',

justifyContent: 'center'

},

title:{

fontSize:14,

}

});

如下使用即可

/**

* Created by zaizai on 2017/3/7.

*/

import React, { Component } from 'react';

import {

StyleSheet

} from 'react-native';

import {

Router,

Scene,

Modal,

ActionConst

} from 'react-native-router-flux';

import { connect } from 'react-redux';

import HomeView from '../pages/home';

import PublishView from '../pages/publish';

import ProfileView from '../pages/profile';

import MessageView from '../pages/message';

import DiscroverView from '../pages/discrover';

import TabIcon from '../components/TabIcon';

const RouterWithRedux = connect()(Router);

/**

* 定义基本的样式

* @param props

* @param computedProps

* @returns {{flex: number, backgroundColor: string, shadowColor: null, shadowOffset: null, shadowOpacity: null, shadowRadius: null}}

*/

const getSceneStyle = (props, computedProps) => {

const style = {

flex: 1,

backgroundColor: '#fff',

shadowColor: null,

shadowOffset: null,

shadowOpacity: null,

shadowRadius: null,

};

if (computedProps.isActive) {

console.log(computedProps)

style.marginTop = computedProps.hideNavBar ? 0 : 64;

style.marginBottom = computedProps.hideTabBar ? 0 : 50;

}

return style;

};

export default class App extends  Component{

// 构造

constructor(props) {

super(props);

// 初始状态

this.state = {

selectedTab: 'home',

};

}

render(){

return(

);

}

}

const styles = StyleSheet.create({

container: {

flex: 1,

},

tab_image: {

height: 28,

width: 28,

},

tabBarStyle: {

borderTopWidth: 0.5,

borderColor: '#b7b7b7',

backgroundColor: 'white',

opacity: 1

},

instructions: {

textAlign: 'center',

color: '#333333',

marginBottom: 5

}

});

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

推荐阅读更多精彩内容

  • 持续更新中...... 一套企业级的 UI 设计语言和 React 实现。 https://mobile.ant....
    日不落000阅读 5,656评论 0 35
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,451评论 25 707
  • 前言 iconFont的使用对于前端开发同学肯定不陌生,移动端开发也有普遍的使用。既然这多公司都选择使用iconF...
    光强_上海阅读 7,884评论 0 13
  • afinalAfinal是一个android的ioc,orm框架 https://github.com/yangf...
    passiontim阅读 15,396评论 2 45
  • 早晨五点二十,从梦中醒来,泪水止不住地流,又梦见外公了。梦里他一个人坐在阳台上,我们准备出门,我过去拥抱他与他道别...
    龙里个龙阅读 478评论 0 1