इस गाइड का तीसरा हिस्सा, कस्टम टैब सेवा पर फ़ोकस किया गया है. साथ ही, यह भी बताया गया है कि अपने ऐप्लिकेशन में इसका इस्तेमाल करने से, उपयोगकर्ताओं को बेहतर अनुभव क्यों मिलता है:
- बाहरी कॉन्टेंट को तुरंत खोलना:
warmup()
का इस्तेमाल करने पर, उपयोगकर्ता के किसी लिंक पर क्लिक करने से पहले ही ब्राउज़र प्रोसेस बैकग्राउंड में शुरू हो जाती है. इससे, लिंक खोलने में 700 मिलीसेकंड तक की बचत हो सकती है.mayLaunchUrl()
पेजों को पहले से फ़ेच करता है. दोनों एपीआई का एक साथ इस्तेमाल करने से, पेज तुरंत लोड हो जाते हैं. इससे कस्टम टैब इंटिग्रेशन के उपयोगकर्ता अनुभव को बेहतर बनाने में काफ़ी मदद मिलती है. - छोटे किए गए कस्टम टैब को बेहतर तरीके से मैनेज करना: कस्टम टैब सेवा से कनेक्ट करके और कस्टम टैब लॉन्च करते समय उसी
CustomTabSession
का इस्तेमाल करके, Chrome किसी नए टैब को लॉन्च करने से पहले, पहले से छोटे किए गए कस्टम टैब को हटा देगा. इससे, उपयोगकर्ता को बेहतर अनुभव मिलेगा.
इसके लिए, ये काम करने होंगे:
CustomTabsClient.getPackageName(...)
का इस्तेमाल करके देखें कि डिफ़ॉल्ट ब्राउज़र पर कस्टम टैब काम करते हैं या नहीं. अगर हां, तोCustomTabsClient.bindCustomTabsService()
का इस्तेमाल करके CustomTabsService से बाइंड करें.CustomTabsService से कनेक्ट होने के बाद,
CustomTabsServiceConnection.onCustomTabsServiceConnected()
कॉलबैक में ये काम करें:a.
CustomTabsClient.warmup()
का इस्तेमाल करके, ब्राउज़र प्रोसेस को वॉर्म अप करें. b.CustomTabsClient.newSession()
का इस्तेमाल करके नयाCustomTabsSession
बनाएं.इसके अलावा,
CustomTabsSession.mayLaunchUrl()
का इस्तेमाल करके ऐसे वेब पेजों को प्रीफ़ेच करें जिन पर उपयोगकर्ता जा सकता है.नया कस्टम टैब लॉन्च करते समय, कन्स्ट्रक्टर
new CustomTabsIntent.Builder(session)
का इस्तेमाल करके CustomTabsIntent.Builder कोCustomTabsSession
पास करें.
अगर आपका ऐप्लिकेशन Android एपीआई लेवल 30 को टारगेट करता है, तो CustomTabsClient.getPackageName(...)
के लिए आपको अपने Android मेनिफ़ेस्ट में क्वेरी सेक्शन जोड़ना होगा. इसके लिए, आपको एक इंटेंट-फ़िल्टर का एलान करना होगा, जो कस्टम टैब की सुविधा वाले ब्राउज़र से मैच करता हो.
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
…
<queries>
<intent>
<action android:name="android.support.customtabs.action.CustomTabsService" />
</intent>
</queries>
</manifest>
कस्टम टैब सेवा से कनेक्ट करने का पूरा उदाहरण यहां दिया गया है:
private CustomTabsClient mClient;
private CustomTabsSession mSession;
private CustomTabsServiceConnection mConnection = new CustomTabsServiceConnection() {
@Override
public void onCustomTabsServiceConnected(
@NonNull ComponentName name,
@NonNull CustomTabsClient client
) {
mClient = client;
// Warm up the browser process
mClient.warmup(0 /* placeholder for future use */);
// Create a new browser session
mSession = mClient.newSession(new CustomTabsCallback());
// Pre-render pages the user is likely to visit
// you can do this any time while the service is connected
mSession.mayLaunchUrl(Uri.parse("https://developers.android.com"), null, null);
}
@Override
public void onServiceDisconnected(ComponentName name) {
mClient = null;
mSession = null;
}
};
private void bindCustomTabService(Context context) {
// Check for an existing connection
if (mClient != null) {
// Do nothing if there is an existing service connection
return;
}
// Get the default browser package name, this will be null if
// the default browser does not provide a CustomTabsService
String packageName = CustomTabsClient.getPackageName(context, null);
if (packageName == null) {
// Do nothing as service connection is not supported
return;
}
CustomTabsClient.bindCustomTabsService(context, packageName, mConnection);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
…
bindCustomTabService(this);
findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String url = "https://developers.android.com";
CustomTabsIntent intent = new CustomTabsIntent.Builder(mSession)
.build();
intent.launchUrl(MainActivity.this, Uri.parse(url));
}
});
}
Android ऐप्लिकेशन में लिंक खोलना
Android पर, यूआरएल को Android ऐप्लिकेशन मैनेज कर सकते हैं. उदाहरण के लिए, अगर उपयोगकर्ता के पास Facebook ऐप्लिकेशन इंस्टॉल है और वह किसी Facebook पोस्ट के लिंक पर क्लिक करता है, तो आम तौर पर वह लिंक को ब्राउज़र के बजाय Facebook ऐप्लिकेशन में खोलना चाहता है.
कस्टम टैब, डिफ़ॉल्ट रूप से लिंक को उस Android ऐप्लिकेशन में खोलता है जिसमें वे लिंक मौजूद होते हैं. हालांकि, इसके लिए ज़रूरी है कि वह ऐप्लिकेशन आपके डिवाइस में इंस्टॉल हो. हालांकि, CustomTabsServiceConnection
सेट अप होने के बाद, यह सुविधा काम नहीं करती और सभी यूआरएल कस्टम टैब में खुलते हैं. बेहतर उपयोगकर्ता अनुभव के लिए, हमारा सुझाव है कि आप नीचे दिए गए कोड का इस्तेमाल करके इस व्यवहार को फिर से चालू करें:
CustomTabsIntent customTabsIntent = new CustomTabsIntent.Builder()
.setSendToExternalDefaultHandlerEnabled(true)
.build();