Added in API level 1

Configuration


class Configuration : Parcelable, Comparable<Configuration!>
kotlin.Any
   ↳ android.content.res.Configuration

This class describes all device configuration information that can impact the resources the application retrieves. This includes both user-specified configuration options (locale list and scaling) as well as device configurations (such as input modes, screen size and screen orientation).

You can acquire this object from Resources, using android.content.res.Resources#getConfiguration. Thus, from an activity, you can get it by chaining the request with android.app.Activity#getResources:

Configuration config = getResources().getConfiguration();

Summary

Constants
static Int

Constant for colorMode: bits that encode the dynamic range of the screen.

static Int

Constant for colorMode: a COLOR_MODE_HDR_MASK value indicating that the screen is not HDR (low/standard dynamic range).

static Int

Constant for colorMode: bits shift to get the screen dynamic range.

static Int

Constant for colorMode: a COLOR_MODE_HDR_MASK value indicating that it is unknown whether or not the screen is HDR.

static Int

Constant for colorMode: a COLOR_MODE_HDR_MASK value indicating that the screen is HDR (dynamic range).

static Int

Constant for colorMode: a value indicating that the color mode is undefined

static Int

Constant for colorMode: bits that encode whether the screen is wide gamut.

static Int

Constant for colorMode: a COLOR_MODE_WIDE_COLOR_GAMUT_MASK value indicating that the screen is not wide gamut.

static Int

Constant for colorMode: a COLOR_MODE_WIDE_COLOR_GAMUT_MASK value indicating that it is unknown whether or not the screen is wide gamut.

static Int

Constant for colorMode: a COLOR_MODE_WIDE_COLOR_GAMUT_MASK value indicating that the screen is wide gamut.

static Int

Default value for densityDpi indicating that no width has been specified.

static Int

An undefined fontWeightAdjustment.

static Int

Constant for grammatical gender: to indicate the terms of address the user preferred in an application is feminine.

static Int

Constant for grammatical gender: to indicate the terms of address the user preferred in an application is masculine.

static Int

Constant for grammatical gender: to indicate the terms of address the user preferred in an application is neuter.

static Int

Constant for grammatical gender: to indicate the user has not specified the terms of address for the application.

static Int

Constant for hardKeyboardHidden, value corresponding to the physical keyboard being exposed.

static Int

Constant for hardKeyboardHidden: a value indicating that no value has been set.

static Int

Constant for hardKeyboardHidden, value corresponding to the physical keyboard being hidden.

static Int

Constant for keyboardHidden, value corresponding to the keysexposed resource qualifier.

static Int

Constant for keyboardHidden: a value indicating that no value has been set.

static Int

Constant for keyboardHidden, value corresponding to the keyshidden resource qualifier.

static Int

Constant for keyboard, value corresponding to the 12key resource qualifier.

static Int

Constant for keyboard, value corresponding to the nokeys resource qualifier.

static Int

Constant for keyboard, value corresponding to the qwerty resource qualifier.

static Int

Constant for keyboard: a value indicating that no value has been set.

static Int

Constant used to to represent MNC (Mobile Network Code) zero.

static Int

Constant for navigationHidden, value corresponding to the navexposed resource qualifier.

static Int

Constant for navigationHidden: a value indicating that no value has been set.

static Int

Constant for navigationHidden, value corresponding to the navhidden resource qualifier.

static Int

Constant for navigation, value corresponding to the dpad resource qualifier.

static Int

Constant for navigation, value corresponding to the nonav resource qualifier.

static Int

Constant for navigation, value corresponding to the trackball resource qualifier.

static Int

Constant for navigation: a value indicating that no value has been set.

static Int

Constant for navigation, value corresponding to the wheel resource qualifier.

static Int

Constant for orientation, value corresponding to the land resource qualifier.

static Int

Constant for orientation, value corresponding to the port resource qualifier.

static Int

static Int

Constant for orientation: a value indicating that no value has been set.

static Int

Constant for screenLayout: a SCREENLAYOUT_LAYOUTDIR_MASK value indicating that a layout dir has been set to LTR.

static Int

Constant for screenLayout: bits that encode the layout direction.

static Int

Constant for screenLayout: a SCREENLAYOUT_LAYOUTDIR_MASK value indicating that a layout dir has been set to RTL.

static Int

Constant for screenLayout: bits shift to get the layout direction.

static Int

Constant for screenLayout: a SCREENLAYOUT_LAYOUTDIR_MASK value indicating that no layout dir has been set.

static Int

Constant for screenLayout: bits that encode the aspect ratio.

static Int

Constant for screenLayout: a SCREENLAYOUT_LONG_MASK value that corresponds to the notlong resource qualifier.

static Int

Constant for screenLayout: a SCREENLAYOUT_LONG_MASK value indicating that no size has been set.

static Int

Constant for screenLayout: a SCREENLAYOUT_LONG_MASK value that corresponds to the long resource qualifier.

static Int

Constant for screenLayout: bits that encode roundness of the screen.

static Int

Constant for screenLayout: a SCREENLAYOUT_ROUND_MASK value indicating that the screen does not have a rounded shape.

static Int

Constant for screenLayout: a SCREENLAYOUT_ROUND_MASK value indicating that it is unknown whether or not the screen has a round shape.

static Int

Constant for screenLayout: a SCREENLAYOUT_ROUND_MASK value indicating that the screen has a rounded shape.

static Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 480x640 dp units, corresponds to the large resource qualifier.

static Int

Constant for screenLayout: bits that encode the size.

static Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 320x470 dp units, corresponds to the normal resource qualifier.

static Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 320x426 dp units, corresponds to the small resource qualifier.

static Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating that no size has been set.

static Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 720x960 dp units, corresponds to the xlarge resource qualifier.

static Int

Constant for screenLayout: a value indicating that screenLayout is undefined

static Int

Default value for screenHeightDp indicating that no width has been specified.

static Int

Default value for screenWidthDp indicating that no width has been specified.

static Int

