UserStyleSetting


public sealed class UserStyleSetting

Known direct subclasses
UserStyleSetting.BooleanUserStyleSetting

A BooleanUserStyleSetting represents a setting with a true and a false setting.

UserStyleSetting.ColorUserStyleSetting

A ColorUserStyleSetting allows the user to select colour(s) from a list of predefined choices.

UserStyleSetting.ComplicationSlotsUserStyleSetting

ComplicationSlotsUserStyleSetting is the recommended UserStyleSetting for representing complication slot configuration, options such as the number of active complication slots, their location, etc...

UserStyleSetting.CustomValueUserStyleSetting

An application specific style setting.

UserStyleSetting.DoubleRangeUserStyleSetting

A DoubleRangeUserStyleSetting represents a setting with a Double value in the range [minimumValue .. maximumValue].

UserStyleSetting.LargeCustomValueUserStyleSetting

An application specific style setting which supports a larger maximum size than CustomValueUserStyleSetting.

UserStyleSetting.ListUserStyleSetting

A ListUserStyleSetting represents a setting with options selected from a List.

UserStyleSetting.LongRangeUserStyleSetting

A LongRangeUserStyleSetting represents a setting with a Long value in the range minimumValue .. maximumValue.


Watch faces often have user configurable styles, the definition of what is a style is left up to the watch face but it typically incorporates a variety of settings such as: color, visual theme for watch hands, font, tick shape, complication slots, audio elements, etc...

A UserStyleSetting represents one of these dimensions. See also UserStyleSchema which defines the list of UserStyleSettings provided by the watch face.

Styling data gets shared with the companion phone to support editors (typically over bluetooth), as a result the size of serialized UserStyleSettings could become an issue if large.

It is possible to define a hierarchy of styles, (e.g. a watch face might have support a number of different looks, each with their own settings). A hierarchy is defined by setting child styles in ListUserStyleSetting.ListOption.childSettings. A setting is deemed to be active if it's either in the top level of the tree, or if it's the child of an Option selected by the user in the UserStyle. In a hierarchy multiple ComplicationSlotsUserStyleSetting are allowed but only one can be active at any time, for more details see UserStyleSchema.findComplicationSlotsOptionForUserStyle.

Summary

Nested types

A BooleanUserStyleSetting represents a setting with a true and a false setting.

Represents a true or false option in the BooleanUserStyleSetting.

A Builder for BooleanUserStyleSetting.

A ColorUserStyleSetting allows the user to select colour(s) from a list of predefined choices.

A Builder for ColorUserStyleSetting.

Represents choice within a ColorUserStyleSetting, these must be enumerated up front.

A Builder for ColorOption.

ComplicationSlotsUserStyleSetting is the recommended UserStyleSetting for representing complication slot configuration, options such as the number of active complication slots, their location, etc...

A Builder for ComplicationSlotsUserStyleSetting.

Overrides to be applied to the corresponding androidx.wear.watchface.ComplicationSlot's initial config (as specified in it's constructor) when the setting is selected.

Constructs a ComplicationSlotOverlay.Builder.

Represents an override to the initial androidx.wear.watchface.ComplicationSlotsManager configuration.

A Builder for ComplicationSlotsOption.

An application specific style setting.

An application specific custom value.

A DoubleRangeUserStyleSetting represents a setting with a Double value in the range [minimumValue .. maximumValue].

A Builder for DoubleRangeUserStyleSetting.

Represents an option as a Double in the range minimumValue .. maximumValue.

public final class UserStyleSetting.Id

Machine readable identifier for UserStyleSettings.

An application specific style setting which supports a larger maximum size than CustomValueUserStyleSetting.

An application specific custom value.

A ListUserStyleSetting represents a setting with options selected from a List.

A Builder for ListUserStyleSetting.

Represents choice within a ListUserStyleSetting, these must be enumerated up front.

A Builder for ListOption.

A LongRangeUserStyleSetting represents a setting with a Long value in the range minimumValue .. maximumValue.

