Áudio de alta resolução

A versão do Android 10 inclui as seguintes melhorias para áudio de alta resolução:

  • Float:os codecs e extratores WAV e FLAC foram atualizados para oferecer suporte a float (mais de 24 bits de precisão sem perdas). Os efeitos de downmix e Virtualizer foram atualizados para flutuar. A precisão atualizada é permitida pela MediaPlayer (NuPlayer).
  • Alta frequência:os codecs WAV, FLAC e os extratores foram atualizados para oferecer suporte a 192 kHz. Os efeitos padrão fornecidos pelo Android são testados para suporte a 192 kHz em frequências padrão. As frequências padrão permitidas são 88,2 kHz, 96 kHz, 176,4 kHz e 192 kHz.
  • Multicanal:os efeitos de reprodução padrão do Android são testados para suporte multicanal em até oito canais.
  • Tempo:as informações de tempo são incluídas em todo o framework de áudio.

A partir do Android 9, as seguintes melhorias não exigem implementação de parceiros:

  • O número de faixas de saída de clientes simultâneas aumenta de 14 para 40, já que instâncias de clientes limitadas de AudioTrack foram um problema para apps no Android 8.x.
  • A memória máxima do cliente/servidor aumenta de 4 MB para 32 MB (dependendo da memória total do dispositivo) para permitir mais faixas de áudio de alta resolução simultâneas.
  • O total de faixas mistas aumenta de 32 para 256 para evitar a contenção de recursos entre apps e a interface do sistema.

Mudanças no efeito da saída

Consulte Efeitos de áudio para conferir as mudanças na versão do Android 11.

Antes do lançamento do Android 9, o processamento da cadeia de efeitos era implementado no formato de amostra estéreo int16. Isso tinha várias limitações:

  • Todos os efeitos de saída forçaram a conversão de dados de áudio de ponto flutuante para int16, causando perda de precisão.
  • Os efeitos de saída foram rejeitados de sinks de saída com uma contagem de canais maior que dois.

Na versão do Android 9, o pipeline de processamento da cadeia de efeitos foi atualizado para oferecer suporte ao formato de ponto flutuante multicanal. Pontos importantes:

  • Os efeitos de software do Android já foram migrados para o modo flutuante estéreo.
  • Os efeitos legados têm suporte com adaptadores de formato, que convertem float em int16 conforme necessário.

Implementar efeitos de saída

Uma implementação de referência para efeitos de saída está disponível em frameworks/av/media/libeffects.

Os parceiros que implementarem os próprios efeitos de saída personalizados precisam fazer o seguinte para a versão do Android 10:

  • Atualize os efeitos de saída para oferecer suporte ao formato de ponto flutuante multicanal:
    • O suporte ao processamento Int16 não é mais necessário.
    • Suporte a contagens de canais de saída de 2 a 8 (para compatibilidade futura, considere contagens de 1 a 30).
    • Suporte a contagens de canais de entrada que correspondem a contagens de canais de saída para efeitos de inserção. Os efeitos auxiliares continuam a ter uma contagem de canal de entrada 1 (mono).
    • Suporte a máscaras de posição de canal (canônicas) e máscaras de índice de canal de (1 << n) - 1.
  • Se você precisar continuar a oferecer suporte aos efeitos de saída legados do fornecedor e não puder atualizá-los, verifique o código legado da seguinte maneira:
    • Os efeitos de saída legados (inserir) precisam rejeitar configurações sem suporte em EFFECT_CMD_SET_CONFIG.
      • Verifique se o formato é int16.
      • Verifique se as máscaras de canal de entrada e saída são estéreo.
      • Se uma das verificações falhar, retorne -EINVAL.
    • Os efeitos de saída legados (auxiliares) são configurados pelo AudioFlinger com uma máscara de canal de entrada mono e potencialmente máscaras de canal de saída multicanal, dependendo se o destino de saída é multicanal. Elas precisam rejeitar configurações sem suporte em EFFECT_CMD_SET_CONFIG.
      • Verifique se o formato é int16.
      • Verifique se a máscara do canal de entrada é mono e a máscara do canal de saída é estéreo.
      • Se uma das verificações falhar, retorne -EINVAL.
    • Verificar o código legado. Não suponha que ele funciona.