Pemanasan dan pengambilan awal: menggunakan Layanan Tab Khusus

Bagian ketiga panduan ini berfokus pada Layanan Tab Khusus dan alasan penggunaannya dalam aplikasi akan menciptakan pengalaman pengguna yang lebih baik:

  • Membuka konten eksternal secara instan: menggunakan warmup() akan membuat proses browser dimulai di latar belakang bahkan sebelum pengguna mengklik link dan dapat menghemat waktu hingga 700 md saat membuka link. mayLaunchUrl() melakukan pra-pengambilan halaman. Menggunakan kedua API secara bersamaan memungkinkan halaman dimuat secara instan, yang sangat meningkatkan pengalaman pengguna dari integrasi Tab Khusus.
  • Penanganan tab Khusus yang diperkecil dengan lebih baik: dengan menghubungkan ke layanan Tab Khusus dan menggunakan CustomTabSession yang sama saat meluncurkan Tab Khusus, Chrome akan dapat menghapus Tab Khusus yang sebelumnya diperkecil sebelum meluncurkan tab baru, sehingga memberikan pengalaman pengguna yang lebih konsisten.

Langkah-langkah yang diperlukan adalah:

  1. Periksa apakah browser default mendukung Tab Khusus menggunakan CustomTabsClient.getPackageName(...). Jika ya, ikat ke CustomTabsService menggunakan CustomTabsClient.bindCustomTabsService().
  2. Setelah terhubung ke CustomTabsService, di callback CustomTabsServiceConnection.onCustomTabsServiceConnected(), lakukan:

    a. Lakukan pemanasan proses browser menggunakan CustomTabsClient.warmup(). b. Buat CustomTabsSession baru menggunakan CustomTabsClient.newSession().

  3. Secara opsional, ambil data halaman web yang mungkin dikunjungi pengguna menggunakan CustomTabsSession.mayLaunchUrl().

  4. Saat meluncurkan Tab Khusus baru, teruskan CustomTabsSession ke CustomTabsIntent.Builder menggunakan konstruktor new CustomTabsIntent.Builder(session).

Jika aplikasi Anda menargetkan Android API level 30, CustomTabsClient.getPackageName(...) mengharuskan Anda untuk menambahkan bagian kueri ke Manifes Android Anda, mendeklarasikan filter intent yang cocok dengan browser dengan dukungan Tab Khusus.

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

Berikut adalah contoh lengkap cara terhubung ke layanan Tab Khusus:

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));
        }
    });
}

Di Android, URL dapat ditangani oleh aplikasi Android. Misalnya, jika pengguna telah menginstal aplikasi Facebook dan mengklik link ke postingan Facebook, mereka biasanya lebih suka membuka link di aplikasi Facebook daripada di browser.

Secara default, Custom Tabs akan membuka link dalam aplikasi Android masing-masing jika diinstal. Namun, setelah CustomTabsServiceConnection dibuat, perilaku ini akan berhenti berfungsi dan semua URL akan terbuka di Tab Khusus. Untuk pengalaman pengguna yang lebih baik, sebaiknya aktifkan kembali perilaku ini menggunakan kode berikut:

CustomTabsIntent customTabsIntent = new CustomTabsIntent.Builder()
    .setSendToExternalDefaultHandlerEnabled(true)
    .build();

Selanjutnya: Pelajari cara mengubah ukuran pengalaman Tab Khusus.