美文网首页React-Nativereact-native
react-native 实现百度地图(ios&Andr

react-native 实现百度地图(ios&Andr

作者: sybil052 | 来源:发表于2017-03-31 17:32 被阅读5018次

    最近公司需要在app上使用地图组件加载地图,从网上找了很多第三方都不是很理想,总会有ios和Android不兼容的问题,后来在GitHub上看到了react-native-baidu-map,觉得可以一试,虽然GitHub上有配置说明,但在过程中遇到许多坑,写篇文章记录一下,免得忘记。

    准备工作

    先说明一下,我使用的react-native开发工具是webStorm,同时我们需要你的电脑上装有Android studio和Xcode,这样方便我们配置后面的一些东西。android我使用的是真机来运行,而ios直接使用模拟器运行,至于mac上怎么使用Android真机运行程序,我想也不用赘述了。
    好了,下面正式开始我们的项目。

    1.创建项目

    首先打开终端,在相应的目录下输入命令创建新项目,

    react-native init BaiDuMapDemo
    

    项目创建完成,进入项目根目录下输入

    npm install react-native-baidu-map --save
    

    打开网址:https://github.com/lovebing/react-native-baidu-map
    下载demo,如果你有git,你也可以直接使用命令下载demo:

    git clone https://github.com/lovebing/react-native-baidu-map.git
    

    demo下载完成,将demo中的BaiduMapDemo.js文件直接拷贝到新建项目的根目录下,使用webStorm打开新建的项目,修改index.android.js和index.ios.js文件。

    import React, { Component } from 'react';
    import {
      AppRegistry,
      StyleSheet,
      Text,
      View,
      TouchableHighlight
    } from 'react-native';
    import BaiduMapDemo from './BaiduMapDemo'
    
    export default class BaiDuMapDemo extends Component {
      render() {
        return (
          <BaiduMapDemo/>
        );
      }
    }
    
    AppRegistry.registerComponent('BaiDuMapDemo', () => BaiDuMapDemo);
    

    2.Android运行

    (1)在settings.gradle中添加以下内容
    include ':react-native-baidu-map'
    project(':react-native-baidu-map').projectDir = new File(settingsDir, '../node_modules/react-native-baidu-map/android')
    
    (2)在build.gradle中添加:
    compile project(':react-native-baidu-map')
    
    (3) 修改MainApplication.Java 文件

    添加:new BaiduMapPackage(getApplicationContext())
    例如:

    @Override
    protected List<ReactPackage> getPackages() {
      return Arrays.<ReactPackage>asList(
          new MainReactPackage(),
          new BaiduMapPackage(getApplicationContext())
      );
    }
    
    (4) 修改AndroidMainifest.xml 文件

    此文件有2处需要配置:
    1)配置各种权限
    2)添加com.baidu.lbsapi.API_KEY
    完整权限配置:

        <!-- 这个权限用于进行网络定位-->
        <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
        <!-- 这个权限用于访问GPS定位-->
        <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
        <!-- 用于访问wifi网络信息,wifi信息会用于进行网络定位-->
        <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
    
        <uses-permission android:name="android.permission.INTERNET" />
        <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
        <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
        <uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />
        <uses-permission android:name="android.permission.WAKE_LOCK"/>
        <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
        <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
        <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
        <uses-permission android:name="android.permission.WRITE_SETTINGS" />
    
        <uses-sdk
            android:minSdkVersion="16"
            android:targetSdkVersion="22" />
    
        <application
          android:name=".MainApplication"
          android:allowBackup="true"
          android:label="@string/app_name"
          android:icon="@mipmap/ic_launcher"
          android:theme="@style/AppTheme">
    
            <meta-data
                android:name="com.baidu.lbsapi.API_KEY"
                android:value="3Hk70Z0e6N3hDRQZwuLFAlgLqB5B4ak7"/>
    

    注意:API_key需要自己去百度地图API申请!

    (5)运行

    使用命令运行项目:

    npm install
    react-native run-android
    

    按道理说这样配置完成项目就已经能跑了,但是手机却出错了

    QQ20170331-164649@2x.png
    百度了一下找到了解决方案:http://www.open-open.com/lib/view/open1477469117948.html
    然后运行成功啦上效果图 IMG_0914.JPG

    2.IOS运行

    (1)打开文件

    使用Xcode打开新建项目中ios目录中的BaiDuMapDemo.xcodeproj文件

    (2)配置

    1)Project navigator->Libraries->Add Files to 选择BaiDuMapDemo/node_modules/react-native-baidu-map/ios/RCTBaiduMap.xcodeproj

    QQ20170331-170747.png

    2)Project navigator->Build Phases->Link Binary With Libraries 加入 libRCTBaiduMap.a

    QQ20170331-171006.png

    3)添加BaiDuMapDemo/node_modules/react-native-baidu-map/ios/lib,并在Project navigator->Build Settings->Search Paths, Framework search paths 添加路径xxx/BaiDuMapDemo/node_modules/react-native-baidu-map/ios/lib,Header search paths 添加 xxx/BaiDuMapDemo/node_modules/react-native-baidu-map/ios/RCTBaiduMap

    QQ20170331-171755.png

    4)添加依赖, react-native-baidu-map/ios/lib 下的全部 framwordk(上一步拷贝lib时这些已经自动添加,可省略), CoreLocation.framework和QuartzCore.framework、OpenGLES.framework、SystemConfiguration.framework、CoreGraphics.framework、Security.framework、libsqlite3.0.tbd(xcode7以前为 libsqlite3.0.dylib)、CoreTelephony.framework 、libstdc++.6.0.9.tbd(xcode7以前为libstdc++.6.0.9.dylib)

    QQ20170331-172020.png

    5)添加 BaiduMapAPI_Map.framework/Resources/mapapi.bundle

    QQ20170331-172144.png

    6)AppDelegate.m init 初始化

    #import "RCTBaiduMapViewManager.h"
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
        ...
        [RCTBaiduMapViewManager initSDK:@"api key"];
        ...
    }
    

    注意:api key也要替换成自己申请的key

    7)编译运行
    上效果图~

    QQ20170331-172320@2x.png

    注意:在配置iOS时会有很多坑,我配置时出现了duplicate symbols for architecture x86_64错误,百度后发现是重复导入RCTBaiduMap文件夹导致的,将文件夹删除即可解决,将解决的网址贴出来:http://blog.csdn.net/crazyzhang1990/article/details/49586049

    好了,自此Android和ios平台的百度地图全部加载出来了!希望大家也能顺利运行出来~

    相关文章

      网友评论

      • 昔颜_a266:楼主这一句#import "RCTBaiduMapViewManager.h"项目里面没这个文件,这个只有是0.48.3才有吗?
      • 0baa9561da80:楼主,我现在要做的需求是可以搜索地点,然后导航过去,这个需求能实现吗
      • channelRead0:一年之后的今天,我也开始趟react-native的坑了。
        sybil052:@逆水行舟____ 加油
      • 私小甲鱼:我安装上面步骤来弄 导入库完后运行项目 发现 #import "RCTBridgeModule.h" file not found,这是要怎么处理的
        e3f10e3206c9:@私小甲鱼 您好 安卓打包后,点击地图页面就闪退,你遇到了吗,您有qq吗
        私小甲鱼:@sybil052 灰常谢谢大神, 我弄好了
        sybil052:@私小甲鱼 改为<React/RCTBridgeModule.h>试一下
      • 简翦儋箪:请问一下,我安装的时候为什么一直报错,一直报Redefinition of 'RCTMethodInfo'
        简翦儋箪:@sybil052 好的 我试试 谢谢
        sybil052:详细参考我的另一篇文章《项目升级到0.48.3常见问题》https://www.jianshu.com/p/427fa3004ad3
        sybil052:@简翦儋箪 把项目中的#import "RCTBridgeModule.h"改为#import <React/RCTBridgeModule.h>试试
      • ebf135683f92:请问博主 rn 0.52.0 版本能正常运行么
        ebf135683f92:@sybil052 谢谢
        sybil052:@ebf135683f92 0.52.0我没有试,0.48.3可以~
      • fighterboy:这个坐标点的样式 怎么换成我自己的
        sybil052:@fighterboy 现在的我的位置,也是用标注搞的,你可以用sdk中的定位自己写一下~或者拓展一下标注的样式的自定义
        fighterboy:@sybil052 我的位置跟 注入的坐标 可以分开么 我那个显示的是一个图片
        sybil052:ios的图标在BaiduMapAPI_Map.framework/Resources/mapapi.bundle/images文件夹下,android的图标在android/src/res/mipmap-hdpi文件夹下
      • 丶HanGH:你好请问第5步的/mapapi.bundle在哪里添加...
        sybil052:找到node_modules/react-native-baidu-map/ios/BaiduMapAPI_Map.framework/Resources/mapapi.bundle,直接拖进去就行了
      • 苏州韭菜明:留下我的脚印
      • 叫我旺仔:留下我的脚印

      本文标题:react-native 实现百度地图(ios&Andr

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