Monaca Docs
  • Monaca
  • Create Your First App
  • Release Notes and Updates
    • Privacy Manifest Requirement for iOS Apps
    • Plugin uses-permission Tag Deduplication Feature
    • iOS Monaca Debugger Discontinuation & Alternative Features
    • Error submitting to iOS App Store (ITMS-90165)
    • Build error in cordova-custom-config
    • Cordova 11 changes
    • Cordova 10 changes
    • Cordova 9 changes
    • New Monaca CLI and Localkit
    • Migration from Cordova to Capacitor
  • Product Guides
    • Monaca Development Overview
    • Monaca Cloud IDE
      • Overview
      • Features in the Monaca Cloud IDE
      • Integrated Terminal
      • Editor Shortcuts
      • Project Dependencies
        • File and Folder Structure
        • JS/CSS Components
        • Cordova Plugins
        • Custom Cordova Plugins
      • Version Control
        • Introduction
        • GitHub Integration
        • Git SSH Integration
      • Monaca CI
        • Overview
        • Deploy Services
        • Deploy to Appetize.io
        • Deploy to DeployGate
        • Deploy to Firebase
      • Build
        • Building for iOS
          • Building an iOS App
          • Build Settings between Monaca and Xcode
        • Building for Android
        • Building for Electron
          • Building on Windows
        • Building for PWA
        • Building for Windows
        • Build Environment Settings
        • Common Build and Application Upload Errors
        • Build History
      • Distribution
        • App Store Distribution
          • App Store Connect Guide
          • iOS App Upload Feature
        • Google Play Distribution
        • Amazon Appstore Distribution
        • Non-market App Distribution
      • Download App Package
      • Tutorial
    • Monaca Localkit
      • Overview
      • Pairing and Debugging
      • Remote Building and Publishing
      • Troubleshooting Guide
      • Tutorial
    • Monaca CLI
      • Overview
      • Monaca CLI Commands
      • Pairing and Debugging
      • Project Dependencies
        • File and Folder Structure
        • JS/JSS Components
        • Cordova Plugins
        • Custom Cordova Plugins
      • Remote Building and Publishing
      • Troubleshooting Guide
      • Tutorial
    • Monaca Debugger
      • Functionalities
      • Installation
        • Monaca Debugger for Android
        • Monaca Debugger for iOS
        • Monaca Debugger for Android Emulator
      • Usage
      • Custom Build Debugger for iOS
      • iOS App Simulator Build
      • Troubleshooting Guide
      • Tutorials
    • Team Dashboard
    • Quick Viewer
    • Migrating from Other Platforms
      • Key Points
      • Cloud IDE preview function settings
      • Migrating from Angular
      • Migrating from Ionic
      • Migrating from React
      • Migrating from Vue
      • Migrating from PhoneGap
        • Key Differences
        • Guide for PhoneGap Build Users
        • Guide for PhoneGap CLI Users
        • Guide for PhoneGap Desktop App Users
      • Migrating from Telerik
  • Build App
    • Build for iOS
      • Creating a Private Key and CSR
      • Creating a Certificate
      • Updating Provisioning Profiles
  • Tutorials
    • Monaca Cloud IDE Tutorial
      • Part 1: Starting a Project
      • Part 2: Running Monaca Debugger with Monaca Cloud IDE
      • Part 3: Building a Monaca App
      • Part 4: Publishing a Monaca App
    • Monaca Localkit Tutorial
      • Part 1: Starting a Project
      • Part 2: Running Monaca Debugger with Monaca Localkit
      • Part 3: Building a Monaca App
      • Part 4: Publishing a Monaca App
    • Monaca CLI Tutorial
      • Part 1: Starting a Project
      • Part 2: Running Monaca Debugger with Monaca CLI
      • Part 3: Building a Monaca App
      • Part 4: Publishing a Monaca App
    • Electron Tutorial
      • How to Use a NPM Package
      • How to Use a Web API
    • Barcode Scanner Plugin
    • Cordova SQLite Storage Plugin
    • Cordova Google Analytics Plugin
    • Cordova Firebase Plugin
    • Cordova In-app Purchase Plugin
    • Cordova AppVersion Plugin
    • Cordova Ionic Keyboard Plugin
    • Cordova Social Sharing Plugin
    • NIFCLOUD mobile backend
    • Phonegap Push Plugin
  • API Reference
    • Monaca API
      • Monaca Cloud & Remote Build API Guide
      • Utilities
    • Core Cordova Plugins
      • Cordova 11.0
        • Battery Status Plugin
        • Camera Plugin
        • Device Plugin
        • Device Motion Plugin
        • Device Orientation Plugin
        • Dialogs Plugin
        • File Plugin
        • Geolocation Plugin
        • InAppBrowser Plugin
        • Media Plugin
        • Media Capture Plugin
        • Network Information Plugin
        • Splashscreen Plugin
        • Vibration Plugin
        • StatusBar Plugin
      • Cordova 10.0
        • Battery Status Plugin
        • Camera Plugin
        • Device Plugin
        • Device Motion Plugin
        • Device Orientation Plugin
        • Dialogs Plugin
        • File Plugin
        • Geolocation Plugin
        • InAppBrowser Plugin
        • Media Plugin
        • Media Capture Plugin
        • Network Information Plugin
        • Splashscreen Plugin
        • Vibration Plugin
        • StatusBar Plugin
        • Whitelist Plugin (Android Only)
      • Cordova 9.0
        • Battery Status Plugin
        • Camera Plugin
        • Contacts Plugin
        • Device Plugin
        • Device Motion Plugin
        • Device Orientation Plugin
        • Dialogs Plugin
        • File Plugin
        • File Transfer Plugin
        • Geolocation Plugin
        • Globalization Plugin
        • InAppBrowser Plugin
        • Media Plugin
        • Media Capture Plugin
        • Network Information Plugin
        • Splashscreen Plugin
        • Vibration Plugin
        • StatusBar Plugin
        • Whitelist Plugin (Android Only)
    • Third-party Cordova Plugins
      • Advanced HTTP Plugin
      • PhoneGap BarcodeScanner Plugin
      • Cordova Custom Config Plugin
      • DatePicker Plugin
      • Share Plugin (Android)
      • WebIntent Plugin (Android)
    • Monaca Power Plugins
      • Monaca HTML5 Resource Encryption
      • Monaca In-App Updater
      • Monaca Secure Storage
      • Barcode Scanner Plugin
      • Android build memory size setting
    • Service Integration
      • Repro
      • AppsFlyer
    • Configuration Files
      • Android
        • Android Configuration
        • config.xml
        • AndroidManifest.xml
      • iOS
        • iOS Configuration
        • config.xml
        • MonacaApp-Info.plist
  • Samples & Tips
    • Sample Apps
      • AdMob
      • Twitter Single Sign-on App
      • Facebook Single Sign-on App
      • Flickr
      • TODO App
      • BirthYear App
      • Break the Bricks
      • Train Catalog App
      • Omikuji Fortune Telling App
      • Clock App
      • Memo Application
      • RSS Reader App
      • Hello World App
    • Tips & Tricks
      • Playing Sound and Music
      • Control the Splash Screen
      • Using Database
  • Features
    • Push Notification
    • SNS Authentication
    • Database
  • FAQ
    • General
    • IDE
    • Build
    • Release
    • Subscription
      • How to Use Activation Code
    • Application
    • Usage
    • Debugger
  • Supported Environments
  • Trouble Shooting
    • Preview Log repeats to reload (Vue packages version mismatch error)
  • Monaca Product Website
  • 日本語
