Suporte a dispositivos sem bateria

Esta página descreve como o Android lida com produtos que têm baterias removíveis ou não têm baterias internas. Em vez disso, eles são conectados a uma fonte de energia externa, como uma tomada CA ou uma porta USB em outro dispositivo.

Há uma bateria?

O código a seguir pode ser usado por aplicativos para detectar se o dispositivo tem uma bateria:

```
final Intent batteryInfo = registerReceiver(null, new
IntentFilter(Intent.ACTION_BATTERY_CHANGED));

return batteryInfo.getBooleanExtra(BatteryManager.EXTRA_PRESENT, true);
```

Comportamento de dispositivos sem bateria

Se o Android não detectar um dispositivo de bateria para seu produto, os seguintes valores padrão relacionados à bateria serão usados. Os padrões mudaram na versão do Android 9. Esta tabela mostra as diferenças.

Estado da bateria Android 9 e versões mais recentes Android 8.1 e versões anteriores
Apresentar false verdadeiro
Status desconhecido carregando
Capacidade restante 0 100%
Clínica desconhecido bom
Status on-line do carregador CA não modificado forçado como "true"

Os fabricantes podem alterar as configurações padrão usando um driver power_supply do kernel ou um HAL de integridade.

Android 9 e versões mais recentes

Ele remove parte do código anterior para dispositivos sem bateria que, por padrão, fingiam que uma bateria estava presente, estava sendo carregada em 100% e apresentava boa integridade, com uma leitura normal de temperatura no termistor.

A maioria das APIs de framework que lidam com essas informações continua processando situações comuns da mesma forma que antes: o sistema é considerado em carregamento (ou seja, não está funcionando com a bateria) e não é considerado com bateria fraca. Se a interface desenhar o ícone da bateria, ele vai aparecer com um ponto de exclamação, e a porcentagem da bateria será mostrada como 0%. Mas o dispositivo não será desligado devido à bateria fraca, e os trabalhos que exigem carregamento ou boa bateria serão programados.

Android 8.1 e versões anteriores

Como o status da bateria é desconhecido, as APIs do framework Android vão considerar que o sistema está carregando (ou seja, não está funcionando com a bateria) e não será considerado como tendo bateria fraca. Se a interface renderizar o ícone da bateria, ele vai aparecer com um ponto de exclamação, e a porcentagem da bateria será mostrada como 0%. Mas o dispositivo não será desligado devido à bateria fraca, e os trabalhos que exigem carregamento ou boa bateria serão programados.

Implementação

O código padrão do Android 9 pode funcionar corretamente no seu dispositivo, mas é recomendável fazer uma mudança no kernel ou na HAL para refletir com precisão o estado de energia e da bateria do produto, conforme descrito anteriormente. Se o Android 9 e versões mais recentes não detectarem um dispositivo carregador de fonte de alimentação Linux class , por padrão, todos os tipos de carregadores (CA, USB, sem fio) terão o status offline. Se todos os carregadores estiverem off-line, mas nenhum dispositivo a bateria for detectado, o sistema ainda será considerado em carregamento, já que está funcionando com energia externa, não com bateria, conforme descrito anteriormente.

Se o produto não tiver bateria e estiver sempre conectado a uma fonte de energia, é melhor implementar um driver charger da classe power_supply do kernel do Linux para a fonte de energia CA ou USB que define o atributo online sysfs como true. Ou configure a propriedade on-line do carregador CA em uma HAL de integridade para seu dispositivo. Para configurar a propriedade on-line do carregador CA em uma HAL de saúde, consulte HAL de saúde AIDL.

Essa HAL de integridade personalizada implementa uma versão personalizada de Health::getHealthInfo() que modifica o valor de BatteryProperties.chargerAcOnline = true.

Para começar, copie o arquivo hardware/interfaces/health/aidl/default/Health.cpp para sua própria implementação da HAL de integridade e modifique-o de acordo com a HAL de integridade AIDL.