Économiseur de batterie de routine

Android 10 introduit une option de planification de l'économiseur de batterie appelée En fonction de la routine. Cette option permet à une application choisie par l'OEM de fournir des signaux au système pour une planification plus intelligente de l'économiseur de batterie. Cette option nécessite une configuration et est facultative.

Configuration de l'appareil

Spécification du fournisseur

Pour informer l'UI des paramètres que l'appareil est correctement configuré, utilisez votre superposition de configuration pour remplacer la valeur config_batterySaverScheduleProvider par le nom de package de votre application.

Par exemple, si vous souhaitez que le package d'application com.google.android.apps.turbo contrôle le paramètre based on routine (En fonction de la routine), vous devez définir cette valeur de configuration:

<string name="config_batterySaverScheduleProvider" translatable="false">
com.google.android.apps.turbo</string>

L'option En fonction de la routine devrait maintenant s'afficher sur le téléphone. Pour vérifier, créez votre image, flashez-la sur un téléphone, puis accédez à Settings > Battery > Battery Saver > Battery Saver Schedule (Paramètres > Batterie > Économiseur de batterie > Calendrier de l'économiseur de batterie). L'option En fonction d'une routine devrait s'afficher.

Seuil de désactivation par défaut

Le nouveau champ config_dynamicPowerSavingsDefaultDisableThreshold spécifie un niveau de batterie à partir duquel le système désactive l'économiseur de batterie, s'il a été activé par le planificateur basé sur la routine. La valeur par défaut du système est de 80%, mais vous pouvez la modifier.

Configuration de l'application

Autorisations

Les API nécessaires pour que l'application active le mode économie de batterie sont protégées par l'autorisation android.permission.POWER_SAVER. Il s'agit d'une autorisation de signature/privilège. Accordez donc cette autorisation à l'application que vous souhaitez pouvoir déclencher dans votre privapp-whitelist.

Exemple d'octroi de l'autorisation privapp à une application:

<privapp-permissions package="com.google.android.apps.turbo">
   <permission name="android.permission.POWER_SAVER"/>
</privapp-permissions>

Si vous ne préaccordez pas cette autorisation à la version de l'application sur l'image système, l'application ne peut pas l'acquérir ni appeler correctement les API. Le système ne fournit aucun commentaire au-delà des erreurs d'autorisation habituelles. Vérifiez donc que vous pouvez appeler les API et observez leurs effets.

Installation

Pour que basé sur la routine fonctionne correctement, vous devez préinstaller l'application sur l'image système avec l'autorisation requise. N'attribuez l'autorisation POWER_SAVER qu'à une seule application et autorisez-la à contrôler les API basées sur la routine. Le comportement de la fonctionnalité lorsque plusieurs applications tentent d'utiliser l'autorisation et les API n'est pas pris en charge et n'est pas spécifié.

Déclencher l'économiseur de batterie

API

En supposant que la configuration ait bien été effectuée jusqu'à présent, l'application OEM spécifiée dans la configuration devrait pouvoir appeler la méthode associée dans PowerManager pour déclencher le mode économie de batterie:

public boolean setDynamicPowerSaveHint(boolean powerSaveHint, int disableThreshold)

Si l'option de planification de l'économiseur de batterie basée sur la routine est activée et que l'application appelle cette méthode avec une valeur true pour powerSaveHint, l'économiseur de batterie s'active. Spécifiez disableThreshold pour que, si l'application ne peut pas communiquer avec le système, le système sache toujours à quel pourcentage de batterie il est possible de désactiver l'économiseur de batterie.

Cette API est soumise aux forçages utilisateur et à la mise en veille de l'économiseur de batterie de la même manière que l'économiseur de batterie automatique basé sur un pourcentage. Pour en savoir plus, consultez la documentation de l'API.

Pour vérifier que les API sont appelées correctement, interrogez les paramètres globaux pour vérifier que le paramètre de sauvegarde a changé de valeur selon les appels d'API.

Par exemple, si l'utilisateur a sélectionné le mode Économiseur de batterie de routine et que l'application appelle setDynamicPowerSaveHint(true, 10), les paramètres globaux doivent avoir les valeurs suivantes:

automatic_power_save_mode: 1
dynamic_power_savings_disable_threshold: 10
dynamic_power_savings_enabled: 1

Si vous appelez ensuite setDynamicPowerSaveHint(false, 25), les valeurs doivent être les suivantes:

automatic_power_save_mode: 1
dynamic_power_savings_disable_threshold: 25
dynamic_power_savings_enabled: 0

Vous pouvez vérifier ces valeurs à l'aide de la commande adb suivante:

adb shell settings get global <setting-name>

Validation

Il n'existe aucun moyen automatisé de vérifier cette fonctionnalité, car il est impossible de savoir quel comportement un OEM utilisera pour décider quand déclencher le mode Économiseur d'énergie de routine. Les OEM sont donc tenus de tester leur intégration pour s'assurer que le comportement répond aux attentes. Vérifiez en particulier que l'appareil peut effectuer les tâches suivantes:

  • L'utilisateur sélectionne En fonction d'un pourcentage dans l'interface utilisateur de la planification de l'économiseur de batterie et sélectionne 15%. L'économiseur de batterie ne doit s'activer automatiquement que lorsque la batterie est à 15 %.
  • L'utilisateur sélectionne En fonction de la routine dans l'interface utilisateur de la planification de l'économiseur de batterie. Lorsque l'application appelle l'API avec true, l'économiseur de batterie s'active. De plus, l'économiseur de batterie se désactive automatiquement si l'appareil est chargé au niveau de seuil indiqué et débranché.
  • L'utilisateur sélectionne Aucun dans l'interface utilisateur de la programmation de l'économiseur de batterie. L'économiseur de batterie ne doit JAMAIS s'activer automatiquement.
  • Si l'application active le mode économie de batterie et que l'utilisateur le désactive manuellement (à l'aide des paramètres rapides, des paramètres, etc.), il doit rester désactivé jusqu'à ce que l'utilisateur le réactive manuellement ou branche l'appareil.