A API Phone Number Hint, uma biblioteca com tecnologia do Google Play Services, oferece uma maneira simples de mostrar os números de telefone (com base no SIM) de um usuário como sugestão.
Os benefícios de usar a dica de número de telefone incluem:
- Nenhuma solicitação de permissão extra é necessária
- Elimina a necessidade de o usuário digitar manualmente o número de telefone
- Não é necessário ter uma Conta do Google
- Não está diretamente vinculado aos fluxos de trabalho de login/inscrição
- Suporte mais amplo para versões do Android em comparação com o Preenchimento automático
Antes de começar
Para preparar o app, siga as etapas nas seções a seguir.
Configurar o app
Adicione a dependência do Google Play Services
para a API Phone Number Hint ao
arquivo de build do Gradle do seu módulo,
que geralmente é app/build.gradle
:
apply plugin: 'com.android.application'
...
dependencies {
implementation 'com.google.android.gms:play-services-auth:21.3.0'
}
Como funciona
A API Phone Number Hint usa um PendingIntent
para iniciar o fluxo. Depois que a PendingIntent for iniciada, o usuário vai receber
uma interface que lista todos os números de telefone (com base no SIM). O usuário pode
selecionar um número de telefone para usar ou cancelar o fluxo.
O número de telefone selecionado será disponibilizado para o desenvolvedor
extrair do Intent
.

Criar um objeto GetPhoneNumbeHintIntentRequest
Comece criando um objeto GetPhoneNumberHintIntentRequest
usando o
método GetPhoneNumberHintIntentRequest.Builder()
fornecido. Esse objeto de solicitação pode ser usado para receber um Intent
e iniciar o
fluxo de sugestão de número de telefone.
val request: GetPhoneNumberHintIntentRequest = GetPhoneNumberHintIntentRequest.builder().build()
GetPhoneNumberHintIntentRequest request = GetPhoneNumberHintIntentRequest.builder().build();
Dica para solicitar um número de telefone
Chame SignInClient.getPhoneNumberHintIntent()
,
transmitindo o objeto GetPhoneNumberHintIntentRequest
anterior,
para recuperar o PendingIntent
e iniciar o fluxo de dica de número de telefone.
val phoneNumberHintIntentResultLauncher = ... Identity.getSignInClient(activity) .getPhoneNumberHintIntent(request) .addOnSuccessListener { result: PendingIntent -> try { phoneNumberHintIntentResultLauncher.launch( IntentSenderRequest.Builder(result).build() ) } catch (e: Exception) { Log.e(TAG, "Launching the PendingIntent failed") } } .addOnFailureListener { Log.e(TAG, "Phone Number Hint failed") }
ActivityResultLauncherphoneNumberHintIntentResultLauncher = ... Identity.getSignInClient(activity) .getPhoneNumberHintIntent(request) .addOnSuccessListener( result -> { try { phoneNumberHintIntentResultLauncher.launch(result.getIntentSender()); } catch(Exception e) { Log.e(TAG, "Launching the PendingIntent failed", e); } }) .addOnFailureListener(e -> { Log.e(TAG, "Phone Number Hint failed", e); });
Como recuperar o número de telefone
Transmita o Intent
para SignInClient.getPhoneNumberFromIntent
para recuperar o número de telefone.
val phoneNumberHintIntentResultLauncher = registerForActivityResult(ActivityResultContracts.StartIntentSenderForResult()) { result -> try { val phoneNumber = Identity.getSignInClient(activity).getPhoneNumberFromIntent(result.data) } catch(e: Exception) { Log.e(TAG, "Phone Number Hint failed") } }
ActivityResultLauncherphoneNumberHintIntentResultLauncher = registerForActivityResult( new ActivityResultContracts.StartActivityForResult(), new ActivityResultCallback () { @Override public void onActivityResult(ActivityResult result) { try { String phoneNumber = Identity.getSignInClient(activity).getPhoneNumberFromIntent(result.getData()); } catch { Log.e(TAG, "Phone Number Hint failed", e); } } });