Powered by GitBook
On this page
  • AndroidManifest.xml (Main elements)
  • <manifest>
  • <uses-sdk>
  • <uses-permission>
  • <uses-feature>
  • <application>
  • <intent-filter>
  • <action>
  • <category>

Was this helpful?

  1. API Reference
  2. Configuration Files
  3. Android

AndroidManifest.xml

Previousconfig.xmlNextiOS

Last updated 3 years ago

Was this helpful?

Basic behaviour of Android applications can be configured by editing AndroidManifest.xml file. It is located under android folder inside your monaca project as shown below:

For Cordova 6.2 or higher, AndroidManifest.xml file is removed from Monaca framework. Therefore, in order to config Android application settings, use .

AndroidManifest.xml (Main elements)

<?xml version="1.0" encoding="utf-8"?>
<manifest>

  <uses-permission />
  <uses-sdk />
  <uses-feature />
  <supports-screens />

  <application>
    <activity>
        <intent-filter>
            <action />
            <category />
        </intent-filter>
    </activity>
  </application>

</manifest>

<manifest>

Is the root element of AndroidManifest.xml file. The child element of <manifest> is <application> and it must contain xlmns:android and package attributes.

Attribute

Type

Description

xmlns:android

String

An Android namespace attribute. This attribute must always have this value: http://schemas.android.com/apk/res/android.

android:versionCode

String

An internal version number. It is used only to determine whether one version is more recent than others. Higher number indicates a more recent version. This version number is not shown to users.

android:versionName

String

A version number which is visible to users.

package

String

Package name

