react-native-vector-icons的使用
2018-02-05 本文已影响260人
marlti7
1.安装三方包
yarn add react-native-vector-icons或
npm install react-native-vector-icons --save
2.自动link
react-native link react-native-vector-icons
ios配置(ios需要单独导入字体文件,安卓link完就可以用了)
1.右键工程文件Add Files to "(你工程名)"
data:image/s3,"s3://crabby-images/af16b/af16bdd4ae5cb74c9c9a7d83e766af1ecc9ce416" alt=""
2.选择node_modules/react-native-vector-icons/Fonts文件夹
data:image/s3,"s3://crabby-images/22116/221164d5669fcebcdeac0dd4ae40bc200bbf33fa" alt=""
3.检查info.plist文件Fonts provided by application是否成功加入了字体文件
data:image/s3,"s3://crabby-images/8ae25/8ae255f5db1b6c64017f10095ec12b972f8c09de" alt=""
3.直接使用
import React from 'react';
import {
View,
Text,
TouchableOpacity,
Platform,
StatusBar,
} from 'react-native';
import FontAwesome from 'react-native-vector-icons/FontAwesome';
export default class CustomHeader extends React.Component {
render() {
return (
<FontAwesome
name="angle-left"
size={26}
style={{ color: 'white' }}
/>
);
}
}
4.自定义icon(ios)(android 直接在 android/app/src/main/assets/fonts文件夹下添加该ttf文件)
1.将自定义icon的svg文件上传至http://fontello.com/(或其他网站,这里提供我自己使用的),并选中,点击右上角,download webfont
data:image/s3,"s3://crabby-images/a8bdb/a8bdb61f18c6e100ec8973246f52031ae04f1cd8" alt=""
2.下载后得到如下
data:image/s3,"s3://crabby-images/40c9f/40c9f9ce7cfd7e436411ed44290aea2cb8e684ef" alt=""
3.将config.json加入到项目文件中,如下代码中的customIcon.json
4.将font文件夹下ttf文件(此处fontello.ttf), 也通过和上面一样的Add Files to "(你工程名)"加入到你的项目中(或者直接拖拽到刚才react-native-vector-icons中的那些字体文件的同一目录下)
data:image/s3,"s3://crabby-images/4e62a/4e62aa340c2113bede6e394f0aa85a895ff28724" alt=""
5.info.plist文件Fonts provided by application加入了字体文件名
data:image/s3,"s3://crabby-images/0709d/0709dbd686c688101feb9af73596864fbcaf9fa4" alt=""
6.依该包的自定义icon引入方法,代码如下
import React from 'react';
import {
Text,
View,
Button,
StatusBar,
} from 'react-native';
import { createIconSetFromFontello } from 'react-native-vector-icons';
import clIconConfig from '../config/customIcon.json';
// 自定义icon http://fontello.com/ download webfont config.json 与 ttf文件
// ios中 需要在项目Xcode文件中 Add file to xiangmu, 并在info.plist中的
// fonts provided by application加入改字体文件
// android 需要在 android/app/src/main/assets/fonts文件夹下添加该ttf文件
const CLIcon = createIconSetFromFontello(clIconConfig);
// 导入stack导航组件
export default class HomeScreen extends React.Component {
render() {
// 这里可以是导入的其他组件
const { navigate } = this.props.navigation;
return (
<View style={{ backgroundColor: '#fff', flex: 1 }}>
<Text>Hello, Chat App!</Text>
<CLIcon
name="seer-contacts"
size={26}
style={{ color: 'red' }}
/>
<Button
onPress={() => navigate('Chat')}
title="Chat with Lucy"
/>
</View>
);
}
}
data:image/s3,"s3://crabby-images/31e94/31e945153deea3258260be671ea67508856bb657" alt=""