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 tons clairs et des ombres plus détaillés, 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 les ressources de l'appareil en ne l'activant pas. Cette page explique comment vérifier si les graphiques sont compatibles avec l'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 est utilisée pour 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 et appelez Bitmap.hasGainMap() (disponible depuis Android 14) pour vérifier s'il comporte une carte de gain.

Configurer votre fenêtre pour afficher l'Ultra HDR

Pour afficher les images Ultra HDR avec toute la gamme dynamique, définissez le mode 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 s'affichent pas en Ultra HDR, sauf si l'appareil est équipé d'Android 14 ou version ultérieure.)

Synthèse

Le code suivant montre à quoi ressemble l'ensemble du processus. Ce code suppose qu'une image est chargée dans un bitmap et vérifie si l'image comporte une carte de gain. Si c'est le cas, le code définit le mode 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 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 :