Default value for smallestScreenWidthDp indicating that no width has been specified.

static Int

Constant for touchscreen, value corresponding to the finger resource qualifier.

static Int

Constant for touchscreen, value corresponding to the notouch resource qualifier.

static Int

static Int

Constant for touchscreen: a value indicating that no value has been set.

static Int

Constant for uiMode: bits that encode the night mode.

static Int

Constant for uiMode: a UI_MODE_NIGHT_MASK value that corresponds to the notnight resource qualifier.

static Int

Constant for uiMode: a UI_MODE_NIGHT_MASK value indicating that no mode type has been set.

static Int

Constant for uiMode: a UI_MODE_NIGHT_MASK value that corresponds to the night resource qualifier.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the appliance resource qualifier.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the car resource qualifier.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the desk resource qualifier.

static Int

Constant for uiMode: bits that encode the mode type.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to no UI mode resource qualifier specified.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the television resource qualifier.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value indicating that no mode type has been set.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the vrheadset resource qualifier.

static Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the watch resource qualifier.

Inherited constants
Public constructors

Construct an invalid Configuration.

Makes a deep copy suitable for modification.

Public methods
Int

Int

Parcelable methods

Int

Return a bit mask of the differences between this Configuration object and the given one.

Boolean

Boolean
equals(other: Any?)

Indicates whether some other object is "equal to" this one.

static Configuration

Generate a delta Configuration between base and change.

Int

Returns the user preference for the grammatical gender.

Int

Return the layout direction.

LocaleList

Get the locale list.

Int

Boolean

Check if the Configuration's current screenLayout is at least the given size.

Boolean

Retuns whether the configuration is in night mode

Boolean

Return whether the screen has a high dynamic range.

Boolean

Return whether the screen has a round shape.

Boolean

Return whether the screen has a wide color gamut and wide color gamut rendering is supported by this device.

static Boolean
needNewResources(configChanges: Int, interestingChanges: Int)

Determines if a new resource needs to be loaded from the bit set of configuration changes returned by updateFrom(android.content.res.Configuration).

Unit

Unit

Set the layout direction from a Locale.

Unit

Set the locale list to a list of just one locale.

Unit

Set the locale list.

Unit

Sets the fields in this object to those in the given Configuration.

Unit

Set this object to the system defaults.

String

Int

Copies the fields from delta into this Configuration object, keeping track of which ones have changed.

Unit
writeToParcel(dest: Parcel, flags: Int)

Properties
static Parcelable.Creator<Configuration!>

Int

Bit mask of color capabilities of the screen.

Int

The target screen density being rendered to, corresponding to density resource qualifier.

Float

Current user preference for the scaling factor for fonts, relative to the base density scaling.

Int

Adjustment in text font weight.

Int

A flag indicating whether the hard keyboard has been hidden.

Int

The kind of keyboard attached to the device.

Int

A flag indicating whether any keyboard is available.

Locale!

Current user preference for the locale, corresponding to locale resource qualifier.

Int

IMSI MCC (Mobile Country Code), corresponding to mcc resource qualifier.

Int

IMSI MNC (Mobile Network Code), corresponding to mnc resource qualifier.

Int

The kind of navigation method available on the device.

Int

A flag indicating whether any 5-way or DPAD navigation available.

Int

Overall orientation of the screen.

Int

The height of the available screen space in dp units.

Int

Bit mask of overall layout of the screen.

Int

The width of the available screen space in dp units.

Int

The smallest screen size an application will see in normal operation.

Int

The kind of touch screen attached to the device.

Int

Bit mask of the ui mode.

Constants

COLOR_MODE_HDR_MASK

Added in API level 26
static val COLOR_MODE_HDR_MASK: Int

Constant for colorMode: bits that encode the dynamic range of the screen.

Value: 12

COLOR_MODE_HDR_NO

Added in API level 26
static val COLOR_MODE_HDR_NO: Int

Constant for colorMode: a COLOR_MODE_HDR_MASK value indicating that the screen is not HDR (low/standard dynamic range).

Corresponds to the -lowdr resource qualifier.

Value: 4

COLOR_MODE_HDR_SHIFT

Added in API level 26
static val COLOR_MODE_HDR_SHIFT: Int

Constant for colorMode: bits shift to get the screen dynamic range.

Value: 2

COLOR_MODE_HDR_UNDEFINED

Added in API level 26
static val COLOR_MODE_HDR_UNDEFINED: Int

Constant for colorMode: a COLOR_MODE_HDR_MASK value indicating that it is unknown whether or not the screen is HDR.

Value: 0

COLOR_MODE_HDR_YES

Added in API level 26
static val COLOR_MODE_HDR_YES: Int

Constant for colorMode: a COLOR_MODE_HDR_MASK value indicating that the screen is HDR (dynamic range).

Corresponds to the -highdr resource qualifier.

Value: 8

COLOR_MODE_UNDEFINED

Added in API level 26
static val COLOR_MODE_UNDEFINED: Int

Constant for colorMode: a value indicating that the color mode is undefined

Value: 0

COLOR_MODE_WIDE_COLOR_GAMUT_MASK

Added in API level 26
static val COLOR_MODE_WIDE_COLOR_GAMUT_MASK: Int

Constant for colorMode: bits that encode whether the screen is wide gamut.

Value: 3

COLOR_MODE_WIDE_COLOR_GAMUT_NO

Added in API level 26
static val COLOR_MODE_WIDE_COLOR_GAMUT_NO: Int

Constant for colorMode: a COLOR_MODE_WIDE_COLOR_GAMUT_MASK value indicating that the screen is not wide gamut.

Corresponds to the -nowidecg resource qualifier.

Value: 1

COLOR_MODE_WIDE_COLOR_GAMUT_UNDEFINED

Added in API level 26
static val COLOR_MODE_WIDE_COLOR_GAMUT_UNDEFINED: Int

Constant for colorMode: a COLOR_MODE_WIDE_COLOR_GAMUT_MASK value indicating that it is unknown whether or not the screen is wide gamut.

Value: 0

COLOR_MODE_WIDE_COLOR_GAMUT_YES

Added in API level 26
static val COLOR_MODE_WIDE_COLOR_GAMUT_YES: Int

Constant for colorMode: a COLOR_MODE_WIDE_COLOR_GAMUT_MASK value indicating that the screen is wide gamut.

Corresponds to the -widecg resource qualifier.

Value: 2

DENSITY_DPI_UNDEFINED

Added in API level 17
static val DENSITY_DPI_UNDEFINED: Int

Default value for densityDpi indicating that no width has been specified.

Value: 0

FONT_WEIGHT_ADJUSTMENT_UNDEFINED

Added in API level 31
static val FONT_WEIGHT_ADJUSTMENT_UNDEFINED: Int

An undefined fontWeightAdjustment.

Value: 2147483647

GRAMMATICAL_GENDER_FEMININE

Added in API level 34
static val GRAMMATICAL_GENDER_FEMININE: Int

Constant for grammatical gender: to indicate the terms of address the user preferred in an application is feminine.

Value: 2

GRAMMATICAL_GENDER_MASCULINE

Added in API level 34
static val GRAMMATICAL_GENDER_MASCULINE: Int

Constant for grammatical gender: to indicate the terms of address the user preferred in an application is masculine.

Value: 3

GRAMMATICAL_GENDER_NEUTRAL

Added in API level 34
static val GRAMMATICAL_GENDER_NEUTRAL: Int

Constant for grammatical gender: to indicate the terms of address the user preferred in an application is neuter.

Value: 1

GRAMMATICAL_GENDER_NOT_SPECIFIED

Added in API level 34
static val GRAMMATICAL_GENDER_NOT_SPECIFIED: Int

Constant for grammatical gender: to indicate the user has not specified the terms of address for the application.

Value: 0

HARDKEYBOARDHIDDEN_NO

Added in API level 3
static val HARDKEYBOARDHIDDEN_NO: Int

Constant for hardKeyboardHidden, value corresponding to the physical keyboard being exposed.

Value: 1

HARDKEYBOARDHIDDEN_UNDEFINED

Added in API level 3
static val HARDKEYBOARDHIDDEN_UNDEFINED: Int

Constant for hardKeyboardHidden: a value indicating that no value has been set.

Value: 0

HARDKEYBOARDHIDDEN_YES

Added in API level 3
static val HARDKEYBOARDHIDDEN_YES: Int

Constant for hardKeyboardHidden, value corresponding to the physical keyboard being hidden.

Value: 2

KEYBOARDHIDDEN_NO

Added in API level 1
static val KEYBOARDHIDDEN_NO: Int

Constant for keyboardHidden, value corresponding to the keysexposed resource qualifier.

Value: 1

KEYBOARDHIDDEN_UNDEFINED

Added in API level 1
static val KEYBOARDHIDDEN_UNDEFINED: Int

Constant for keyboardHidden: a value indicating that no value has been set.

Value: 0

KEYBOARDHIDDEN_YES

Added in API level 1
static val KEYBOARDHIDDEN_YES: Int

Constant for keyboardHidden, value corresponding to the keyshidden resource qualifier.

Value: 2

KEYBOARD_12KEY

Added in API level 1
static val KEYBOARD_12KEY: Int

Constant for keyboard, value corresponding to the 12key resource qualifier.

Value: 3

KEYBOARD_NOKEYS

Added in API level 1
static val KEYBOARD_NOKEYS: Int

Constant for keyboard, value corresponding to the nokeys resource qualifier.

Value: 1

KEYBOARD_QWERTY

Added in API level 1
static val KEYBOARD_QWERTY: Int

Constant for keyboard, value corresponding to the qwerty resource qualifier.

Value: 2

KEYBOARD_UNDEFINED

Added in API level 1
static val KEYBOARD_UNDEFINED: Int

Constant for keyboard: a value indicating that no value has been set.

Value: 0

MNC_ZERO

Added in API level 19
static val MNC_ZERO: Int

Constant used to to represent MNC (Mobile Network Code) zero. 0 cannot be used, since it is used to represent an undefined MNC.

Value: 65535
Added in API level 5
static val NAVIGATIONHIDDEN_NO: Int

Constant for navigationHidden, value corresponding to the navexposed resource qualifier.

Value: 1
Added in API level 5
static val NAVIGATIONHIDDEN_UNDEFINED: Int

Constant for navigationHidden: a value indicating that no value has been set.

Value: 0
Added in API level 5
static val NAVIGATIONHIDDEN_YES: Int

Constant for navigationHidden, value corresponding to the navhidden resource qualifier.

Value: 2
Added in API level 1
static val NAVIGATION_DPAD: Int

Constant for navigation, value corresponding to the dpad resource qualifier.

Value: 2
Added in API level 1
static val NAVIGATION_NONAV: Int

Constant for navigation, value corresponding to the nonav resource qualifier.

Value: 1
Added in API level 1
static val NAVIGATION_TRACKBALL: Int

Constant for navigation, value corresponding to the trackball resource qualifier.

Value: 3
Added in API level 1
static val NAVIGATION_UNDEFINED: Int

Constant for navigation: a value indicating that no value has been set.

Value: 0
Added in API level 1
static val NAVIGATION_WHEEL: Int

Constant for navigation, value corresponding to the wheel resource qualifier.

Value: 4

ORIENTATION_LANDSCAPE

Added in API level 1
static val ORIENTATION_LANDSCAPE: Int

Constant for orientation, value corresponding to the land resource qualifier.

Value: 2

ORIENTATION_PORTRAIT

Added in API level 1
static val ORIENTATION_PORTRAIT: Int

Constant for orientation, value corresponding to the port resource qualifier.

Value: 1

ORIENTATION_SQUARE

Added in API level 1
Deprecated in API level 16
static val ORIENTATION_SQUARE: Int

Deprecated: Not currently supported or used.

Value: 3

