Verificar se um dispositivo Android tem um navegador compatível com guias personalizadas

As seções a seguir mostram como confirmar se o navegador padrão ou qualquer navegador em um dispositivo Android oferece suporte a guias personalizadas.

Verificar se o navegador padrão oferece suporte a guias personalizadas

Para verificar se o navegador padrão oferece suporte a guias personalizadas, use o método auxiliar getPackageName em CustomTabsClient:

String packageName = CustomTabsClient.getPackageName(
        context,
        Collections.emptyList()
);
if (packageName == null) {
    // Custom Tabs are not supported by the default browser
}

Verificar se algum navegador no dispositivo oferece suporte a guias personalizadas

Para verificar se algum navegador instalado no dispositivo oferece suporte a guias personalizadas, você precisa consultar apps que podem processar intents VIEW, extrair os nomes dos pacotes e usar o método auxiliar getPackageName em CustomTabsClient:

// Get all apps that can handle VIEW intents and Custom Tab service connections.
Intent activityIntent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://www.example.com"));
PackageManager packageManager = context.getPackageManager();
List<ResolveInfo> resolveInfos = packageManager.queryIntentActivities(activityIntent, PackageManager.MATCH_ALL);

// Extract package names from ResolveInfo objects
List<String> packageNames = new ArrayList<>();
for (ResolveInfo info : resolveInfos) {
    packageNames.add(info.activityInfo.packageName);
}

// Get a package that supports Custom Tabs
String packageName = CustomTabsClient.getPackageName(
        context,
        packageNames,
        true /* ignore default */
);
if (packageName == null) {
    // Custom Tabs are not supported by any browser on the device
}

Mudanças na visibilidade de pacotes do Android 11

O Android 11 introduziu mudanças na visibilidade do pacote. Se o app Android for direcionado ao nível 30 da API ou mais recente, adicione a declaração a seguir na seção de consultas do AndroidManifest.xml.

Sem essa declaração, o método queryIntentActivities não vai retornar resultados:

<queries>
    <intent>
        <action android:name=
            "android.support.customtabs.action.CustomTabsService" />
    </intent>
</queries>

Nenhum navegador no dispositivo oferece suporte a guias personalizadas

Se nenhum navegador compatível com guias personalizadas estiver disponível no dispositivo e você iniciar um URL usando customTabsIntent.launchUrl(context, url), a intent poderá falhar, resultando em uma ActivityNotFoundException.

Sempre faça uma verificação de compatibilidade para garantir uma melhor experiência do usuário.

É possível usar uma Intent ACTION_VIEW padrão para abrir o URL em qualquer navegador disponível.