ViewPager sous Android : Comment slider d’un fragment à un autre - Astuces info | IPA ,APK, Android,Iphone,Ipad,Ipod

Astuces info | IPA ,APK, Android,Iphone,Ipad,Ipod

astuces et trucs des application ,jeux,ipa,apk, tous les nouveautés des jeux et theme android et iphone ipad ipod,tablette, tous ce que vous chercher dans l internet

jeudi 4 juillet 2013

ViewPager sous Android : Comment slider d’un fragment à un autre



Nous revoici pour un nouveau tutoriel, le premier à aborder la notion de Fragment. Les Fragments ont été introduits dans la version Android 3.0 (également utilisable avec des versions antérieures) avec pour objectif de permettre une plus grande flexibilité pour les écrans larges tel que les tablettes tactiles (ce que nous verrons dans un prochain tutoriel). Notre objectif aujourd’hui est simplement de créer un joli effet “slide” entre des pages.

Qu’est-ce qu’un Fragment ?


C’est certainement la question que vous devez vous poser. On peut voir un Fragment comme une “mini-Activity” ou une portion d’une activité qui ne peut pas vivre en dehors d’une Activity. Un des aspects pratiques du Fragment est qu’il peut être facilement réutilisé d’une Activity à l’autre.

Notre projet


Comme d’habitude, je vous invite à créer un projet dédié à ce tutoriel, que j’ai baptisé TutoFragment. Je l’ai volontairement créé pour la version Android 2.2 pour y intégrer le package de compatibilité, puisqu’à la base, les Fragments viennent sont une fonctionnalité de la version 3.0.
Nous allons donc premièrement télécharger la librairie complémentaire. Pour cela, allez dans le SDK Manager en cliquant sur l’icône suivante et télécharger “Android Support”.

sdk_manager

ViewPager sous Android : Comment slider d’un fragment à un autre


Ajoutons ensuite cette librairie au projet. Pour cela, sélectionnez votre projet sous Eclipse, clic droit/Android tools/Add support library. La librairie s’intègre automatiquement au projet, ce qui nous permet d’utiliser la classe Fragment !

Les fichiers xml


Le layout principal, que j’ai renommé viewpager.xml, se présente de la manière suivante:

?xml version="1.0" encoding="utf-8"?

android.support.v4.view.ViewPager
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/viewpager"
/android.support.v4.view.ViewPager


La balise du composant utilisé ici a une syntaxe particulière puisqu’elle fait référence à un composant de la librairie ajoutée précédemment.

Les trois autres layouts seront les pages affichées successivement lors du slide et possèdent un code similaires. Voici le code de page_gauche_layout.xml, je vous laisse créer les deux autres par vous même (page_milieu_layout et page_droite_layout).

?xml version="1.0" encoding="utf-8"?
LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"

TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_margin="20dp"
android:text="Page de gauche" /

/LinearLayout


Le code Java


J’ai renommé la classe principale en Fragments Slider Activity. Celle-ci dérive de la classe Fragment Activity qui est simplement une Activity permettant de gérer les Fragments. Le code est commenté, je vous laisse regarder.

import java.util.List;
import java.util.Vector;

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;

public class FragmentsSliderActivity extends FragmentActivity {

private PagerAdapter mPagerAdapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
super.setContentView(R.layout.viewpager);

// Création de la liste de Fragments que fera défiler le PagerAdapter
List fragments = new Vector();

// Ajout des Fragments dans la liste
fragments.add(Fragment.instantiate(this,PageGaucheFragment.class.getName()));
fragments.add(Fragment.instantiate(this,PageMilieuFragment.class.getName()));
fragments.add(Fragment.instantiate(this,PageDroiteFragment.class.getName()));

// Création de l'adapter qui s'occupera de l'affichage de la liste de
// Fragments
this.mPagerAdapter = new MyPagerAdapter(super.getSupportFragmentManager(), fragments);

ViewPager pager = (ViewPager) super.findViewById(R.id.viewpager);
// Affectation de l'adapter au ViewPager
pager.setAdapter(this.mPagerAdapter);
}
}


Pour passer d’une page à une autre, nous avons besoin d’un adapter (à la manière des ListView). L’adapter, appelé MyPagerAdapter dérive de FragmentPagerAdapter. Rien de compliqué, il fonctionne sur le même principe que les Adapters de ListViews.

import java.util.List;

import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;

public class MyPagerAdapter extends FragmentPagerAdapter {

private final List fragments;

//On fournit à l'adapter la liste des fragments à afficher
public MyPagerAdapter(FragmentManager fm, List fragments) {
super(fm);
this.fragments = fragments;
}

@Override
public Fragment getItem(int position) {
return this.fragments.get(position);
}

@Override
public int getCount() {
return this.fragments.size();
}
}


Enfin, la classe PageGaucheFragment, qui dérive de la classe Fragment possède des méthodes différentes de la classe Activity.

Ici, nous allons surcharger la méthode onCreateView. Cette méthode retourne un type View, on va donc lui indiquer notre layout par le biais de l’inflater. Les classes PageMilieuFragment et PageDroiteFragment sont quasi-identiques, je vous laisse vous en occuper.

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class PageGaucheFragment extends Fragment {

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
return inflater.inflate(R.layout.page_gauche_layout, container, false);
}
}


Rendu final:
page 1page 2page 2

Conclusion


Ainsi se termine notre premier tutoriel sur les Fragments, en espérant que tout soit clair. Vous pouvez trouver le code source ici.

Aucun commentaire:

Enregistrer un commentaire