ORIENTATION_UNDEFINED

Added in API level 1
static val ORIENTATION_UNDEFINED: Int

Constant for orientation: a value indicating that no value has been set.

Value: 0

SCREENLAYOUT_LAYOUTDIR_LTR

Added in API level 17
static val SCREENLAYOUT_LAYOUTDIR_LTR: Int

Constant for screenLayout: a SCREENLAYOUT_LAYOUTDIR_MASK value indicating that a layout dir has been set to LTR.

Value: 64

SCREENLAYOUT_LAYOUTDIR_MASK

Added in API level 17
static val SCREENLAYOUT_LAYOUTDIR_MASK: Int

Constant for screenLayout: bits that encode the layout direction.

Value: 192

SCREENLAYOUT_LAYOUTDIR_RTL

Added in API level 17
static val SCREENLAYOUT_LAYOUTDIR_RTL: Int

Constant for screenLayout: a SCREENLAYOUT_LAYOUTDIR_MASK value indicating that a layout dir has been set to RTL.

Value: 128

SCREENLAYOUT_LAYOUTDIR_SHIFT

Added in API level 17
static val SCREENLAYOUT_LAYOUTDIR_SHIFT: Int

Constant for screenLayout: bits shift to get the layout direction.

Value: 6

SCREENLAYOUT_LAYOUTDIR_UNDEFINED

Added in API level 17
static val SCREENLAYOUT_LAYOUTDIR_UNDEFINED: Int

Constant for screenLayout: a SCREENLAYOUT_LAYOUTDIR_MASK value indicating that no layout dir has been set.

Value: 0

SCREENLAYOUT_LONG_MASK

Added in API level 4
static val SCREENLAYOUT_LONG_MASK: Int

Constant for screenLayout: bits that encode the aspect ratio.

Value: 48

SCREENLAYOUT_LONG_NO

Added in API level 4
static val SCREENLAYOUT_LONG_NO: Int

Constant for screenLayout: a SCREENLAYOUT_LONG_MASK value that corresponds to the notlong resource qualifier.

Value: 16

SCREENLAYOUT_LONG_UNDEFINED

Added in API level 4
static val SCREENLAYOUT_LONG_UNDEFINED: Int

Constant for screenLayout: a SCREENLAYOUT_LONG_MASK value indicating that no size has been set.

Value: 0

SCREENLAYOUT_LONG_YES

Added in API level 4
static val SCREENLAYOUT_LONG_YES: Int

Constant for screenLayout: a SCREENLAYOUT_LONG_MASK value that corresponds to the long resource qualifier.

Value: 32

SCREENLAYOUT_ROUND_MASK

Added in API level 23
static val SCREENLAYOUT_ROUND_MASK: Int

Constant for screenLayout: bits that encode roundness of the screen.

Value: 768

SCREENLAYOUT_ROUND_NO

Added in API level 23
static val SCREENLAYOUT_ROUND_NO: Int

Constant for screenLayout: a SCREENLAYOUT_ROUND_MASK value indicating that the screen does not have a rounded shape.

Value: 256

SCREENLAYOUT_ROUND_UNDEFINED

Added in API level 23
static val SCREENLAYOUT_ROUND_UNDEFINED: Int

Constant for screenLayout: a SCREENLAYOUT_ROUND_MASK value indicating that it is unknown whether or not the screen has a round shape.

Value: 0

SCREENLAYOUT_ROUND_YES

Added in API level 23
static val SCREENLAYOUT_ROUND_YES: Int

Constant for screenLayout: a SCREENLAYOUT_ROUND_MASK value indicating that the screen has a rounded shape. Corners may not be visible to the user; developers should pay special attention to the android.view.WindowInsets delivered to views for more information about ensuring content is not obscured.

Corresponds to the -round resource qualifier.

Value: 512

SCREENLAYOUT_SIZE_LARGE

Added in API level 4
static val SCREENLAYOUT_SIZE_LARGE: Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 480x640 dp units, corresponds to the large resource qualifier. See Supporting Multiple Screens for more information.

Value: 3

SCREENLAYOUT_SIZE_MASK

Added in API level 4
static val SCREENLAYOUT_SIZE_MASK: Int

Constant for screenLayout: bits that encode the size.

Value: 15

SCREENLAYOUT_SIZE_NORMAL

Added in API level 4
static val SCREENLAYOUT_SIZE_NORMAL: Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 320x470 dp units, corresponds to the normal resource qualifier. See Supporting Multiple Screens for more information.

Value: 2

SCREENLAYOUT_SIZE_SMALL

Added in API level 4
static val SCREENLAYOUT_SIZE_SMALL: Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 320x426 dp units, corresponds to the small resource qualifier. See Supporting Multiple Screens for more information.

Value: 1

SCREENLAYOUT_SIZE_UNDEFINED

Added in API level 4
static val SCREENLAYOUT_SIZE_UNDEFINED: Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating that no size has been set.

Value: 0

SCREENLAYOUT_SIZE_XLARGE

Added in API level 9
static val SCREENLAYOUT_SIZE_XLARGE: Int

Constant for screenLayout: a SCREENLAYOUT_SIZE_MASK value indicating the screen is at least approximately 720x960 dp units, corresponds to the xlarge resource qualifier. See Supporting Multiple Screens for more information.

Value: 4

SCREENLAYOUT_UNDEFINED

Added in API level 17
static val SCREENLAYOUT_UNDEFINED: Int

Constant for screenLayout: a value indicating that screenLayout is undefined

Value: 0

SCREEN_HEIGHT_DP_UNDEFINED

Added in API level 13
static val SCREEN_HEIGHT_DP_UNDEFINED: Int

Default value for screenHeightDp indicating that no width has been specified.

Value: 0

SCREEN_WIDTH_DP_UNDEFINED

Added in API level 13
static val SCREEN_WIDTH_DP_UNDEFINED: Int

Default value for screenWidthDp indicating that no width has been specified.

Value: 0

SMALLEST_SCREEN_WIDTH_DP_UNDEFINED

