exporting_for_android.rst 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. .. _doc_exporting_for_android:
  2. Exporting for Android
  3. =====================
  4. .. seealso::
  5. This page describes how to export a Godot project to Android.
  6. If you're looking to compile export template binaries from source instead,
  7. read :ref:`doc_compiling_for_android`.
  8. Exporting for Android has fewer requirements than compiling Godot for Android.
  9. The following steps detail what is needed to set up the Android SDK and the engine.
  10. Install OpenJDK 11
  11. ------------------
  12. Download and install `OpenJDK 11 <https://adoptium.net/?variant=openjdk11>`__.
  13. Download the Android SDK
  14. ------------------------
  15. Download and install the Android SDK.
  16. - You can install it using `Android Studio version 4.1 or later <https://developer.android.com/studio/>`__.
  17. - Run it once to complete the SDK setup using these `instructions <https://developer.android.com/studio/intro/update#sdk-manager>`__.
  18. - Ensure that the `required packages <https://developer.android.com/studio/intro/update#recommended>`__ are installed as well.
  19. - Android SDK Platform-Tools version 30.0.5 or later
  20. - Android SDK Build-Tools version 30.0.3
  21. - Android SDK Platform 29
  22. - Android SDK Command-line Tools (latest)
  23. - CMake version 3.10.2.4988404
  24. - NDK version 21.4.7075529
  25. - You can install it using the `command line tools <https://developer.android.com/studio/#command-tools>`__.
  26. - Once the command line tools are installed, run the `sdkmanager <https://developer.android.com/studio/command-line/sdkmanager>`__ command to complete the setup process:
  27. ::
  28. sdkmanager --sdk_root=<android_sdk_path> "platform-tools" "build-tools;30.0.3" "platforms;android-29" "cmdline-tools;latest" "cmake;3.10.2.4988404" "ndk;21.4.7075529"
  29. .. note::
  30. If you are using Linux,
  31. **do not use an Android SDK provided by your distribution's repositories as it will often be outdated**.
  32. Create a debug.keystore
  33. -----------------------
  34. Android needs a debug keystore file to install to devices and distribute
  35. non-release APKs. If you have used the SDK before and have built
  36. projects, ant or eclipse probably generated one for you (in the ``~/.android`` directory on Linux and
  37. macOS, in the ``C:\Users\<user>\.android\`` directory on Windows).
  38. If you can't find it or need to generate one, the keytool command from
  39. the JDK can be used for this purpose::
  40. keytool -keyalg RSA -genkeypair -alias androiddebugkey -keypass android -keystore debug.keystore -storepass android -dname "CN=Android Debug,O=Android,C=US" -validity 9999 -deststoretype pkcs12
  41. This will create a ``debug.keystore`` file in your current directory. You should move it to a memorable location such as ``%USERPROFILE%\.android\``, because you will need its location in a later step. For more information on ``keytool`` usage, see `this Q&A article <https://godotengine.org/qa/21349/jdk-android-file-missing>`__.
  42. Setting it up in Godot
  43. ----------------------
  44. Enter the Editor Settings screen. This screen contains the editor
  45. settings for the user account in the computer (it's independent of the
  46. project).
  47. .. image:: img/editorsettings.png
  48. Scroll down to the section where the Android settings are located:
  49. .. image:: img/androidsdk.png
  50. In that screen, 2 paths need to be set:
  51. - The ``Android Sdk Path`` should be the location where the Android SDK was installed.
  52. - For example ``%LOCALAPPDATA%\Android\Sdk\`` on Windows or ``/Users/$USER/Library/Android/sdk/`` on macOS.
  53. - The debug ``.keystore`` file
  54. - It can be found in the folder where you put the ``debug.keystore`` file you created above.
  55. Once that is configured, everything is ready to export to Android!
  56. .. note::
  57. If you get an error saying *"Could not install to device."*, make sure
  58. you do not have an application with the same Android package name already
  59. installed on the device (but signed with a different key).
  60. If you have an application with the same Android package name but a
  61. different signing key already installed on the device, you **must** remove
  62. the application in question from the Android device before exporting to
  63. Android again.
  64. Providing launcher icons
  65. ------------------------
  66. Launcher icons are used by Android launcher apps to represent your application to users. Godot only requires high-resolution icons (for ``xxxhdpi`` density screens) and will automatically generate lower-resolution variants.
  67. There are two types of icons required by Godot:
  68. - **Main Icon:** The "classic" icon. This will be used on all Android versions up to Android 8 (Oreo), exclusive. Must be at least 192×192 px.
  69. - **Adaptive Icons:** Starting from Android 8 (inclusive), `Adaptive Icons <https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive>`_ were introduced. Applications will need to include separate background and foreground icons to have a native look. The user's launcher application will control the icon's animation and masking. Must be at least 432×432 px.
  70. .. seealso:: It's important to adhere to some rules when designing adaptive icons. `Google Design has provided a nice article <https://medium.com/google-design/designing-adaptive-icons-515af294c783>`_ that helps to understand those rules and some of the capabilities of adaptive icons.
  71. .. caution:: The most important adaptive icon design rule is to have your icon critical elements inside the safe zone: a centered circle with a diameter of 66dp (264 pixels on ``xxxhdpi``) to avoid being clipped by the launcher.
  72. If you don't provide some of the requested icons, Godot will replace them using a fallback chain, trying the next in line when the current one fails:
  73. - **Main Icon:** Provided main icon -> Project icon -> Default Godot main icon.
  74. - **Adaptive Icon Foreground:** Provided foreground icon -> Provided main icon -> Project icon -> Default Godot foreground icon.
  75. - **Adaptive Icon Background:** Provided background icon -> Default Godot background icon.
  76. It's highly recommended to provide all the requested icons with their specified resolutions.
  77. This way, your application will look great on all Android devices and versions.
  78. Exporting for Google Play Store
  79. -------------------------------
  80. Uploading an APK to Google's Play Store requires you to sign using a non-debug
  81. keystore file; such file can be generated like this:
  82. .. code-block:: shell
  83. keytool -v -genkey -keystore mygame.keystore -alias mygame -keyalg RSA -validity 10000
  84. This keystore and key are used to verify your developer identity, remember the password and keep it in a safe place!
  85. Use Google's Android Developer guides to learn more about `APK signing <https://developer.android.com/studio/publish/app-signing>`__.
  86. Now fill in the following forms in your Android Export Presets:
  87. .. image:: img/editor-export-presets-android.png
  88. - **Release:** Enter the path to the keystore file you just generated.
  89. - **Release User:** Replace with the key alias.
  90. - **Release Password:** Key password. Note that the keystore password and the key password currently have to be the same.
  91. **Your export_presets.cfg file now contains sensitive information.** If you use
  92. a version control system, you should remove it from public repositories and add
  93. it to your ``.gitignore`` file or equivalent.
  94. Don't forget to uncheck the **Export With Debug** checkbox while exporting.
  95. .. image:: img/export-with-debug-button.png
  96. Optimizing the APK size
  97. -----------------------
  98. By default, the APK will contain native libraries for both ARMv7 and ARMv8
  99. architectures. This increases its size significantly. To create a smaller APK,
  100. uncheck either **Armeabi-v 7a** or **Arm 64 -v 8a** in your project's Android
  101. export preset. This will create an APK that only contains a library for
  102. a single architecture. Note that applications targeting ARMv7 can also run on
  103. ARMv8 devices, but the opposite is not true.
  104. Since August 2019, Google Play requires all applications to be available in
  105. 64-bit form. This means you cannot upload an APK that contains *just* an ARMv7
  106. library. To solve this, you can upload several APKs to Google Play using its
  107. `Multiple APK support <https://developer.android.com/google/play/publishing/multiple-apks>`__.
  108. Each APK should target a single architecture; creating an APK for ARMv7
  109. and ARMv8 is usually sufficient to cover most devices in use today.
  110. You can optimize the size further by compiling an Android export template with
  111. only the features you need. See :ref:`doc_optimizing_for_size` for more
  112. information.
  113. Troubleshooting rendering issues
  114. --------------------------------
  115. To improve out-of-the-box performance on mobile devices, Godot automatically
  116. uses low-end-friendly settings by default on both Android and iOS.
  117. This can cause rendering issues that do not occur when running the project on a
  118. desktop platform. See :ref:`doc_mobile_rendering_limitations` for more information.