A builder for LongRangeUserStyleSetting.

Represents an option a Long in the range minimumValue .. maximumValue.

public abstract class UserStyleSetting.Option

Represents a choice within a style setting which can either be an option from the list or a an arbitrary value depending on the nature of the style setting.

public final class UserStyleSetting.Option.Id

Machine readable identifier for Options.

Optional data for an on watch face editor (not the companion editor).

Public methods

boolean
equals(Object other)
final @NonNull Collection<@NonNull WatchFaceLayer>

Used by the style configuration UI.

final @NonNull UserStyleSetting.Option

Returns the default for when the user hasn't selected an option.

final int

The default option index, used if nothing has been selected within the options list.

final @NonNull CharSequence

Localized description string displayed under the displayName.

final @NonNull CharSequence

Localized human readable name for the element, used in the userStyle selection UI.

final Icon

Icon for use in the companion editor style selection UI.

final @NonNull UserStyleSetting.Id

Identifier for the element, must be unique.

@NonNull UserStyleSetting.Option

Translates an option name into an option.

final @NonNull List<@NonNull UserStyleSetting.Option>

List of options for this UserStyleSetting.

final UserStyleSetting.WatchFaceEditorData

Optional data for an on watch face editor, this will not be sent to the companion and its contents may be used in preference to other fields by an on watch face editor.

int
@NonNull String

Public methods

equals

public boolean equals(Object other)

getAffectedWatchFaceLayers

Added in 1.0.0
public final @NonNull Collection<@NonNull WatchFaceLayergetAffectedWatchFaceLayers()

Used by the style configuration UI. Describes which rendering layers this style affects.

getDefaultOption

Added in 1.0.0
public final @NonNull UserStyleSetting.Option getDefaultOption()

Returns the default for when the user hasn't selected an option.

getDefaultOptionIndex

Added in 1.0.0
public final int getDefaultOptionIndex()

The default option index, used if nothing has been selected within the options list.

getDescription

Added in 1.0.0
public final @NonNull CharSequence getDescription()

Localized description string displayed under the displayName.

getDisplayName

Added in 1.0.0
public final @NonNull CharSequence getDisplayName()

Localized human readable name for the element, used in the userStyle selection UI.

getIcon

Added in 1.0.0
public final Icon getIcon()

Icon for use in the companion editor style selection UI.

getId

Added in 1.0.0
public final @NonNull UserStyleSetting.Id getId()

Identifier for the element, must be unique. Styling data gets shared with the companion (typically via bluetooth) so size is a consideration and short ids are encouraged. There is a maximum length see UserStyleSetting.Id.MAX_LENGTH.

getOptionForId

Added in 1.0.0
public @NonNull UserStyleSetting.Option getOptionForId(@NonNull UserStyleSetting.Option.Id optionId)

Translates an option name into an option. This will need to be overridden for userStyle categories that can't sensibly be fully enumerated (e.g. a full 24-bit color picker).

Parameters
@NonNull UserStyleSetting.Option.Id optionId

The Option.Id of the option

Returns
@NonNull UserStyleSetting.Option

An Option corresponding to the name. This could either be one of the options from UserStyleSettings or a newly constructed Option depending on the nature of the UserStyleSetting. If optionName is unrecognized then the default value for the setting should be returned.

getOptions

Added in 1.0.0
public final @NonNull List<@NonNull UserStyleSetting.OptiongetOptions()

List of options for this UserStyleSetting. Depending on the type of UserStyleSetting this may be an exhaustive list, or just examples to populate a ListView in case the UserStyleSetting isn't supported by the UI (e.g. a new WatchFace with an old companion).

getWatchFaceEditorData

Added in 1.1.0
public final UserStyleSetting.WatchFaceEditorData getWatchFaceEditorData()

Optional data for an on watch face editor, this will not be sent to the companion and its contents may be used in preference to other fields by an on watch face editor.

hashCode

public int hashCode()

toString

public @NonNull String toString()