Added in API level 13
static val SMALLEST_SCREEN_WIDTH_DP_UNDEFINED: Int

Default value for smallestScreenWidthDp indicating that no width has been specified.

Value: 0

TOUCHSCREEN_FINGER

Added in API level 1
static val TOUCHSCREEN_FINGER: Int

Constant for touchscreen, value corresponding to the finger resource qualifier.

Value: 3

TOUCHSCREEN_NOTOUCH

Added in API level 1
static val TOUCHSCREEN_NOTOUCH: Int

Constant for touchscreen, value corresponding to the notouch resource qualifier.

Value: 1

TOUCHSCREEN_STYLUS

Added in API level 1
Deprecated in API level 16
static val TOUCHSCREEN_STYLUS: Int

Deprecated: Not currently supported or used.

Value: 2

TOUCHSCREEN_UNDEFINED

Added in API level 1
static val TOUCHSCREEN_UNDEFINED: Int

Constant for touchscreen: a value indicating that no value has been set.

Value: 0

UI_MODE_NIGHT_MASK

Added in API level 8
static val UI_MODE_NIGHT_MASK: Int

Constant for uiMode: bits that encode the night mode.

Value: 48

UI_MODE_NIGHT_NO

Added in API level 8
static val UI_MODE_NIGHT_NO: Int

Constant for uiMode: a UI_MODE_NIGHT_MASK value that corresponds to the notnight resource qualifier.

Value: 16

UI_MODE_NIGHT_UNDEFINED

Added in API level 8
static val UI_MODE_NIGHT_UNDEFINED: Int

Constant for uiMode: a UI_MODE_NIGHT_MASK value indicating that no mode type has been set.

Value: 0

UI_MODE_NIGHT_YES

Added in API level 8
static val UI_MODE_NIGHT_YES: Int

Constant for uiMode: a UI_MODE_NIGHT_MASK value that corresponds to the night resource qualifier.

Value: 32

UI_MODE_TYPE_APPLIANCE

Added in API level 16
static val UI_MODE_TYPE_APPLIANCE: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the appliance resource qualifier.

Value: 5

UI_MODE_TYPE_CAR

Added in API level 8
static val UI_MODE_TYPE_CAR: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the car resource qualifier.

Value: 3

UI_MODE_TYPE_DESK

Added in API level 8
static val UI_MODE_TYPE_DESK: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the desk resource qualifier.

Value: 2

UI_MODE_TYPE_MASK

Added in API level 8
static val UI_MODE_TYPE_MASK: Int

Constant for uiMode: bits that encode the mode type.

Value: 15

UI_MODE_TYPE_NORMAL

Added in API level 8
static val UI_MODE_TYPE_NORMAL: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to no UI mode resource qualifier specified.

Value: 1

UI_MODE_TYPE_TELEVISION

Added in API level 13
static val UI_MODE_TYPE_TELEVISION: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the television resource qualifier.

Value: 4

UI_MODE_TYPE_UNDEFINED

Added in API level 8
static val UI_MODE_TYPE_UNDEFINED: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value indicating that no mode type has been set.

Value: 0

UI_MODE_TYPE_VR_HEADSET

Added in API level 26
static val UI_MODE_TYPE_VR_HEADSET: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the vrheadset resource qualifier.

Value: 7

UI_MODE_TYPE_WATCH

Added in API level 20
static val UI_MODE_TYPE_WATCH: Int

Constant for uiMode: a UI_MODE_TYPE_MASK value that corresponds to the watch resource qualifier.

Value: 6

Public constructors

Configuration

Added in API level 1
Configuration()

Construct an invalid Configuration. This state is only suitable for constructing a Configuration delta that will be applied to some valid Configuration object. In order to create a valid standalone Configuration, you must call setToDefaults.

Example:

Configuration validConfig = new Configuration();
      validConfig.setToDefaults();
 
      Configuration deltaOnlyConfig = new Configuration();
      deltaOnlyConfig.orientation = Configuration.ORIENTATION_LANDSCAPE;
 
      validConfig.updateFrom(deltaOnlyConfig);
  

Configuration

Added in API level 1
Configuration(o: Configuration!)

Makes a deep copy suitable for modification.

Public methods

compareTo

Added in API level 1
fun compareTo(other: Configuration!): Int
Parameters
o the object to be compared.
Return
Int a negative integer, zero, or a positive integer as this object is less than, equal to, or greater than the specified object.
Exceptions
java.lang.NullPointerException if the specified object is null
java.lang.ClassCastException if the specified object's type prevents it from being compared to this object.

describeContents

Added in API level 1
fun describeContents(): Int

Parcelable methods

Return
Int a bitmask indicating the set of special object types marshaled by this Parcelable object instance. Value is either 0 or android.os.Parcelable#CONTENTS_FILE_DESCRIPTOR

equals

Added in API level 1
fun equals(that: Configuration!): Boolean

equals

Added in API level 1
fun equals(other: Any?): Boolean

Indicates whether some other object is "equal to" this one.

The equals method implements an equivalence relation on non-null object references:

  • It is reflexive: for any non-null reference value x, x.equals(x) should return true.
  • It is symmetric: for any non-null reference values x and y, x.equals(y) should return true if and only if y.equals(x) returns true.
  • It is transitive: for any non-null reference values x, y, and z, if x.equals(y) returns true and y.equals(z) returns true, then x.equals(z) should return true.
  • It is consistent: for any non-null reference values x and y, multiple invocations of x.equals(y) consistently return true or consistently return false, provided no information used in equals comparisons on the objects is modified.
  • For any non-null reference value x, x.equals(null) should return false.

An equivalence relation partitions the elements it operates on into equivalence classes; all the members of an equivalence class are equal to each other. Members of an equivalence class are substitutable for each other, at least for some purposes.

Parameters
obj the reference object with which to compare.
that This value may be null.
Return
Boolean true if this object is the same as the obj argument; false otherwise.

generateDelta

