Recently, many netizens have asked RN how to integrate Baidu Map. I used react-native-baidu-map in both previous projects. I feel that the steps are slightly complicated. If there is a slight omission in one step, it is easy to make a mistake. Next, I will build a new project from scratch and record the process of my installation step by step. I hope I can help you.~
react-native-baidu-map github address
1. Create a new RN project: (BaiDuMapTest)
data:image/s3,"s3://crabby-images/f5f46/f5f46891da47a98d6b7b74a9a4aec29209134afe" alt=""
The following interface appears to indicate that the new project has succeeded
data:image/s3,"s3://crabby-images/05d0f/05d0f9b4dfe69a01be794beea635d8735aee08a5" alt=""
2. Install react-native-baidu-map (Note: Be sure to install it in the project root directory):
In the terminal input:
npm install react-native-baidu-map --save
data:image/s3,"s3://crabby-images/19b8b/19b8bc2b4d570f289b7377a246e4eb13b595401d" alt=""
3.Xcode configuration:
data:image/s3,"s3://crabby-images/0b0fb/0b0fb3b206e4a25cf9b7cf67c53fa4773f0cbbb7" alt=""
data:image/s3,"s3://crabby-images/14035/140358ce30e17b2a7adbcb9e98945bee761ebdec" alt=""
Build Phases - > Link Binary With Libraries join libRCT BaiduMap.a
data:image/s3,"s3://crabby-images/820d8/820d80df80969e77e03c77081ee9434bef6ccb60" alt=""
Build Settings - > Search Paths, Framework search paths add $(PROJECT_DIR)/. / node_modules/react-native-baidu-map/ios/lib, Header search paths add $(SRCROOT)/. / node_modules/react-native-baidu-map/ios/RCTduMap
data:image/s3,"s3://crabby-images/d1aaa/d1aaa3e648a5bdc352f0c210e03184cb5dea2617" alt=""
data:image/s3,"s3://crabby-images/d505d/d505dc22dd610af880cb23d8d7269e65730a69f9" alt=""
Adding dependencies, all framwordk under react-native-baidu-map/ios/lib:
data:image/s3,"s3://crabby-images/96442/96442322deea1eb4e71687f8dae46cee7e43c2dc" alt=""
Method:
data:image/s3,"s3://crabby-images/8213f/8213f04b39e406f31988a45867175571e9b69498" alt=""
data:image/s3,"s3://crabby-images/f9499/f94990da0cf1fff8b85e0e8aa254169a35695635" alt=""
data:image/s3,"s3://crabby-images/6b411/6b411f7b2b75bb768f105e45544a2f968d76e84c" alt=""
data:image/s3,"s3://crabby-images/ad0be/ad0be3d711a06e3817dda24caeec1cf7c010a46c" alt=""
Then continue adding: CoreLocation.framework and Quartz Core. framework, OpenGLES.framework, SystemConfiguration.framework, CoreGraphics.framework, Security.framework, libsqlite3.0.tbd (libsqlite3.0.dylib before Xcode 7), CoreTelephony.framework, libstdc+.6.0.9.tbd (libstdc+.9.tbd before Xcode 7).+ + 6.0.9. dylib)
For example:
data:image/s3,"s3://crabby-images/9b37e/9b37e7d0b06864e27a4feccfbf42f6803179b801" alt=""
After adding all:
data:image/s3,"s3://crabby-images/98123/98123b77d39cafb04619eb7893e12bf379f8b697" alt=""
Next add BaiduMap API_Map.framework/Resources/mapapi.bundle
data:image/s3,"s3://crabby-images/2bbec/2bbec65669ff70633ceac166c3e69a439a2d6d82" alt=""
data:image/s3,"s3://crabby-images/5e626/5e6261a8bb4fe5c7097803e6b0d98fb4bbd1d39d" alt=""
data:image/s3,"s3://crabby-images/9a3d5/9a3d5f590b280b7a59937edcb13a0b163172da15" alt=""
4.AppDelegate.m init initialization
#import "RCTBaiduMapViewManager.h" - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { ... [RCTBaiduMapViewManager initSDK:@"api key"];//The api key here must correspond to the Bundle identifier of APP on the official website, otherwise the map will fail. ... }
data:image/s3,"s3://crabby-images/8853a/8853a4cdbe5f015415df5772735698f62c9c83fb" alt=""
5.build to see if the configuration is successful
This error may be reported at this time:
data:image/s3,"s3://crabby-images/9e02a/9e02a93f86b7ad5a1ce47db46ae144f222402ee3" alt=""
Solution:
#import "RCTViewManager.h" #import "RCTConvert+CoreLocation.h"
Change to
#import <React/RCTViewManager.h> #import <React/RCTConvert+CoreLocation.h>
As shown in the figure:
data:image/s3,"s3://crabby-images/4985a/4985ad73de45eea2f3f66cd86a142c788110b5ed" alt=""
Then build success.~
6. So far, the configuration has been completed, we can play Baidu Map in RN.~
Here we will refer to Demo on the official website to show you:
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 BaiduMapDemo from './BaiduMapDemo'; export default class BaiDuMapTest extends Component { render() { return ( <BaiduMapDemo /> ); } } const styles = StyleSheet.create({ container: { flex: 1, justifyContent: 'center', alignItems: 'center', backgroundColor: '#F5FCFF', }, welcome: { fontSize: 20, textAlign: 'center', margin: 10, }, instructions: { textAlign: 'center', color: '#333333', marginBottom: 5, }, }); AppRegistry.registerComponent('BaiDuMapTest', () => BaiDuMapTest);
BaiduMapDemo.js
/** * @author lovebing */ import React, { Component, PropTypes } from 'react'; import { MapView, MapTypes, Geolocation } from 'react-native-baidu-map'; import { Button, AppRegistry, StyleSheet, Text, View, TouchableHighlight } from 'react-native'; import Dimensions from 'Dimensions'; export default class BaiduMapDemo extends Component { constructor() { super(); this.state = { mayType: MapTypes.NORMAL, zoom: 15, center: { longitude: 113.981718, latitude: 22.542449 }, trafficEnabled: false, baiduHeatMapEnabled: false, markers: [{ longitude: 113.981718, latitude: 22.542449, title: "Window of the world" },{ longitude: 113.995516, latitude: 22.537642, title: "" }] }; } componentDidMount() { } render() { return ( <View style={styles.container}> <MapView trafficEnabled={this.state.trafficEnabled} baiduHeatMapEnabled={this.state.baiduHeatMapEnabled} zoom={this.state.zoom} mapType={this.state.mapType} center={this.state.center} marker={this.state.marker} markers={this.state.markers} style={styles.map} onMarkerClick={(e) => { console.warn(JSON.stringify(e)); }} onMapClick={(e) => { }} > </MapView> <View style={styles.row}> <Button title="Normal" onPress={() => { this.setState({ mapType: MapTypes.NORMAL }); }} /> <Button style={styles.btn} title="Satellite" onPress={() => { this.setState({ mapType: MapTypes.SATELLITE }); }} /> <Button style={styles.btn} title="Locate" onPress={() => { console.warn('center', this.state.center); Geolocation.getCurrentPosition() .then(data => { console.warn(JSON.stringify(data)); this.setState({ zoom: 15, marker: { latitude: data.latitude, longitude: data.longitude, title: 'Your location' }, center: { latitude: data.latitude, longitude: data.longitude, rand: Math.random() } }); }) .catch(e =>{ console.warn(e, 'error'); }) }} /> </View> <View style={styles.row}> <Button title="Zoom+" onPress={() => { this.setState({ zoom: this.state.zoom + 1 }); }} /> <Button title="Zoom-" onPress={() => { if(this.state.zoom > 0) { this.setState({ zoom: this.state.zoom - 1 }); } }} /> </View> <View style={styles.row}> <Button title="Traffic" onPress={() => { this.setState({ trafficEnabled: !this.state.trafficEnabled }); }} /> <Button title="Baidu HeatMap" onPress={() => { this.setState({ baiduHeatMapEnabled: !this.state.baiduHeatMapEnabled }); }} /> </View> </View> ); } } const styles = StyleSheet.create({ row: { flexDirection: 'row', height: 40 }, container: { flex: 1, justifyContent: 'flex-start', alignItems: 'center', backgroundColor: '#F5FCFF', }, map: { width: Dimensions.get('window').width, height: Dimensions.get('window').height - 200, marginBottom: 16 } });
Design sketch:
data:image/s3,"s3://crabby-images/a3e23/a3e23f849a6846c6393e74963edd290684091414" alt=""
I hope this article can help you. Thank you.~