On large screen and foldable devices running Android 12 or newer, your application can run simultaneously with other applications in multi-window mode, irrespective of its default configuration. If your application is designed for a specific orientation or aspect ratioThe relationship of an image’s proportional dimensions, such as its width and height.
See in Glossary, or is non-resizable, the Android OS automatically switches it into compatibility mode. In this mode, the Android OS scales your application to fit the available screen size. However, in some cases, the application might not be optimized for a specific screen size, resulting in a suboptimal user experience.
Note: For devices running Android 12 or newer versions, multi-window mode is the default behavior.
To ensure consistent user experience, consider designing your application to adapt to various screen sizes, including large screen and foldable devices. You can use the following settings and APIs.
The Resizeable Activity Player setting enables multi-window mode in your application and allows the Android OS to consider it resizable. For new projects, Unity enables this setting by default and sets android.resizeableActivity="true"
in the Android manifest file. In this case, the aspect ratio restrictions are ignored.
If you choose to set android.resizeableActivity="false"
, the Android OS behaves in the following way:
Android OS version | Behavior |
---|---|
Older than Android 12 | Displays your application as full-screen and disables multi-window mode. |
Android 12 and newer | Enables multi-window mode by default and activates the compatibility mode for your application to adjust it to the available screen dimensions. |
In the compatibility mode, the application might not display as expected. In scenarios such as transitioning between screens on large screens and foldable devices, the OS might prompt the user to restart the application. Restarting the application causes loss of activity and the overall application state.
Note: On small-screen devices running Android 12 or newer versions, a resizable application supports multi-window mode based on the minimum width and minimum height of the activity. A non-resizable application doesn’t support multi-window mode on small-screen devices.
The AndroidApplication API provides information on your Android application while it runs on a device. You can use this API to perform the following actions:
Using the AndroidApplication.onConfigurationChanged method, you can detect any device configuration changes. You can retrieve device information, such as screen layout, screen size, and orientation. The method also retrieves additional configuration details, such as whether the screen is folded or unfolded, the type of keyboard in use, and user preferences for language and region. For more information on which device properties you can retrieve, refer to AndroidConfiguration API. Use the AndroidApplication.onConfigurationChanged method to make necessary adjustments, such as rearranging the user interface, to ensure your application adapts seamlessly to different device configurations.
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.