Added in API level 33
static fun generateDelta(
    base: Configuration,
    change: Configuration
): Configuration

Generate a delta Configuration between base and change. The resulting delta can be used with .

Caveat: If the any of the Configuration's members becomes undefined, then updateFrom(android.content.res.Configuration) will treat it as a no-op and not update that member. This is fine for device configurations as no member is ever undefined.
Parameters
base Configuration: This value cannot be null.
change Configuration: This value cannot be null.
Return
Configuration This value cannot be null.

getLayoutDirection

Added in API level 17
fun getLayoutDirection(): Int

Return the layout direction. Will be either View#LAYOUT_DIRECTION_LTR or View#LAYOUT_DIRECTION_RTL.

Return
Int Returns View#LAYOUT_DIRECTION_RTL if the configuration is SCREENLAYOUT_LAYOUTDIR_RTL, otherwise View#LAYOUT_DIRECTION_LTR.

getLocales

Added in API level 24
fun getLocales(): LocaleList

Get the locale list. This is the preferred way for getting the locales (instead of using the direct accessor to locale, which would only provide the primary locale).

Return
LocaleList The locale list. This value cannot be null.

hashCode

Added in API level 1
fun hashCode(): Int
Return
Int a hash code value for this object.

isLayoutSizeAtLeast

Added in API level 11
fun isLayoutSizeAtLeast(size: Int): Boolean

Check if the Configuration's current screenLayout is at least the given size.

Parameters
size Int: The desired size, either SCREENLAYOUT_SIZE_SMALL, SCREENLAYOUT_SIZE_NORMAL, SCREENLAYOUT_SIZE_LARGE, or SCREENLAYOUT_SIZE_XLARGE.
Return
Boolean Returns true if the current screen layout size is at least the given size.

isNightModeActive

Added in API level 30
fun isNightModeActive(): Boolean

Retuns whether the configuration is in night mode

Return
Boolean true if night mode is active and false otherwise

isScreenHdr

Added in API level 26
fun isScreenHdr(): Boolean

Return whether the screen has a high dynamic range.

Return
Boolean true if the screen has a high dynamic range, false otherwise

isScreenRound

Added in API level 23
fun isScreenRound(): Boolean

Return whether the screen has a round shape. Apps may choose to change styling based on this property, such as the alignment or layout of text or informational icons.

Return
Boolean true if the screen is rounded, false otherwise

isScreenWideColorGamut

Added in API level 26
fun isScreenWideColorGamut(): Boolean

Return whether the screen has a wide color gamut and wide color gamut rendering is supported by this device. When true, it implies the screen is colorspace aware but not necessarily color-managed. The final colors may still be changed by the screen depending on user settings.

Return
Boolean true if the screen has a wide color gamut and wide color gamut rendering is supported, false otherwise

needNewResources

Added in API level 1
static fun needNewResources(
    configChanges: Int,
    interestingChanges: Int
): Boolean

Determines if a new resource needs to be loaded from the bit set of configuration changes returned by updateFrom(android.content.res.Configuration).

Parameters
configChanges Int: the mask of changes configurations as returned by updateFrom(android.content.res.Configuration) Value is either 0 or a combination of android.content.pm.ActivityInfo#CONFIG_MCC, android.content.pm.ActivityInfo#CONFIG_MNC, android.content.pm.ActivityInfo#CONFIG_LOCALE, android.content.pm.ActivityInfo#CONFIG_TOUCHSCREEN, android.content.pm.ActivityInfo#CONFIG_KEYBOARD, android.content.pm.ActivityInfo#CONFIG_KEYBOARD_HIDDEN, android.content.pm.ActivityInfo#CONFIG_NAVIGATION, android.content.pm.ActivityInfo#CONFIG_ORIENTATION, android.content.pm.ActivityInfo#CONFIG_SCREEN_LAYOUT, android.content.pm.ActivityInfo#CONFIG_UI_MODE, android.content.pm.ActivityInfo#CONFIG_SCREEN_SIZE, android.content.pm.ActivityInfo#CONFIG_SMALLEST_SCREEN_SIZE, android.content.pm.ActivityInfo#CONFIG_DENSITY, android.content.pm.ActivityInfo#CONFIG_LAYOUT_DIRECTION, android.content.pm.ActivityInfo#CONFIG_COLOR_MODE, android.content.pm.ActivityInfo#CONFIG_FONT_SCALE, and android.content.pm.ActivityInfo#CONFIG_GRAMMATICAL_GENDER
interestingChanges Int: the configuration changes that the resource can handle as given in android.util.TypedValue#changingConfigurations Value is either 0 or a combination of android.content.pm.ActivityInfo#CONFIG_MCC, android.content.pm.ActivityInfo#CONFIG_MNC, android.content.pm.ActivityInfo#CONFIG_LOCALE, android.content.pm.ActivityInfo#CONFIG_TOUCHSCREEN, android.content.pm.ActivityInfo#CONFIG_KEYBOARD, android.content.pm.ActivityInfo#CONFIG_KEYBOARD_HIDDEN, android.content.pm.ActivityInfo#CONFIG_NAVIGATION, android.content.pm.ActivityInfo#CONFIG_ORIENTATION, android.content.pm.ActivityInfo#CONFIG_SCREEN_LAYOUT, android.content.pm.ActivityInfo#CONFIG_UI_MODE, android.content.pm.ActivityInfo#CONFIG_SCREEN_SIZE, android.content.pm.ActivityInfo#CONFIG_SMALLEST_SCREEN_SIZE, android.content.pm.ActivityInfo#CONFIG_DENSITY, android.content.pm.ActivityInfo#CONFIG_LAYOUT_DIRECTION, android.content.pm.ActivityInfo#CONFIG_COLOR_MODE, android.content.pm.ActivityInfo#CONFIG_FONT_SCALE, and android.content.pm.ActivityInfo#CONFIG_GRAMMATICAL_GENDER
Return
Boolean true if the resource needs to be loaded, false otherwise

