## Overview
npm install @amazon-devices/kepler-graphicsThe Kepler Graphics Turbo Module API provides functionality for applications to query the display capabilities such as screen resolution, refresh rate, color depth/format, and HDR support for the connected display from the platform. The API also considers the device's support and returns the capabilities according to the device's limitations. This Turbo Module internally uses the display APIs from the Kepler Graphics Interface (IDL interface). Most of the APIs are 1:1 mapped against the IDL interfaces.
The display APIs consists of both get methods and set methods. Applications that are using the set methods via DisplayManager class requires
the security privilege com.amazon.graphics.privilege.display.manager in their Application's manifest.toml file under "[needs]" section as shown below.
```
[[needs.privilege]]
id = "com.amazon.graphics.privilege.display.manager"
Please note the get methods do not require any privilege.
Kepler Applications can consume this package through the Kepler SDK.
For instructions on how to install the Kepler SDK, see Kepler SDK Setup.
The Kepler Graphics Turbo Module is provided by the kepler-graphics npm package. This npm package must be added to the application's package.json as dependency.
``
"dependencies": {
...
"@amazon-devices/kepler-graphics": "^2.3.0",
}
The interfaces and types should be imported from the kepler-graphics package
in a source code file as shown below:
``
import {
Display,
DisplayManager,
DisplayController,
ColorDepth,
ColorSpace,
HdcpLevel,
HdrType,
LlmState,
HdrMode,
IDisplayConfig,
IDisplayListener,
IDisplayControllerListener,
ISubscription
} from '@amazon-devices/kepler-graphics';
Based on the consumed APIs, only the needed types in the above import listing can be retained.
Use this package APIs to query the connected display properties and get hotplug events.
The following is a list of supported use cases:
1. Listening to display hotplug events.
2. Querying supported Screen Resolutions (width x heigh) and Refresh rates of the display.
3. Querying supported HDR types/Transfer Functions, maximum HDCP level, Screen Density (DPI) of the display.
5. Querying currently active Screen Resolution, Refresh Rate, Color Depth, Color Format, HDR Mode, Low Latency Mode (ALLM) for the display.
6. Listening to change events for the above mentioned display properties.
If application gets the system privilege mentioned in the Authentication section above, then the following set of operations are allowed.
7. Changing current Screen Resolution and Refresh Rate to one of the supported values.
8. Changing other display properties like Color Depth, Color Format, HDR Mode and ALLM.
The following sections provide sample code for some of the use cases.
`Display
const displayConnected = DisplayController.isPrimaryDisplayConnected();
if (displayConnected) {
// Perform operations on the display.
} else {
// Display is not connected, Do NOT use the and DisplayManager methods.`
// In this case, the hotplug event callbacks can be used to know
// when a new display is connected.
}
and IDisplayControllerListener.onRemoveDisplay() callback methods provide those events as shown below.`
const displayControllerListener: IDisplayControllerListener = { onAddDisplay: (id: Int32) => {
console.log("IDisplayControllerListener::onAddDisplay - ", id);
// Any initialization when new display is connected.
},
onRemoveDisplay: (id: Int32) => {
console.log("IDisplayControllerListener::onRemoveDisplay - ", id);
// Any cleanup required.
// Please note the
Display and DisplayManager methods do not work
// when the display is disconnected.
},
};// Register the listener callback object to receive events.
const subscription: ISubscription = DisplayController.addListener(displayControllerListener);
`$3
Display.getCurrentConfig() returns the currently active configuration as IDisplayConfig object. The members of the IDisplayConfig object provides the screen resolution (width x height), screen density, supported refresh rates, and more. Below is the sample code.`
// Get currently active display config.
const displayConfig = Display.getCurrentConfig();
// Current width in pixels.
const width = displayConfig.widthInPixels;
// Current height in pixels.
const height = displayConfig.heightInPixels;
// Screen Density in DPI (dots-per-inch).
const dpi = displayConfig.screenDensityInDpi;// Current refresh rate in milli hz (eg: 60000 = 60Hz).
const currentRefreshRate = Display.getCurrentRefreshRateInMillihertz();
`$3
To check if HDR is supported by the display and also by the device, the following example code can be used.
`
// Checks if the display along with device supports any of the HDR formats.
const hdrSupport = Display.isHDRSupported();// Get the current user selected HDR mode - possible values are in 'enum HdrMode'.
const hdrMode = Display.getHdrMode();
if (hdrSupport && (hdrMode !== HdrMode.DISABLED)) {
// HDR is supported.
// Now get the current configuration to check if required HDR format is supported.
const displayConfig = Display.getCurrentConfig();
for (const hdrType of displayConfig.supportedHdrType) {
if (hdrType === HdrType.HDR10) {
// HDR10 supported.
} else if (hdrType === HdrType.HDR10_PLUS) {
// HDR10+ supported.
} else if (hdrType === HdrType.HLG) {
// HLG supported.
} else if (hdrType == HdrType.DOLBY_VISION) {
// Dolby Vision supported.
}
}
} else {
// HDR is not supported or disabled by user.
}
`
NOTE: The supported HDR types shown above is from the current active display configuration (resolution) only. Other display configuration obtained through Display.getAllSupportedConfigs() might list certain HDR types. Those HDR types are usable only when the current active configuration is changed to that particular display configuration through DisplayManager.requestConfigChange() method.$3
`
// Query the display connector name.
const name = Display.getName();// Get current HDCP level - possible values are in 'enum HdcpLevel'.
const hdcpLevel = Display.getCurrentHdcpLevel();
// Get current color depth - possible values are in 'enum ColorDepth'.
const colorDepth = Display.getColorDepth();
// Get current color space - possible values are in 'enum ColorSpace'.
const colorSpace = Display.getColorSpace();
// Check if low latency mode is supported in the device.
llmSupported = Display.isLowLatencyModeSupported();
if (llmSupported) {
// Low Latency Mode is supported in the display.
}
`$3
Applications can listen for changes to the display properties like screen resolution, refresh rate, color depth/space, HDCP level, HDR mode, and Low Latency Mode through the
IDisplayListener callback interface. See the following code example:`
const displayListener: IDisplayListener = { onConfigChange: (config: IDisplayConfig) => {
console.log("IDisplayListener onConfigChange == ", config);
},
onRefreshRateChange: (refreshRateInrMillihertz: Int32) => {
console.log("IDisplayListener onRefreshRateChange == ", refreshRateInrMillihertz);
},
onColorDepthChange: (colorDepth: ColorDepth) => {
Alert.alert("IDisplayListener onConfigChange == ");
console.log("IDisplayListener onColorDepthChange == ", colorDepth);
},
onColorSpaceChange: (colorSpace: ColorSpace) => {
console.log("IDisplayListener onColorSpaceChange == ", colorSpace);
},
onHdcpLevelChange: (level: HdcpLevel) => {
console.log("IDisplayListener onHdcpLevelChange == ", level);
},
onAutoConfigSwitchStateChange: (state: boolean) => {
console.log("IDisplayListener onAutoConfigSwitchStateChange == ", state);
},
onMultipleRefreshRateStateChange: (state: boolean) => {
console.log("IDisplayListener onMultipleRefreshRateStateChange == ", state);
},
onLowLatencyModeStateChange: (state: LlmState) => {
console.log("IDisplayListener onLowLatencyModeStateChange == ", state);
},
onHdrModeChange: (hdr_mode: HdrMode) => {
console.log("IDisplayListener onHdrModeChange == ", hdr_mode);
},
onSinkStateChange: (active: boolean) => {
console.log("IDisplayListener onSinkStateChange == ", active);
}
};
// Register the listener object to receive the callbacks.
const subscription: ISubscription = Display.addDisplayListener(displayListener);
`FAQs
#### Q1: Why display supported HDR type is not listed in the
IDisplayConfig.supportedHdrType array?
In addition to the display properties, the method implementation considers the device capabilities too
for reporting the supported types. If the device does not support certain HDR type, for example "Dolby Vision", then the list reported by IDisplayConfig.supportedHdrType does not contain it.#### Q2: How to unsubscribe for the listener callbacks?
The methods
Display.addDisplayListener() and DisplayController.addListener() returns a ISubscription object.
This object is used to unsubscribe the listener by calling the unsubscribe() method. See the following code example.
`
useEffect(() => {
const subscription: ISubscription = DisplayController.addListener(displayControllerListener);
return () => {
subscription.unsubscribe();
};
}, []);
`#### Q3: Why does
supportedHdrType return multiple duplicated values like
`
{
"heightInPixels": 1080,
"maxHdcpLevel": 7,
"screenDensityInDpi": 81,
"supportedHdrType": [
1,
1,
1,
1,
1
],
"supportedRefreshRatesInMillihertz": [
60000,
50000,
30000,
25000,
24000
],
"widthInPixels": 1920
}
`
HDR types are correlated with refresh rates. In this scenario, there are five different refresh rates, each with its corresponding HDR type support information. For instance, at a refresh rate of 60 millihertz (mHz), the HDR support type is 1, which corresponds to HdrType.NONE`.