Skip to content

Publish your game to Android and iOS manually using Cordova

From GDevelop, you can publish your games to Android and iOS. In the export dialog, you can choose the first Android and iOS option, which will use GDevelop online services to automatically build your game for Android and iOS.

If you want more control or have special needs, you can also choose iOS and Android (manual) option. This option exports your game as a Cordova project. Cordova is a technology allowing HTML5 games and apps to run on Android and iOS and be packaged as apps, and then distributed on the App Store or Play Store.

Warning

This option requires you to install advanced developer tools and some knowledge of how to use them. It's a good idea to read some external documentation as you discover them.

Export Window

Go to File > Export. Next, select Build Manually under Publish your game. Then, select the Mobile tab.

Build

First, choose a folder where the game will be exported. It is recommended to choose an empty folder, at least for the first time, to avoid losing any file that could be overwritten by the export.

You can then click on Package. The game will be exported to a Cordova project. You can then use Cordova command line tool to generate an Android Studio project (for Android) or XCode project (for iOS) and build the game.

Compiling for Android or iOS with Cordova

Building for Android or iOS with Cordova requires you to install specific tools on your system.

Ensure you checkout the latest documentation of Cordova to know exactly what needs to be installed: Cordova required tools

Here is a summary:

iOS/iPhone

you need macOS with XCode installed.

Android

You need to install:

  • Android Studio with the Android SDK
  • Java (version 11, can be downloaded from the Oracle website) - as we are using cordova-android 11
  • Gradle.

Build Cordova project

To be able to build the exported Cordova project, you also need to have Node.js installed on your system. Finally, you need to install Cordova by typing on the command prompt or terminal:

npm install -g cordova

After that, navigate to your Cordova project's directory and type this on the command prompt or terminal:

  • cordova platform add ios if you want to export your game to iOS.
  • cordova platform add android@11 if you want to export your game to Android.

This will create new folders on your project's directory:

  • platforms/ios: iOS project of your game, which can be open with XCode.
  • platforms/android: Android project of your game, which can be open with Android Studio.

Once you have specified what platform you want your game to be exported to, you can now build the Cordova project. Type on the command prompt or terminal either:

  • cordova build: this will build your project to all the platforms you have.
  • cordova build ios: this will only build your project into an iOS executable, that can be used to install your game on iOS devices.
  • cordova build android: this will only build your project into an Android executable (apk), that can be used to install your game on Android devices.

Tip

Cordova may need a specific version of the Android build tool. It can be installed with the SDK Manager. Ensure you have the Android SDKs of version 30 and 31.

Testing on emulators or Android/iOS devices

Testing on Android

You can run cordova run android to run the compiled application, or cordova run android --device to run on an Android device. Make sure that the device has the developer mode activated, is connected and recognized by the computer.

You can also open Android Studio and open the project (choose the platforms/android folder). Then you can see in the top right the list of connected devices (or installed emulators) and run the app.

Testing on iOS

  • You can list iOS simulators installed on your Mac with cordova emulate ios --list.
  • You can run the app on a specific simulator using target: cordova run ios --target="iPhone-8".

  • To test on an iOS device, it's recommended to launch XCode and open your project (open platforms/ios/YourProject.xcworkspace). You'll need to set up a "Development Team" and choose your device. This is because each device must be added to your "Development Team" before it can run development applications.

Exporting to the stores

Android

For Android, you can compile your app as a release AAB (that can be uploaded on the Play Store), with cordova build. The command line should look like this:

cordova build android --release -- --keystore=/path/to/keystore --storePassword=KEYSTORE_STORE_PASSWORD --alias=KEYSTORE_ALIAS --password=KEYSTORE_PASSWORD --packageType bundle

You can also use Android Studio (open it, then open the platforms/android folder) for building a release APK or Android App Bundle. Choose Build > Generate Signed Bundle / APK....

When you have a signed release APK or Android App Bundle, you can upload it to the Play Developer Console.

iOS

For iOS, it's recommended to open the project (workspace) in XCode and to use the menu Project > Archive.

Note that you might have to change the code signing in the Build Settings:

Once Code Signing is set up (XCode should guide you if there are errors) and the Archive process finished, you'll see a list of your app archives. You can now distribute the app to upload it to the App Store:

Follow the process to get your app uploaded and then go on iTunes Connect to fill in the descriptions, add optional testers with TestFlight, and submit your app for review by Apple.

Export to other platforms (Web, Windows, macOS, Linux)

See the other export options to learn how to publish your game on other platforms!