Afficher des images Ultra HDR

Le format d'image Ultra HDR permet aux images de stocker plus d'informations sur l'intensité de la lumière, ce qui donne des zones claires et sombres plus détaillées, ainsi que des couleurs plus intenses. Android est compatible avec les images Ultra HDR à partir d'Android 14 (niveau d'API 34). Si votre application s'exécute sur ces versions, il est important de la configurer pour qu'elle affiche correctement ces images. En revanche, si votre application n'affiche pas d'images Ultra HDR, vous pouvez économiser des ressources de l'appareil en désactivant l'affichage Ultra HDR. Cette page explique comment vérifier si les graphiques sont compatibles avec Ultra HDR et comment les afficher correctement.

Vérifier la présence d'une carte de gain

Les images Ultra HDR contiennent une carte de gain. La carte de gain permet de déterminer l'augmentation de la luminosité de chaque pixel de l'image. Pour vérifier si une image est au format Ultra HDR, convertissez l'image ou le drawable en Bitmap, puis appelez Bitmap.hasGainMap() (disponible depuis Android 14) pour vérifier si elle dispose d'une carte de gain.

Configurer votre fenêtre pour afficher Ultra HDR

Pour afficher des images Ultra HDR avec la plage dynamique complète, définissez le mode de couleur de la fenêtre sur ActivityInfo.COLOR_MODE_HDR. Pour ce faire, appelez la méthode setColorMode() de la fenêtre. (Ces API sont disponibles à partir d'Android 8. Toutefois, les images ne sont pas affichées en Ultra HDR, sauf si l'appareil est équipé d'Android 14 ou version ultérieure.)

Synthèse

Le code suivant montre l'ensemble du processus. Ce code suppose qu'une image est chargée dans un bitmap et vérifie si l'image possède une carte de gain. Si tel est le cas, le code définit le mode de couleur de la fenêtre sur COLOR_MODE_HDR. Si l'image ne comporte pas de carte de gain, le code bascule la fenêtre sur le mode de couleur par défaut.

Kotlin

val bitmap = /* Get Bitmap from Image Resource */
binding.imageContainer.setImageBitmap(bitmap)

// Set color mode of the activity to the correct color mode.
requireActivity().window.colorMode =
   if (bitmap.hasGainmap()) ActivityInfo.COLOR_MODE_HDR else ActivityInfo.COLOR_MODE_DEFAULT

Java

final Bitmap bitmap = /* Get Bitmap from Image Resource */
binding.imageContainer.setImageBitmap(bitmap);

// Set color mode of the activity to the correct color mode.
int colorMode = ActivityInfo.COLOR_MODE_DEFAULT;
if (bitmap.hasGainmap()) colorMode = ActivityInfo.COLOR_MODE_HDR;
requireActivity().getWindow().setColorMode(colorMode);

Ressources supplémentaires

Pour en savoir plus sur les images Ultra HDR, consultez les ressources supplémentaires suivantes: