React Native图表插件react-native-cha
2017-03-28 本文已影响3605人
冷洪林
之前写了些RN的第三方插件的教程,(比如react-native-baidu-map
iOS端集成:http://www.jianshu.com/p/eceb7e66fa5e ,RN升级配置说明
:http://www.jianshu.com/p/0c30e94de69b ) ,我觉得写博客来帮网友解决问题,比单纯的截图和QQ聊天效率更高,并且复用性高,不用再重复解答。可能很多朋友都在集成第三方的时候会遇到一些莫名其妙的报错,稀奇古怪的填坑,所以此时我们需要有极强的耐心,和清晰的思路。好了,话不多说,接下来开始一步一步集成图表插件react-native-charts-wrapper
:
成都React-Native交流群,进群给管理,先到先得哦
data:image/s3,"s3://crabby-images/11735/117350e3d5851a5506edf50097301e3bb3e7c6d9" alt=""
data:image/s3,"s3://crabby-images/62ac0/62ac09bf673c3c52cc146f10a4c6a09ca5fd2bd1" alt=""
图表插件react-native-charts-wrapper github地址
1.新建一个新的项目,从零开始演示(ChartsTest)
data:image/s3,"s3://crabby-images/8a74c/8a74ce732a690abf1c437536c171c53d592c8fe4" alt=""
当出现以下界面,就说明新建项目成功:
data:image/s3,"s3://crabby-images/c1714/c1714ca9729f90afd56c60a74b24150575bd2cc6" alt=""
2.安装react-native-charts-wrapper(注意:一定要在项目根目录下进行安装):
cd到项目根目录:
data:image/s3,"s3://crabby-images/116ac/116ac777668f677aeb0b39e8d295e762f1f781bc" alt=""
在终端输入:
npm install --save react-native-charts-wrapper
data:image/s3,"s3://crabby-images/6512c/6512cc9ed7f1180ec55f28b3883b9014b31b586b" alt=""
3.把该目录下ChartsTest/node_modules/react-native-charts-wrapper/ReactNativeCharts
的整个ReactNativeCharts
文件夹,拖入到项目中:
data:image/s3,"s3://crabby-images/4e02b/4e02be7596d928edb75291749d290481f9257a8a" alt=""
data:image/s3,"s3://crabby-images/2be9c/2be9c3a19b7e9551e0e786f6be5ba3fb5d4af23a" alt=""
添加完后:
data:image/s3,"s3://crabby-images/fcc7c/fcc7ca33b7f36756bbbfe477b8dffda7f8f1ee3b" alt=""
4.Add Bridge File:因为后面会用到SwiftyJSON
andiOS Charts
,这是用Swift写的,所以我们需要一个桥接文件,方法如下:
新建一个工程名-Bridging-Header.h
头文件(注意,必须是工程名开头!!!):
data:image/s3,"s3://crabby-images/e6703/e6703f4649e2a7968a33e541d3bf5c499c9b566a" alt=""
data:image/s3,"s3://crabby-images/621d0/621d0428be4be14a4647633c8e23b87ae89940b0" alt=""
data:image/s3,"s3://crabby-images/70168/70168ed6fcdc539aa2f1d68ea3f60acd1d688ad3" alt=""
data:image/s3,"s3://crabby-images/1cb56/1cb5631aea290b0fe7c870d886b963492642e887" alt=""
然后:Edit ->
Convert ->
To Current Swift Syntax...
data:image/s3,"s3://crabby-images/49552/49552e282520bab9eb458b6d0c5bfea405727ba6" alt=""
data:image/s3,"s3://crabby-images/8373d/8373d37aa05e1d99710e3a0608fa5a8afb6a4b66" alt=""
等待一会便好。。。
data:image/s3,"s3://crabby-images/c164a/c164a77f5515d0b46a12deed42417f140029bd47" alt=""
data:image/s3,"s3://crabby-images/55790/55790d1aa8b8d4daa1e05ef1f909eb535334d56e" alt=""
接下来在桥接文件里添加:
#import "React/RCTBridge.h"
#import "React/RCTViewManager.h"
#import "React/RCTUIManager.h"
#import "React/UIView+React.h"
#import "React/RCTBridgeModule.h"
#import "React/RCTEventDispatcher.h"
#import "React/RCTEventEmitter.h"
如图:
data:image/s3,"s3://crabby-images/74b3f/74b3f048819ca3887115443a558b901dfa641ef6" alt=""
5.接下来就需要使用我前面说的SwiftyJSON
andiOS Charts
我这里已经帮大家下好了,链接地址:链接: https://pan.baidu.com/s/1hs5M1Vm 密码: q2rt
下载下拉解压后,拖到iOS项目根目录下:
data:image/s3,"s3://crabby-images/ef961/ef9610f0edd635f63b823822524ea49d53aeca13" alt=""
data:image/s3,"s3://crabby-images/1d22d/1d22dd7a4c4512369f0f327bfa6052e68e12c755" alt=""
6.把刚刚的两个文件夹中的SwiftyJSON.xcodeproj
and Charts.xcodeproj
拖到工程的libraries
中:
data:image/s3,"s3://crabby-images/566f7/566f76b222873b4fd9999c9589e35a796c40c81f" alt=""
data:image/s3,"s3://crabby-images/58537/58537667604f2e305aa141e4d95398739a9bb52f" alt=""
完成后如图:
data:image/s3,"s3://crabby-images/d7518/d7518b965434d4f9bbe7324dabd46f7edc18c2f4" alt=""
7.接下来->
Build Phases ->
Link Binary With Libraries添加SwiftyJSON.framework
and Charts.framework
.
data:image/s3,"s3://crabby-images/eac96/eac963133e9a274df0562f9465fc3b39a805c83a" alt=""
data:image/s3,"s3://crabby-images/2f4fe/2f4fe6828b6411f17ba1aa81848065428fd22bbf" alt=""
data:image/s3,"s3://crabby-images/d1753/d17530372a44d86d77746e50bd5dd9d354c14a1b" alt=""
完成后如图:
data:image/s3,"s3://crabby-images/7f24c/7f24c4d905d04853dac32df87e98afff9a21c42f" alt=""
8.添加SwiftyJSON.framework
and Charts.framework
到 Embedded Binaries.
data:image/s3,"s3://crabby-images/c21b7/c21b7c89299a61b1d899781e8f60b5073a07177c" alt=""
data:image/s3,"s3://crabby-images/23621/23621cd906340505a67177d186bd29db13a78698" alt=""
完成后如图:
data:image/s3,"s3://crabby-images/bf027/bf027a42d4248f00fbdd5cad0739193431c797a0" alt=""
9.到这里配置已经完成,我们来Build一下:
data:image/s3,"s3://crabby-images/b92f8/b92f8fd0fee6bd14533227331604d931487397d9" alt=""
ok,配置成功!
10.这里我们还是采用官方的示例代码来玩玩这个图标,看看有多🐂:
index.ios.js:
/**
* Sample React Native App
* https://github.com/facebook/react-native
* @flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View
} from 'react-native';
import BarChartScreen from './BarChartScreen';
export default class ChartsTest extends Component {
render() {
return (
<View style={styles.container}>
<BarChartScreen style={{width:300, height:500}} />
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
}
});
AppRegistry.registerComponent('ChartsTest', () => ChartsTest);
BarChartScreen.js
import React from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
processColor
} from 'react-native';
import {BarChart} from 'react-native-charts-wrapper';
class BarChartScreen extends React.Component {
constructor() {
super();
this.state = {
legend: {
enabled: true,
textSize: 14,
form: 'SQUARE',
formSize: 14,
xEntrySpace: 10,
yEntrySpace: 5,
formToTextSpace: 5,
wordWrapEnabled: true,
maxSizePercent: 0.5
},
data: {
dataSets: [{
values: [{y: 100}, {y: 105}, {y: 102}, {y: 110}, {y: 114}, {y: 109}, {y: 105}, {y: 99}, {y: 95}],
label: 'Bar dataSet',
config: {
color: processColor('teal'),
barSpacePercent: 40,
barShadowColor: processColor('lightgrey'),
highlightAlpha: 90,
highlightColor: processColor('red'),
}
}],
},
xAxis: {
valueFormatter: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep'],
granularityEnabled: true,
granularity : 1,
}
};
}
handleSelect(event) {
let entry = event.nativeEvent
if (entry == null) {
this.setState({...this.state, selectedEntry: null})
} else {
this.setState({...this.state, selectedEntry: JSON.stringify(entry)})
}
}
render() {
return (
<View style={{flex: 1}}>
<View style={{height:80}}>
<Text> selected entry</Text>
<Text> {this.state.selectedEntry}</Text>
</View>
<View style={styles.container}>
<BarChart
style={styles.chart}
data={this.state.data}
xAxis={this.state.xAxis}
animation={{durationX: 2000}}
legend={this.state.legend}
gridBackgroundColor={processColor('#ffffff')}
drawBarShadow={false}
drawValueAboveBar={true}
drawHighlightArrow={true}
onSelect={this.handleSelect.bind(this)}
/>
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#F5FCFF'
},
chart: {
flex: 1
}
});
export default BarChartScreen;
效果如图:
data:image/s3,"s3://crabby-images/224fc/224fce2094004a81133524f495663388047c2224" alt=""
早上上班到现在一直再弄这个,还是有点累的。哈哈,今天还是我生日,我是不是很敬业啊,嘿嘿嘿~
好了 不弄这些花里胡哨的了,示例程序中还有很多图表,希望能帮到大家,谢谢~