A API Phone Number Hint, uma biblioteca com tecnologia do Google Play Services, oferece uma maneira simples de mostrar os números de telefone (baseados no SIM) de um usuário como uma dica.
Os benefícios de usar a Phone Number Hint incluem:
- Nenhuma outra solicitação de permissão é necessária
- Elimina a necessidade de o usuário digitar manualmente o número de telefone
- Nenhuma Conta do Google é necessária
- Não está diretamente vinculada a fluxos de login ou inscrição
- Suporte mais amplo para versões do Android em comparação com o preenchimento automático
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 (baseados no SIM). Em seguida, o usuário pode selecionar um número de telefone que gostaria de usar ou cancelar o fluxo.
O número de telefone selecionado será disponibilizado para o desenvolvedor
recuperar de Intent.
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.5.1'
}
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 uma Intent para iniciar o fluxo da Phone Number Hint.
Kotlin
val request: GetPhoneNumberHintIntentRequest = GetPhoneNumberHintIntentRequest.builder().build()
Java
GetPhoneNumberHintIntentRequest request = GetPhoneNumberHintIntentRequest.builder().build();
Solicitar a Phone Number Hint
Chame SignInClient.getPhoneNumberHintIntent(),
transmitindo o objeto GetPhoneNumberHintIntentRequest anterior,
para recuperar a PendingIntent e iniciar o fluxo da Phone Number Hint.
Kotlin
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") }
Java
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); });
Recuperar o número de telefone
Transmita o Intent para SignInClient.getPhoneNumberFromIntent
para recuperar o número de telefone.
Kotlin
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") } }
Java
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); } } });