Demo Application for React Native Mapbox GL
Note: this app is using non trivial bable/metro configs, so we can consume the maps
library from parent directory directly. Regular apps don't need this complicated setup.
Mapbox is the location data platform for mobile and web applications. We provide building blocks to add location features like maps, search, and navigation into any experience you create. Use our simple and powerful APIs & SDKs and our open source libraries for interactivity and control.
Not a Mapbox user yet? Sign up for an account here. Once you’re signed in, all you need to start building is a Mapbox access token. Use this same short code with all of our interactive mapping libraries, Python and JavaScript SDKs, and directly against our REST APIs. You can create and manage your access tokens on your Mapbox Account page.
- Make sure you are in the example directory
cd example
-
Create a file called
accesstoken
in the root of the example project and just paste in your Mapbox access token. (Theaccesstoken
file is processed in postinstall, so you need to runnpm install
after adding/changing accesstoken.) -
Install our dependencies using
npm install
.
Open up another tab in your Terminal and run
npm start
Note: if modules were added to base lib you might need to run npm start --reset-cache
because we're using babel
to rewrite imports
- Start Android emulator
- Run
adb reverse tcp:8081 tcp:8081
to forward port to packager(needed for hot reloading, if you're not developing you can skip this step). - Run
react-native run-android
fromexample
directory
NOTE
If the build fails make sure gradle has permission to build from cli
cd android
chmod +x gradlew
You can run this with the react-native cli or Xcode
- Run
cd ios && pod install && cd ..
fromexample
directory to install cocoapods pods - Run
react-native run-ios
fromexample
directory
NOTE
If you run into
Command failed: /usr/libexec/PlistBuddy -c Print:CFBundleIdentifier build/Build/Products/Debug-iphonesimulator/RNMapboxGLExample.app/Info.plist
Print: Entry, ":CFBundleIdentifier", Does Not Exist
Just run the example from Xcode, it seems to be an issue with RN.