Summary:Emulator in Android Studio 2.0 introduced new shortcut for hardware menu button. Closes https://github.com/facebook/react-native/pull/6923 Differential Revision: D3168434 fb-gh-sync-id: 7b73146003ae1d2191536796ea0fd50840ef5bec fbshipit-source-id: 7b73146003ae1d2191536796ea0fd50840ef5bec
5.6 KiB
id | title | layout | category | permalink | next |
---|---|---|---|---|---|
android-setup | Android Setup | docs | Quick Start | docs/android-setup.html | linux-windows-support |
This guide describes basic steps of the Android development environment setup that are required to run React Native android apps on an android emulator.
Install Git
-
On Mac, if you have installed XCode, Git is already installed, otherwise run the following:
brew install git
-
On Linux, install Git via your package manager.
-
On Windows, download and install Git for Windows. During the setup process, choose "Run Git from Windows Command Prompt", which will add Git to your
PATH
environment variable.
Install the Android SDK (unless you already have it)
- Install the latest JDK
- Install the Android SDK:
- On Mac:
brew install android-sdk
- On Linux and Windows: Download from the Android website
- On Mac:
Define the ANDROID_HOME environment variable
IMPORTANT: Make sure the ANDROID_HOME
environment variable points to your existing Android SDK:
-
On Mac, add this to your
~/.bashrc
,~/.bash_profile
or whatever your shell uses:# If you installed the SDK via Homebrew, otherwise ~/Library/Android/sdk export ANDROID_HOME=/usr/local/opt/android-sdk
-
On Linux, add this to your
~/.bashrc
,~/.bash_profile
or whatever your shell uses:export ANDROID_HOME=<path_where_you_unpacked_android_sdk>
-
On Windows, go to
Control Panel
->System and Security
->System
->Change settings
->Advanced
->Environment variables
->New
NOTE: You need to restart the Command Prompt (Windows) / Terminal Emulator (Mac OS X, Linux) to apply the new Environment variables.
Use gradle daemon
React Native Android use gradle as a build system. We recommend to enable gradle daemon functionality which may result in up to 50% improvement in incremental build times for changes in java code. Learn here how to enable it for your platform.
Configure your SDK
- Open the Android SDK Manager (on Mac start a new shell and run
android
); in the window that appears make sure you check:
- Android SDK Build-tools version 23.0.1
- Android 6.0 (API 23)
- Local Maven repository for Support Libraries (this is called Android Support Repository in older versions)
- Click "Install Packages"
Install Genymotion
Genymotion is much easier to set up than stock Google emulators. However, it's only free for personal use. If you want to use the stock Google emulator, see below.
- Download and install Genymotion.
- Open Genymotion. It might ask you to install VirtualBox unless you already have it.
- Create a new emulator and start it.
- To bring up the developer menu press ⌘+M
Alternative: Create a stock Google emulator
- Start a new shell and run
android
; in the window that appears make sure you check:
- Intel x86 Atom System Image (for Android 5.1.1 - API 22)
- Intel x86 Emulator Accelerator (HAXM installer)
- Click "Install Packages".
- Configure hardware acceleration (HAXM), otherwise the emulator is going to be slow (or may not run at all).
- On a mac this is typically requires opening:
/usr/local/opt/android-sdk/extras/intel/Hardware_Accelerated_Execution_Manager/IntelHAXM_<version>.dmg
and installing the package within.
- Create an Android Virtual Device (AVD):
- Run
android avd
and click on Create... - With the new AVD selected, click
Start...
- To bring up the developer menu press F2 (or ⌘+M for Android Studio 2.0 or newer)
- Install Frappé (OSX only)
Windows Hyper-V Alternative
The Visual Studio Emulator for Android is a free android emulator that is hardware accelerated via Hyper-V. It doesn't require you to install Visual Studio at all.
To use it with react-native you just have to add a key and value to your registry:
- Open the Run Command (Windows+R)
- Enter
regedit.exe
- In the Registry Editor navigate to
HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Android SDK Tools
- Right Click on
Android SDK Tools
and chooseNew > String Value
- Set the name to
Path
- Double Click the new
Path
Key and set the value toC:\Program Files\Android\sdk
. The path value might be different on your machine.
You will also need to run the command adb reverse tcp:8081 tcp:8081
with this emulator.
Then restart the emulator and when it runs you can just do react-native run-android
as usual.
Editing your app's Java code in Android Studio
You can use any editor to edit JavaScript. If you want to use Android Studio to work on native code, from the Welcome screen of Android Studio choose "Import project" and select the android
folder of your app.
Troubleshooting
In case you encounter
Execution failed for task ':app:installDebug'.
com.android.builder.testing.api.DeviceException: com.android.ddmlib.ShellCommandUnresponsiveException
try downgrading your Gradle version to 1.2.3 in <project-name>/android/build.gradle
(https://github.com/facebook/react-native/issues/2720)