Skip to content

Most visited

Recently visited



In this document

  1. API additions
  2. Behavior Changes

Android Things makes developing connected embedded devices easy by providing the same Android development tools, best-in-class Android framework, and Google APIs that make developers successful on mobile.


Apps for embedded devices bring developers closer to hardware peripherals and drivers than phones and tablets. In addition, embedded devices typically present a single app experience to users. This document goes over the major additions, omissions, and differences between core Android development and Android Things.

Android Things extends the core Android framework with additional APIs provided by the Things Support Library. These APIs allow apps to integrate with new types of hardware not found on mobile devices.

The Android Things platform is also streamlined for single application use. System apps are not present, and your app is launched automatically on startup to immerse your users in the app experience.

API additions

Bluetooth API

The Bluetooth API enables access to the pairing and connection process for remote devices, and the configuration of Bluetooth system settings.

Device Updates API

The Device Updates API allows an application to control and monitor applying over the air (OTA) software updates to the device.


The Low-Power Wireless Personal Area Networks (LoWPAN) APIs enable apps to interact with local devices connected over a wireless personal area network.


The Native Development Kit (NDK) APIs enable you to write applications using C/C++, or integrate existing C/C++ code with an Android Things app.

Peripheral I/O API

The Peripheral I/O APIs let your apps communicate with sensors and actuators using industry standard protocols and interfaces. The following interfaces are supported: GPIO, PWM, I2C, SPI, UART.

User Driver API

User drivers extend existing Android framework services and allow apps to inject hardware events into the framework that other apps can access using the standard Android APIs.

Settings API

Android Things uses three different settings APIs to control settings for the screen (display), system time, and available locales.

Behavior Changes

Core application packages

Android Things doesn't include the standard suite of system apps and content providers. Avoid using common intents as well as the following content provider APIs in your apps:


Displays are optional

Android Things supports graphical user interfaces using the same UI toolkit available to traditional Android applications. In graphical mode, the application window occupies the full real estate of the display. Android Things does not include the system status bar or navigation buttons, giving applications full control over the visual user experience.

However, Android Things does not require a display. On devices where a graphical display is not present, activities are still a primary component of your Android Things app. This is because the framework delivers all input events to the foreground activity, which has focus. Your app cannot receive key events or motion events through any other application component, such as a service.

Home activity support

Android Things expects one application to expose a "home activity" in its manifest as the main entry point for the system to automatically launch on boot. This activity must contain an intent filter that includes both CATEGORY_DEFAULT and IOT_LAUNCHER.

For ease of development, this same activity should include a CATEGORY_LAUNCHER intent filter so Android Studio can launch it as the default activity when deploying or debugging.

    <activity android:name=".HomeActivity">
        <!-- Launch activity as default from Android Studio -->
            <action android:name="android.intent.action.MAIN"/>
            <category android:name="android.intent.category.LAUNCHER"/>

        <!-- Launch activity automatically on boot -->
            <action android:name="android.intent.action.MAIN"/>
            <category android:name="android.intent.category.IOT_LAUNCHER"/>
            <category android:name="android.intent.category.DEFAULT"/>

Support for Google services

Android Things supports a subset of the Google APIs for Android. The following table breaks down API support in Android Things:

Supported APIs Unavailable APIs
Google Analytics for Firebase
Firebase Authentication1
Firebase Cloud Messaging (FCM)
Firebase Crash Reporting
Firebase Realtime Database
Firebase Remote Config
Firebase Storage
Instance ID
Nearby Connections
Nearby Messages2
Mobile Vision
Android Pay
Firebase App Indexing
Firebase Dynamic Links
Firebase Invites
Firebase Notifications
Play Games

1. Does not include the open source FirebaseUI Auth component.
2. Does not include modes which require the user content dialog.

Each release of Android Things bundles the latest stable version of Google Play Services, and requires at least version 11.0.0 of the client SDK. Android Things does not include the Google Play Store, which is responsible for automatically updating Play Services on the device. Because the Play Services version on the device is static, apps cannot target a client SDK greater than the version bundled with the target release.


Declare permissions that you need in your app's manifest file. Normal permissions are granted at install time. Dangerous permissions are granted on the next device reboot and do not require run time checks. This applies to new app installs and updated <uses-permission> elements in existing apps.


Since there is no system-wide status bar and window shade in Android Things, notifications are not supported. Avoid calling the NotificationManager APIs in your apps.

This site uses cookies to store your preferences for site-specific language and display options.

Get the latest Android developer news and tips that will help you find success on Google Play.

* Required Fields


Follow Google Developers on WeChat

Browse this site in ?

You requested a page in , but your language preference for this site is .

Would you like to change your language preference and browse this site in ? If you want to change your language preference later, use the language menu at the bottom of each page.

This class requires API level or higher

This doc is hidden because your selected API level for the documentation is . You can change the documentation API level with the selector above the left navigation.

For more information about specifying the API level your app requires, read Supporting Different Platform Versions.

Take a short survey?
Help us improve the Android developer experience. (Dec 2017 Android Platform & Tools Survey)