Riscaldamento e precaricamento: utilizzo del servizio Schede personalizzate

La terza parte di questa guida è incentrata sul servizio Schede personalizzate e sul motivo per cui utilizzarlo nella tua applicazione crea una migliore esperienza utente:

  • Apri all'istante contenuti esterni: se utilizzi warmup(), il processo del browser viene avviato in background anche prima che l'utente faccia clic su un link e può risparmiare fino a 700 ms quando apre un link. mayLaunchUrl() precarica le pagine. L'utilizzo combinato di entrambe le API consente il caricamento istantaneo delle pagine, migliorando notevolmente l'esperienza utente dell'integrazione di schede personalizzate.
  • Migliore gestione delle schede personalizzate ridotte: collegandoti al servizio Schede personalizzate e utilizzando la stessa CustomTabSession quando avvii la scheda personalizzata, Chrome sarà in grado di rimuovere una delle schede personalizzate precedentemente ridotte a icona prima di lanciare una nuova scheda, offrendo un'esperienza utente più coerente.

I passaggi obbligatori sono:

  1. Controlla se il browser predefinito supporta le schede personalizzate utilizzando CustomTabsClient.getPackageName(...). In caso affermativo, esegui l'associazione a CustomTabsService utilizzando CustomTabsClient.bindCustomTabsService().
  2. Dopo aver eseguito la connessione a CustomTabsService, nel callback CustomTabsServiceConnection.onCustomTabsServiceConnected():

    a. Riscalda il processo del browser utilizzando CustomTabsClient.warmup(). b. Crea una nuova CustomTabsSession utilizzando CustomTabsClient.newSession().

  3. (Facoltativo) Precarica le pagine web che l'utente è probabile che visiti utilizzando CustomTabsSession.mayLaunchUrl().

  4. Quando avvii una nuova scheda personalizzata, passa CustomTabsSession a CustomTabsIntent.Builder utilizzando il costruttore new CustomTabsIntent.Builder(session).

Se la tua app ha come target il livello API Android 30, CustomTabsClient.getPackageName(...) richiede l'aggiunta di una sezione per le query al file manifest Android, dichiarando un filtro per intent che corrisponde ai browser supportati per le schede personalizzate.

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

Ecco un esempio completo di come connettersi a un servizio Schede personalizzate:

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

Su Android, gli URL possono essere gestiti dalle app per Android. Ad esempio, se l'utente ha installato l'app di Facebook e fa clic su un link a un post di Facebook, di solito preferisce l'apertura del link nell'app di Facebook anziché nel browser.

Per impostazione predefinita, le schede personalizzate aprono i link nella rispettiva applicazione per Android, se installata. Tuttavia, una volta stabilito un CustomTabsServiceConnection, questo comportamento smette di funzionare e tutti gli URL si aprono nelle schede personalizzate. Per una migliore esperienza utente, ti consigliamo di riattivare questo comportamento utilizzando il seguente codice:

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

A seguire: scopri come ridimensionare l'esperienza relativa alle schede personalizzate.