readFromParcel

Added in API level 8
fun readFromParcel(source: Parcel!): Unit

setLayoutDirection

Added in API level 17
fun setLayoutDirection(loc: Locale!): Unit

Set the layout direction from a Locale.

Parameters
loc Locale!: The Locale. If null will set the layout direction to View#LAYOUT_DIRECTION_LTR. If not null will set it to the layout direction corresponding to the Locale.

setLocale

Added in API level 17
fun setLocale(loc: Locale?): Unit

Set the locale list to a list of just one locale. This will also set the layout direction according to the locale. Note that after this is run, calling .equals() on the input locale and the locale attribute would return true if they are not null, but there is no guarantee that they would be the same object. See also the note about layout direction in setLocales(android.os.LocaleList).

Parameters
loc Locale?: The locale. Can be null.

setLocales

Added in API level 24
fun setLocales(locales: LocaleList?): Unit

Set the locale list. This is the preferred way for setting up the locales (instead of using the direct accessor or setLocale(java.util.Locale)). This will also set the layout direction according to the first locale in the list. Note that the layout direction will always come from the first locale in the locale list, even if the locale is not supported by the resources (the resources may only support another locale further down the list which has a different direction).

Parameters
locales LocaleList?: The locale list. If null, an empty LocaleList will be assigned.

setTo

Added in API level 8
fun setTo(o: Configuration!): Unit

Sets the fields in this object to those in the given Configuration.

Parameters
o Configuration!: The Configuration object used to set the values of this Configuration's fields.

setToDefaults

Added in API level 1
fun setToDefaults(): Unit

Set this object to the system defaults.

toString

Added in API level 1
fun toString(): String
Return
String a string representation of the object.

writeToParcel

Added in API level 1
fun writeToParcel(
    dest: Parcel,
    flags: Int
): Unit
Parameters
dest Parcel: The Parcel in which the object should be written. This value cannot be null.
flags Int: Additional flags about how the object should be written. May be 0 or PARCELABLE_WRITE_RETURN_VALUE. Value is either 0 or a combination of android.os.Parcelable#PARCELABLE_WRITE_RETURN_VALUE, and android.os.Parcelable.PARCELABLE_ELIDE_DUPLICATES

Properties

CREATOR

Added in API level 1
static val CREATOR: Parcelable.Creator<Configuration!>

colorMode

Added in API level 26
var colorMode: Int

Bit mask of color capabilities of the screen. Currently there are two fields:

The COLOR_MODE_WIDE_COLOR_GAMUT_MASK bits define the color gamut of the screen. They may be one of COLOR_MODE_WIDE_COLOR_GAMUT_NO or COLOR_MODE_WIDE_COLOR_GAMUT_YES.

The COLOR_MODE_HDR_MASK defines the dynamic range of the screen. They may be one of COLOR_MODE_HDR_NO or COLOR_MODE_HDR_YES.

See Supporting Multiple Screens for more information.

densityDpi

Added in API level 17
var densityDpi: Int

The target screen density being rendered to, corresponding to density resource qualifier. Set to DENSITY_DPI_UNDEFINED if no density is specified.

fontScale

Added in API level 1
var fontScale: Float

Current user preference for the scaling factor for fonts, relative to the base density scaling.

Note: Please do not use this to hardcode font size equations. The equation for font scaling is now non-linear; this coefficient is no longer used as a direct multiplier to determine font size. It exists for informational purposes only.

Please use android.util.TypedValue#applyDimension(int, float, DisplayMetrics) or android.util.TypedValue#deriveDimension(int, float, DisplayMetrics) to convert between scaled font size dimensions and pixels.

fontWeightAdjustment

Added in API level 31
var fontWeightAdjustment: Int

Adjustment in text font weight. Used to reflect the current user preference for increasing font weight.

If the text font weight is less than the minimum of 1, 1 will be used. If the font weight exceeds the maximum of 1000, 1000 will be used.

hardKeyboardHidden

Added in API level 3
var hardKeyboardHidden: Int

A flag indicating whether the hard keyboard has been hidden. This will be set on a device with a mechanism to hide the keyboard from the user, when that mechanism is closed. One of: HARDKEYBOARDHIDDEN_NO, HARDKEYBOARDHIDDEN_YES.

keyboard

Added in API level 1
var keyboard: Int

The kind of keyboard attached to the device. One of: KEYBOARD_NOKEYS, KEYBOARD_QWERTY, KEYBOARD_12KEY.

keyboardHidden

Added in API level 1
var keyboardHidden: Int

A flag indicating whether any keyboard is available. Unlike hardKeyboardHidden, this also takes into account a soft keyboard, so if the hard keyboard is hidden but there is soft keyboard available, it will be set to NO. Value is one of: KEYBOARDHIDDEN_NO, KEYBOARDHIDDEN_YES.

locale

Added in API level 1
Deprecated in API level 24
var locale: Locale!

Deprecated: Do not set or read this directly. Use getLocales() and setLocales(android.os.LocaleList). If only the primary locale is needed, getLocales().get(0) is now the preferred accessor.

Current user preference for the locale, corresponding to locale resource qualifier.

mcc

Added in API level 1
var mcc: Int

IMSI MCC (Mobile Country Code), corresponding to mcc resource qualifier. 0 if undefined.

mnc

Added in API level 1
var mnc: Int

IMSI MNC (Mobile Network Code), corresponding to mnc resource qualifier. 0 if undefined. Note that the actual MNC may be 0; in order to check for this use the MNC_ZERO symbol.

Added in API level 1
var navigation: Int

The kind of navigation method available on the device. One of: NAVIGATION_NONAV, NAVIGATION_DPAD, NAVIGATION_TRACKBALL, NAVIGATION_WHEEL.

Added in API level 5
var navigationHidden: Int

A flag indicating whether any 5-way or DPAD navigation available. This will be set on a device with a mechanism to hide the navigation controls from the user, when that mechanism is closed. One of: NAVIGATIONHIDDEN_NO, NAVIGATIONHIDDEN_YES.

