以降のセクションでは、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 を開くことができます。