以降のセクションでは、Android デバイスのデフォルト ブラウザまたは任意のブラウザがカスタムタブをサポートしているかどうかを確認する方法について説明します。
デフォルトのブラウザがカスタムタブをサポートしているかどうかを確認する
デフォルトのブラウザが Custom Tabs をサポートしているかどうかを確認するには、CustomTabsClient
の getPackageName
ヘルパー メソッドを使用します。
String packageName = CustomTabsClient.getPackageName(
context,
Collections.emptyList()
);
if (packageName == null) {
// Custom Tabs are not supported by the default browser
}
デバイス上のブラウザがカスタムタブをサポートしているかどうかを確認する
デバイスにインストールされているブラウザがカスタムタブをサポートしているかどうかを確認するには、VIEW
インテントを処理できるアプリをクエリし、パッケージ名を抽出し、CustomTabsClient
の getPackageName
ヘルパー メソッドを使用する必要があります。
// 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 を開くことができます。