Android デバイスにカスタムタブをサポートするブラウザが搭載されているかどうかを確認する

以降のセクションでは、Android デバイスのデフォルト ブラウザまたは任意のブラウザがカスタムタブをサポートしているかどうかを確認する方法について説明します。

デフォルトのブラウザがカスタムタブをサポートしているかどうかを確認する

デフォルトのブラウザが Custom Tabs をサポートしているかどうかを確認するには、CustomTabsClientgetPackageName ヘルパー メソッドを使用します。

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

デバイス上のブラウザがカスタムタブをサポートしているかどうかを確認する

デバイスにインストールされているブラウザがカスタムタブをサポートしているかどうかを確認するには、VIEW インテントを処理できるアプリをクエリし、パッケージ名を抽出し、CustomTabsClientgetPackageName ヘルパー メソッドを使用する必要があります。

// 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
}

Android 11 のパッケージの公開設定の変更

Android 11 では、パッケージの公開設定が変更されました。Android アプリが API レベル 30 以降をターゲットとしている場合は、AndroidManifest.xml の queries セクションに次の宣言を追加する必要があります。

この宣言がないと、queryIntentActivities メソッドは結果を返しません。

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

デバイスのブラウザでカスタムタブがサポートされていない

デバイスでカスタムタブをサポートするブラウザが使用できず、customTabsIntent.launchUrl(context, url) を使用して URL を起動すると、インテントの失敗につながり、ActivityNotFoundException が発生する可能性があります。

ユーザー エクスペリエンスを向上させるため、必ず互換性チェックを実施してください。

標準の ACTION_VIEW インテントにフォールバックして、使用可能なブラウザで URL を開くことができます。