Example

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    android:versionCode="%%%VERSION_CODE%%%"
    android:versionName="%%%VERSION_NAME%%%" package="%%%PACKAGE_NAME%%%">
</manifest>

<uses-sdk>

Is API level settings of the application. This element is contained in <manifest>.

Attribute

Type

Description

android:minSdkVersion

Number

Minimum API level required for the application to run. Android uses this value to determine whether the application can be installed in a device.

android:targetSdkVersion

Number

API level that the application targets.

Example

<uses-sdk android:minSdkVersion="14" android:targetSdkVersion="22" />

<uses-permission>

Is permission settings. The permission is granted When the application is installed. This element is contained in <manifest>.

Attribute

Type

Description

android:name

String

Name of the permissions to be granted for the Android system. The name of the permission can be defined as Camera, Network and etc.

How to Define <uses-permission>

<components/loader.js> needs ACCESS_NETWORK_STATE permission to run. You may exclude this file from <uses-permission> if it's not necessary for your application.

<uses-permission android:name="%%%PERMISSION_NAME%%%"></uses-permission>

Permission

PERMISSION_NAME

Description

Access Coarse Location

android.permission.ACCESS_COARSE_LOCATION

Allows an app to access current location of a device.

Access Fine Location

android.permission.ACCESS_FINE_LOCATION

Allows an app to use location-based services of a device.

Access Network State

android.permission.ACCESS_NETWORK_STATE

Allows an app to access the Network state.

Access Location Extra Commands

android.permission.ACCESS_LOCATION_EXTRA_COMMANDS

Allows an app to access extra location provider commands.

Bluetooth

android.permission.BLUETOOTH

Allows an app to connect to paired bluetooth devices.

Bluetooth (Admin)

android.permission.BLUETOOTH_ADMIN

Allows an app to discover and pair bluetooth devices.

Camera

android.permission.CAMERA

Allows an app to use the Camera.

Flashlight

android.permission.FLASHLIGHT

Allows access to the flashlight.

Internet

android.permission.INTERNET

Allows an app to use Internet connection.

Modify Audio Setting

android.permission.MODIFY_AUDIO_SETTINGS

Allows an app to change global audio settings.

Read Phone State

android.permission.READ_PHONE_STATE

Allows read-only access to the phone state.

Receive SMS

android.permission.RECEIVE_SMS

Allows an app to intercept SMS messages.

Record Audio

android.permission.RECORD_AUDIO

Allows an app to record audio.

Read Contacts

android.permission.READ_CONTACTS

Allows an app to read the contacts.

Vibrate

android.permission.VIBRATE

Allows an app to use the Vibrator.

Write Contacts

android.permission.WRITE_CONTACTS

Allows an app the write access to the contacts.

Write External Storage

android.permission.WRITE_EXTERNAL_STORAGE

Allows an app the write access to External Storage.

Example

Permissions for Camera

<uses-permission android:name="android.permission.CAMERA"></uses-permission>

<uses-feature>

Declares hardware or software features used by the application. For instance. If the application requires Camera feature, the user whose device has no camera cannot install the application. This element is contained in <manifest>.

Attribute

Type

Description

android:name

String

Feature name

android:required

Boolean

Specifies whether the application requires the feature set in android:name. If you set the value to true, you are indicating that the application cannot function without the feature. If you set it to false, it means that the application prefers to use the feature, but can still function without the feature.

Example

The code below specifies that the application needs Camera feature.

<uses-feature android:name="android.hardware.camera" android:required="true" />

<application>

Is an Application tag. This element is contained in <manifest>.

<application android:icon="@drawable/icon"
             android:label="%%%APPLICATION_NAME%%%"
             android:name="mobi.monaca.framework.MonacaApplication">
</application>

Attribute

Type

Description

android:name

String

Defines a name of the application. It is a fully qualified name of the class that you extend from Application class.

android:icon

String

An icon for the entire application as well as a default icon for each of the application's components

android:label

String

A label for the entire application

android:theme

String

An Application level theme

android:screenOrientation

String

Application level Orientation settings

<intent-filter>

Defines the process of intent filter. This element is contained in <activity>. The child <action> element must be defined.

<intent-filter>
    <action android:name="android.intent.action.MAIN" />
    <category android:name="android.intent.category.LAUNCHER" />
</intent-filter>

<action>

Specifies an action for an intent filter. The element is contained in <intent-filter>.

Attribute

Type

Description

android:name

String

Action name

<category>

Specifies the category of the intent filter. The element is contained in <intent-filter>.

Attribute

Type

Description

android:name

String

Category name

Android Configuration Page