Android 谷歌地图 [React Native?] "API key not found. Check that.."错误

标签 android react-native google-maps react-native-maps

嗨,我是 React Native 的新手。我刚刚做了一个新的应用程序。当我的应用程序中没有 map 组件时,我的其他组件工作正常。但是,当我将其添加到我的 render(){return(..

  <MapView
    ref={ref => { this.map = ref; }}
    mapType={MAP_TYPES.TERRAIN}
    style={styles.map}
    initialRegion={this.state.region}
    onRegionChange={region => this.onRegionChange(region)}
  />

我得到错误:

enter image description here

我搜索了项目文件夹以找到一个 AndroidMainfest.xml,我找到了一对。我更改了一个:\android\app\build\intermediates\manifests\full\debug

来自这里:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.pickup_sports_app"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="16"
        android:targetSdkVersion="22" />

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <!-- Include required permissions for Google Maps API to run. -->
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

    <uses-feature
        android:glEsVersion="0x00020000"
        android:required="true" />

    <android:uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <android:uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <android:uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

    <application
        android:name="com.pickup_sports_app.MainApplication"
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.pickup_sports_app.MainActivity"
            android:configChanges="keyboard|keyboardHidden|orientation|screenSize"
            android:label="@string/app_name"
            android:windowSoftInputMode="adjustResize" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="com.facebook.react.devsupport.DevSettingsActivity" />
        <activity
            android:name="com.google.android.gms.common.api.GoogleApiActivity"
            android:exported="false"
            android:theme="@android:style/Theme.Translucent.NoTitleBar" />

        <meta-data
            android:name="com.google.android.gms.version"
            android:value="@integer/google_play_services_version" />
    </application>

</manifest>

对此:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.pickup_sports_app"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="16"
        android:targetSdkVersion="22" />

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <!-- Include required permissions for Google Maps API to run. -->
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

    <uses-feature
        android:glEsVersion="0x00020000"
        android:required="true" />

    <android:uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <android:uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <android:uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

    <application
        android:name="com.pickup_sports_app.MainApplication"
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.pickup_sports_app.MainActivity"
            android:configChanges="keyboard|keyboardHidden|orientation|screenSize"
            android:label="@string/app_name"
            android:windowSoftInputMode="adjustResize" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="com.facebook.react.devsupport.DevSettingsActivity" />
        <activity
            android:name="com.google.android.gms.common.api.GoogleApiActivity"
            android:exported="false"
            android:theme="@android:style/Theme.Translucent.NoTitleBar" />

        <meta-data
            android:name="com.google.android.gms.version"
            android:value="@integer/google_play_services_version" />
        <meta-data
            android:name="com.google.android.geo.API_KEY"
            android:value="AIzaSyC-V3J1Wz4wqgHqrqffIeZqhVM0gDfTsIg" />

    </application>

</manifest>

我什至只是用 meta-deta API Key 试了一下。

一些其他信息: 我从这里获得了 API key :https://developers.google.com/maps/documentation/android-api/signup .

在我更改它之后,我只是保存了文件并重新启动了模拟器,并在带有命令提示符的目录中使用 react-native run-android 重新启动了应用程序。我不确定这是否是“重建”项目的正确方法。

我正在使用 Facebook 推荐使用的 Airbnb react-native-maps 组件:https://github.com/airbnb/react-native-maps

我最近做了 npm install react-native-maps --savereact-native link react-native-maps 因为这是一个全新的项目(错误在他们提供的新版本中还是什么?)。模拟器是android 7.1.1。

这是 android studio 模拟器的 SDK 管理器: enter image description here

最佳答案

您正在做添加 API_KEY 元素的正确更改。但是,在以下位置编辑文件:

\android\app\\**src**\main (Source directory)

代替

\android\app\\**build**\intermediates\manifests\full\debug (Build directory)

关于Android 谷歌地图 [React Native?] "API key not found. Check that.."错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43170673/

相关文章:

iphone - 如何在谷歌地图自动完成API中获得五个以上的结果

java - Android/Firebase - 如何将检索到的数据添加到 ArrayList

java - 为什么我在使用realm.executeTransactionAsync()方法时遇到编译时错误?

html - 在 Android 中呈现格式化文本的推荐方法?

java - 如何通过忽略大小写来过滤 Recycleview?

javascript - react native : is it possible to stop PanResponder event inside onPanResponderMove?

reactjs - React Native,类型错误: undefined is not an object When it is

reactjs - 删除了“transitionConfig”以支持新的动画 API

android - 如何获取折线点击的具体数据?

javascript - 如何确定静态 Google map 缩放级别