screenHeightDp

Added in API level 13
var screenHeightDp: Int

The height of the available screen space in dp units. Note: If the app targets android.os.Build.VERSION_CODES#VANILLA_ICE_CREAM or after, the height measurement reflects the window size without excluding insets. Otherwise, the measurement excludes window insets even when the app is displayed edge to edge using Window#setDecorFitsSystemWindows(boolean). Use android.view.WindowMetrics#getBounds() to always obtain the vertical display area available to an app or embedded activity including the area occupied by window insets. A version of the API is also available for use on older platforms through androidx.window.layout.WindowMetrics.

Corresponds to the available height resource qualifier. Defaults to SCREEN_HEIGHT_DP_UNDEFINED if no height is specified.

In multi-window mode, equals the height of the available display area of the app window, not the available display area of the device screen (for example, when apps are displayed one above another in split-screen mode in portrait orientation).

For embedded activities, equals the height of the individual activities, not the height of the app window or the device screen.

In multiple-screen scenarios, the height measurement can span screens. For example, if the app is spanning both screens of a dual-screen device rotated 90 degrees (one screen above the other), screenHeightDp represents the height of both screens excluding the area occupied by window insets. When the app is restricted to a single screen in a multiple-screen environment, screenHeightDp is the height of the screen on which the app is displayed excluding window insets.

If the app targets android.os.Build.VERSION_CODES#VANILLA_ICE_CREAM or after, it is the same as android.view.WindowMetrics, but is expressed rounded to the nearest dp rather than px.

Otherwise, differs from android.view.WindowMetrics by not including window insets in the height measurement and by expressing the measurement in dp rather than px. Use screenHeightDp to obtain the height of the display area available to an app or embedded activity excluding the area occupied by window insets.

screenLayout

Added in API level 4
var screenLayout: Int

Bit mask of overall layout of the screen. Currently there are four fields:

The SCREENLAYOUT_SIZE_MASK bits define the overall size of the screen. They may be one of SCREENLAYOUT_SIZE_SMALL, SCREENLAYOUT_SIZE_NORMAL, SCREENLAYOUT_SIZE_LARGE, or SCREENLAYOUT_SIZE_XLARGE.

The SCREENLAYOUT_LONG_MASK defines whether the screen is wider/taller than normal. They may be one of SCREENLAYOUT_LONG_NO or SCREENLAYOUT_LONG_YES.

The SCREENLAYOUT_LAYOUTDIR_MASK defines whether the screen layout is either LTR or RTL. They may be one of SCREENLAYOUT_LAYOUTDIR_LTR or SCREENLAYOUT_LAYOUTDIR_RTL.

The SCREENLAYOUT_ROUND_MASK defines whether the screen has a rounded shape. They may be one of SCREENLAYOUT_ROUND_NO or SCREENLAYOUT_ROUND_YES.

See Supporting Multiple Screens for more information.

screenWidthDp

Added in API level 13
var screenWidthDp: Int

The width of the available screen space in dp units. Note: If the app targets android.os.Build.VERSION_CODES#VANILLA_ICE_CREAM or after, the width measurement reflects the window size without excluding insets. Otherwise, the measurement excludes window insets even when the app is displayed edge to edge using Window#setDecorFitsSystemWindows(boolean). Use android.view.WindowMetrics#getBounds() to always obtain the horizontal display area available to an app or embedded activity including the area occupied by window insets. A version of the API is also available for use on older platforms through androidx.window.layout.WindowMetrics.

Corresponds to the available width resource qualifier. Defaults to SCREEN_WIDTH_DP_UNDEFINED if no width is specified.

In multi-window mode, equals the width of the available display area of the app window, not the available display area of the device screen (for example, when apps are displayed side by side in split-screen mode in landscape orientation).

For embedded activities, equals the width of the individual activities, not the width of the app window or the device screen.

In multiple-screen scenarios, the width measurement can span screens. For example, if the app is spanning both screens of a dual-screen device (with the screens side by side), screenWidthDp represents the width of both screens excluding the area occupied by window insets. When the app is restricted to a single screen in a multiple-screen environment, screenWidthDp is the width of the screen on which the app is displayed excluding window insets.

If the app targets android.os.Build.VERSION_CODES#VANILLA_ICE_CREAM or after, it is the same as android.view.WindowMetrics, but is expressed rounded to the nearest dp rather than px.

Otherwise, differs from android.view.WindowMetrics by not including window insets in the width measurement and by expressing the measurement in dp rather than px. Use screenWidthDp to obtain the width of the display area available to an app or embedded activity excluding the area occupied by window insets.

smallestScreenWidthDp

Added in API level 13
var smallestScreenWidthDp: Int

The smallest screen size an application will see in normal operation. Corresponds to the smallest width resource qualifier. This is the smallest value of screenWidthDp and screenHeightDp in both portrait and landscape orientations. Defaults to SMALLEST_SCREEN_WIDTH_DP_UNDEFINED if no width is specified.

touchscreen

Added in API level 1
var touchscreen: Int

The kind of touch screen attached to the device. One of: TOUCHSCREEN_NOTOUCH, TOUCHSCREEN_FINGER.

uiMode

Added in API level 8
var uiMode: Int

Bit mask of the ui mode. Currently there are two fields:

The UI_MODE_TYPE_MASK bits define the overall ui mode of the device. They may be one of UI_MODE_TYPE_UNDEFINED, UI_MODE_TYPE_NORMAL, UI_MODE_TYPE_DESK, UI_MODE_TYPE_CAR, UI_MODE_TYPE_TELEVISION, UI_MODE_TYPE_APPLIANCE, UI_MODE_TYPE_WATCH, or UI_MODE_TYPE_VR_HEADSET.

The UI_MODE_NIGHT_MASK defines whether the screen is in a special mode. They may be one of UI_MODE_NIGHT_UNDEFINED, UI_MODE_NIGHT_NO or UI_MODE_NIGHT_YES.