Run with --ignore-scripts
if you don't want to download the iOS SDK, as well.
npm install --save react-native-mapbox-gl --ignore-scripts
react-native link
Edit the following files:
// file: android/settings.gradle
...
include ':reactnativemapboxgl'
project(':reactnativemapboxgl').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-mapbox-gl/android')
// file: android/app/build.gradle
...
dependencies {
...
compile project(':reactnativemapboxgl')
}
// file: android/app/src/main/java/com/yourcompany/yourapp/MainActivity.java
import com.mapbox.reactnativemapboxgl.ReactNativeMapboxGLPackage; // <-- import
...
/**
* A list of packages used by the app. If the app uses additional views
* or modules besides the default ones, add more packages here.
*/
@Override
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
new MainReactPackage(),
new ReactNativeMapboxGLPackage()); // <-- Register package here
}
Add the following permissions to the <manifest>
root node of your AndroidManifest.xml
:
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.INTERNET" />
Also, add the Mapbox analytics service to the <application>
node:
<service android:name="com.mapbox.mapboxsdk.telemetry.TelemetryService"/>