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 du mode économie de batterie. Cette option nécessite une configuration et est facultative.
Configuration de l'appareil
Spécification du fournisseur
Pour avertir l'interface utilisateur des paramètres que l'appareil est correctement configuré, utilisez votre superposition de configuration pour remplacer la valeur config_batterySaverScheduleProvider
par le nom du package de votre application.
Par exemple, si vous souhaitez que le package d'application com.google.android.apps.turbo
contrôle le paramètre basé sur la routine, définissez cette valeur de configuration:
<string name="config_batterySaverScheduleProvider" translatable="false">
com.google.android.apps.turbo</string>
L'option basée sur une routine devrait maintenant s'afficher sur le téléphone. Pour le vérifier, créez votre image, flashez-la sur un téléphone, puis accédez à Settings > Battery > Battery Saver > Battery Schedule (Paramètres > Batterie > Économiseur de batterie > Programmation de l'économiseur de batterie). L'option basée sur une routine doit s'afficher.
Seuil de désactivation par défaut
Le nouveau champ config_dynamicPowerSavingsDefaultDisableThreshold
spécifie le niveau de batterie auquel le système désactive l'économiseur de batterie, s'il a été activé par le programmeur 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
.
Voici un exemple d'attribution 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. Par conséquent, vérifiez que vous pouvez appeler les API et observer 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'accordez l'autorisation POWER_SAVER
qu'à une seule application, et autorisez-la à contrôler les API basées sur une routine. Comportement de la fonctionnalité lorsque plusieurs applications tentent d'utiliser l'autorisation et que les API ne sont pas compatibles et ne sont pas spécifiées.
Activer 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 programmation 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 bien appelées, définissez les paramètres de requête globaux afin de vérifier que la valeur du paramètre de sauvegarde a changé 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
:
adb shell settings get global <setting-name>
Validation
Il n'existe aucun moyen automatisé de vérifier cette fonctionnalité, car il n'existe aucun moyen de savoir quel comportement un OEM utilisera pour décider quand déclencher le mode Économiseur de batterie 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 programmation de l'économiseur de batterie, puis 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'UI 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 none dans l'interface utilisateur de 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.