Utiliser le composant compatible avec la version

Maintenant que vous disposez de deux implémentations de TabHelper et CompatTab, l'une pour Android 3.0 et les versions ultérieures et l'autre pour les versions antérieures de la plate-forme, il est temps de les utiliser. Cette leçon explique comment créer la logique permettant de basculer entre ces implémentations, créer des mises en page compatibles avec la version et enfin, utiliser le composant d'interface utilisateur rétrocompatible.

Ajouter la logique de basculement

La classe abstraite TabHelper sert de fabrique pour créer des instances TabHelper et CompatTab appropriées, en fonction de la version actuelle de la plate-forme de l'appareil:

Kotlin

sealed class TabHelper(protected val mActivity: FragmentActivity, protected val tag: String) {

    abstract fun setUp()

    abstract fun addTab(tab: CompatTab)

    // Usage is tabHelper.newTab("tag")
    fun newTab(tag: String): CompatTab =
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
                CompatTabHoneycomb(mActivity, tag)
            } else {
                CompatTabEclair(mActivity, tag)
            }

    companion object {
        // Usage is TabHelper.createInstance(activity)
        fun createInstance(activity: FragmentActivity): TabHelper =
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
                    TabHelperHoneycomb(activity)
                } else {
                    TabHelperEclair(activity)
                }
    }
}

Java

public abstract class TabHelper {
    ...
    // Usage is TabHelper.createInstance(activity)
    public static TabHelper createInstance(FragmentActivity activity) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
            return new TabHelperHoneycomb(activity);
        } else {
            return new TabHelperEclair(activity);
        }
    }

    // Usage is tabHelper.newTab("tag")
    public CompatTab newTab(String tag) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
            return new CompatTabHoneycomb(mActivity, tag);
        } else {
            return new CompatTabEclair(mActivity, tag);
        }
    }
    ...
}

Créer une mise en page d'activité compatible avec les versions

L'étape suivante consiste à fournir des mises en page pour votre activité compatibles avec les implémentations d'onglets. Dans l'ancienne implémentation (TabHelperEclair), vous devez vous assurer que la mise en page de votre activité contient TabWidget et TabHost, ainsi qu'un conteneur pour le contenu des onglets:

res/layout/main.xml :

<!-- This layout is for API level 5-10 only. -->
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/tabhost"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:padding="5dp">

        <TabWidget
            android:id="@android:id/tabs"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />

        <FrameLayout
            android:id="@android:id/tabcontent"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1" />

    </LinearLayout>
</TabHost>

Pour l'implémentation de TabHelperHoneycomb, tout ce dont vous avez besoin est un FrameLayout pour contenir le contenu des onglets, car les indicateurs d'onglet sont fournis par ActionBar:

res/layout-v11/main.xml :

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/tabcontent"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />

Au moment de l'exécution, Android décide de la version de la mise en page main.xml à gonfler en fonction de la version de la plate-forme. Cette logique est la même que celle présentée dans la section précédente pour déterminer l'implémentation de TabHelper à utiliser.

Utiliser TabHelper dans votre activité

Dans la méthode onCreate() de votre activité, vous pouvez obtenir un objet TabHelper et ajouter des onglets avec le code suivant:

Kotlin

override fun onCreate(savedInstanceState: Bundle?) {
    ...
    setContentView(R.layout.main)

    TabHelper.createInstance(this).apply {
        setUp()

        newTab("photos")
                .setText(R.string.tab_photos)
                .also { photosTab ->
                    addTab(photosTab)
                }

        newTab("videos")
                .setText(R.string.tab_videos)
                .also { videosTab ->
                    addTab(videosTab)
                }
    }
}

Java

@Override
public void onCreate(Bundle savedInstanceState) {
    setContentView(R.layout.main);

    TabHelper tabHelper = TabHelper.createInstance(this);
    tabHelper.setUp();

    CompatTab photosTab = tabHelper
            .newTab("photos")
            .setText(R.string.tab_photos);
    tabHelper.addTab(photosTab);

    CompatTab videosTab = tabHelper
            .newTab("videos")
            .setText(R.string.tab_videos);
    tabHelper.addTab(videosTab);
}

Lors de l'exécution de l'application, ce code gonfle la mise en page de l'activité et instancie un objet TabHelperHoneycomb ou TabHelperEclair. La classe concrète utilisée est opaque pour l'activité, car elles partagent l'interface TabHelper commune.

Vous trouverez ci-dessous deux captures d'écran de cette implémentation exécutée sur un appareil Android 2.3 et Android 4.0.

Capture d&#39;écran d&#39;exemples d&#39;onglets exécutés sur un appareil Android 2.3 (avec TabHelperEclair). Captures d&#39;écran d&#39;exemples d&#39;onglets exécutés sur un appareil Android 4.0 (avec TabHelperHoneycomb).

Figure 1 : Exemples de captures d'écran d'onglets rétrocompatibles exécutés sur un appareil Android 2.3 (avec TabHelperEclair) et sur un appareil Android 4.0 (avec TabHelperHoneycomb).