6

Salut J'ai une activité à onglets, et dans le premier onglet, je récupère des données du serveur et les affiche dans une vue recyclée dans les vues de cartes. Pour récupérer les données du serveur, j'utilise la bibliothèque de volley. Je veux mettre en œuvre le Pull pour actualiser pour charger les données (donc chaque fois que je tire il doit faire la demande au réseau). Et je veux aussi désactiver la requête réseau chaque fois que je passe d'un onglet à l'autre (parce que lorsque je change d'onglet je commence à chercher des données) Je veux faire une demande réseau seulement 1 fois (quand l'utilisateur se connecte pour la première fois) Les autres demandes ne sont gérées que par tirage au sort.Tirer pour rafraîchir recyclerview android

Voici mon fragment où je recyclerview et montrer les données:

public class Tab1History extends Fragment 
{ 

private RecyclerView recyclerView; 
private CespiteAdapter adapter; 
UserSessionManager session; 

private static final String URL_DATA = "http://mydata.php"; 

private List<CespiteOgg> cespiteOggList; 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) 
{ 

    View rootView = inflater.inflate(R.layout.tab1history, container, false); 

    recyclerView = (RecyclerView) rootView.findViewById(R.id.my_recycler_view); 
    recyclerView.setHasFixedSize(true);//every item of the RecyclerView has a fix size 
    recyclerView.setLayoutManager(new LinearLayoutManager(getContext())); 

    cespiteOggList = new ArrayList<>(); 

    loadRecyclerViewData(); 

      return rootView; 
} 

private void loadRecyclerViewData() 
{ 
    // Session class instance 
    session = new UserSessionManager(getActivity()); 
    //get user data from session 
    HashMap<String, String> user = session.getUserDetails(); 
    //get name 
    String name = user.get(UserSessionManager.KEY_NAME); 
    // get username 
    final String usernameUtente = user.get(UserSessionManager.KEY_USERNAME); 

    final ProgressDialog progressDialog = new ProgressDialog(getActivity()); 
    progressDialog.setMessage("Carimento dati..."); 
    progressDialog.show(); 

    StringRequest stringRequest = new StringRequest(Request.Method.POST, 
      URL_DATA, 
      new Response.Listener<String>() { 
       @Override 
       public void onResponse(String s) { 
        progressDialog.dismiss(); 
        try { 
         JSONObject jsonObject = new JSONObject(s); 
         JSONArray array = jsonObject.getJSONArray("dates"); 

         for(int i=0; i<array.length(); i++) 
         { 
          JSONObject o = array.getJSONObject(i); 
          CespiteOgg item = new CespiteOgg(
            o.getString("CodNumInventario"), 
            o.getString("Nome"), 
            o.getString("DtCatalogazione"), 
            o.getString("CodIdA"), 
            o.getString("username") 
          ); 
          cespiteOggList.add(item); 
         } 

         adapter = new CespiteAdapter(cespiteOggList, getActivity()); 
         recyclerView.setAdapter(adapter); 

        } catch (JSONException e) { 
         e.printStackTrace(); 
        } 

       } 
      }, 
      new Response.ErrorListener() { 
       @Override 
       public void onErrorResponse(VolleyError error) { 
        progressDialog.dismiss(); 
       } 
      }) 
      { 
       @Override 
       protected Map<String, String> getParams() throws AuthFailureError { 
        Map<String, String> params = new HashMap<String, String>(); 
        params.put("Username", usernameUtente); 
        return params; 
       } 
      }; 

    RegisterRequest.getmInstance(getActivity()).addToRequestque(stringRequest); 

} 
} 

Et il est l'adaptateur:

public class CespiteAdapter extends RecyclerView.Adapter<CespiteAdapter.ViewHolder> 
{ 


private List<CespiteOgg> cespiteOggList; 
private Context context; 

public CespiteAdapter(List<CespiteOgg> cespiteOggList, Context context) { 

    this.cespiteOggList = cespiteOggList; 
    this.context = context; 
} 

public class ViewHolder extends RecyclerView.ViewHolder 
{ 

    public CardView cv; 
    public TextView txtNumInventario; 
    public TextView txtNomeCespite; 
    public TextView txtDtCatalogazione; 
    public TextView txtAula; 
    public TextView txtNomeUser; 


    ViewHolder(View itemView) 
    { 

     super (itemView); 
     //cv = (CardView) itemView.findViewById(R.id.cardView); 
     txtNumInventario = (TextView) itemView.findViewById(R.id.txtNumeroInventario); 
     txtNomeCespite = (TextView) itemView.findViewById(R.id.txtNomeCespite); 
     txtDtCatalogazione = (TextView) itemView.findViewById(R.id.txtDataCatalogazione); 
     txtAula = (TextView) itemView.findViewById(R.id.txtAula); 
     txtNomeUser= (TextView) itemView.findViewById(R.id.txtNomeUser); 


    } 
} 



@Override 
public CespiteAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) 
{ 

    LayoutInflater inflater = LayoutInflater.from(parent.getContext()); 

    View cespiteView = inflater.inflate(R.layout.cespite_card_view, parent, false); 

    return new ViewHolder(cespiteView); 
} 

@Override 
public void onBindViewHolder(ViewHolder holder, int position) 
{ 

    CespiteOgg cespiteOgg = cespiteOggList.get(position); 

    holder.txtNumInventario.setText(cespiteOgg.getNumInventario()); 
    holder.txtNomeCespite.setText(cespiteOgg.getNomeCespite()); 
    holder.txtDtCatalogazione.setText(cespiteOgg.getDtCatalogazione()); 
    holder.txtAula.setText(cespiteOgg.getAula()); 
    holder.txtNomeUser.setText(cespiteOgg.getNomeUser()); 

} 

@Override 
public int getItemCount() 
{ 

    return cespiteOggList.size(); 
} 

} 
+0

vérifier ce lien https://developer.android.com/ entraînement/glisser/ajouter-glisser-interfa ce.html –

Répondre

15

Vous pouvez utiliser un widget android SwipeRefreshLayout au lieu de ProgressDialog.

Suivez étapes ci-dessous pour intégrer SwipeRefreshLayout dans votre fragment Tab1history:

1. Dans votre mise en page tab1history, ajoutez SwipeRefreshLayout comme une mise en page de racine et placez RecyclewrView à l'intérieur.

// tab1history.xml 
<?xml version="1.0" encoding="utf-8"?> 
<android.support.v4.widget.SwipeRefreshLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/swipe_container" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

     <android.support.v7.widget.RecyclerView 
      android:id="@+id/my_recycler_view" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" /> 

</android.support.v4.widget.SwipeRefreshLayout> 

2. Dans votre fragment Tab1History, utilisez SwipeRefreshLayout comme ci-dessous pour charger les données du serveur:

// Tab1History.java 
import android.os.Bundle; 
import android.support.v4.app.Fragment; 
import android.support.v4.widget.SwipeRefreshLayout; 
import android.support.v7.widget.LinearLayoutManager; 
import android.support.v7.widget.RecyclerView; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 

import com.android.volley.Request; 
import com.android.volley.Response; 
import com.android.volley.toolbox.StringRequest; 

import org.json.JSONArray; 
import org.json.JSONException; 
import org.json.JSONObject; 

import java.util.ArrayList; 


public class Tab1History extends Fragment implements SwipeRefreshLayout.OnRefreshListener { 

    SwipeRefreshLayout mSwipeRefreshLayout; 
    private RecyclerView recyclerView; 
    private CespiteAdapter adapter; 
    UserSessionManager session; 

    private static final String URL_DATA = "http://mydata.php"; 

    private List<CespiteOgg> cespiteOggList; 

    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
          Bundle savedInstanceState) 
    { 

     View rootView = inflater.inflate(R.layout.tab1history, container, false); 


     recyclerView = (RecyclerView) rootView.findViewById(R.id.my_recycler_view); 
     recyclerView.setHasFixedSize(true);//every item of the RecyclerView has a fix size 
     recyclerView.setLayoutManager(new LinearLayoutManager(getContext())); 

     cespiteOggList = new ArrayList<>(); 


     // SwipeRefreshLayout 
     mSwipeRefreshLayout = (SwipeRefreshLayout) rootView.findViewById(R.id.swipe_container); 
     mSwipeRefreshLayout.setOnRefreshListener(this); 
     mSwipeRefreshLayout.setColorSchemeResources(R.color.colorPrimary, 
       android.R.color.holo_green_dark, 
       android.R.color.holo_orange_dark, 
       android.R.color.holo_blue_dark); 

     /** 
     * Showing Swipe Refresh animation on activity create 
     * As animation won't start on onCreate, post runnable is used 
     */ 
     mSwipeRefreshLayout.post(new Runnable() { 

      @Override 
      public void run() { 

       mSwipeRefreshLayout.setRefreshing(true); 

       // Fetching data from server 
       loadRecyclerViewData(); 
      } 
     }); 

     return rootView; 
    } 

    /** 
    * This method is called when swipe refresh is pulled down 
    */ 
    @Override 
    public void onRefresh() { 

     // Fetching data from server 
     loadRecyclerViewData(); 
    } 

    private void loadRecyclerViewData() 
    { 
     // Showing refresh animation before making http call 
     mSwipeRefreshLayout.setRefreshing(true); 

     // Session class instance 
     session = new UserSessionManager(getActivity()); 
     //get user data from session 
     HashMap<String, String> user = session.getUserDetails(); 
     //get name 
     String name = user.get(UserSessionManager.KEY_NAME); 
     // get username 
     final String usernameUtente = user.get(UserSessionManager.KEY_USERNAME); 


     StringRequest stringRequest = new StringRequest(Request.Method.POST, 
       URL_DATA, 
       new Response.Listener<String>() { 
        @Override 
        public void onResponse(String s) { 

         try { 
          JSONObject jsonObject = new JSONObject(s); 
          JSONArray array = jsonObject.getJSONArray("dates"); 

          for(int i=0; i<array.length(); i++) 
          { 
           JSONObject o = array.getJSONObject(i); 
           CespiteOgg item = new CespiteOgg(
             o.getString("CodNumInventario"), 
             o.getString("Nome"), 
             o.getString("DtCatalogazione"), 
             o.getString("CodIdA"), 
             o.getString("username") 
           ); 
           cespiteOggList.add(item); 
          } 

          adapter = new CespiteAdapter(cespiteOggList, getActivity()); 
          recyclerView.setAdapter(adapter); 

         } catch (JSONException e) { 
          e.printStackTrace(); 
         } 

         // Stopping swipe refresh 
         mSwipeRefreshLayout.setRefreshing(false); 

        } 
       }, 
       new Response.ErrorListener() { 
        @Override 
        public void onErrorResponse(VolleyError error) { 

         // Stopping swipe refresh 
         mSwipeRefreshLayout.setRefreshing(false); 
        } 
       }) 
     { 
      @Override 
      protected Map<String, String> getParams() throws AuthFailureError { 
       Map<String, String> params = new HashMap<String, String>(); 
       params.put("Username", usernameUtente); 
       return params; 
      } 
     }; 

     RegisterRequest.getmInstance(getActivity()).addToRequestque(stringRequest); 

    } 
} 

Espérons que cela fonctionne correctement.

+0

Merci l'homme, fonctionne comme un charme! – arst3k

0

Tirer pour actualiser la listeVoir & Exemple RecyclerView dans Android Studio - SwipeRefreshLayout.I J'espère que ce code fonctionne correctement, vous pouvez essayer ce code.

Pull de base Actualiser Pour/SwipeRefreshLayout code XML:

<android.support.v4.widget.SwipeRefreshLayout 
     android:id="@+id/simpleSwipeRefreshLayout" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content"> 

     < Add View's Here..../> 
</android.support.v4.widget.SwipeRefreshLayout> 

Ci-dessous vous pouvez télécharger le code, voir la sortie finale et explication étape par étape du Pull de base Pour rafraîchir par exemple.obtenir le code complet avec l'exemple http://abhiandroid.com/materialdesign/pulltorefresh

0

Source Code

https://drive.google.com/open?id=1qjJ_to-1knVNaJB4T3U_L_p_YYNvgAeZ

APK

https://drive.google.com/open?id=1MxQZwjIXgR2jgDkUW1mbFrTLMSaQQisC

public class MainActivity extends AppCompatActivity implements SwipeRefreshLayout.OnRefreshListener { 


    SwipeRefreshLayout mSwipeRefreshLayout; 


     // SwipeRefreshLayout 
     mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_container); 

     mSwipeRefreshLayout.setOnRefreshListener(this); 
//  mSwipeRefreshLayout.setColorSchemeResources(R.color.colorPrimary, 
     mSwipeRefreshLayout.setColorSchemeResources(R.color.colorAccent, 
       android.R.color.holo_green_dark, 
       android.R.color.holo_orange_dark, 
       android.R.color.holo_blue_dark); 

     /** 
     * Showing Swipe Refresh animation on activity create 
     * As animation won't start on onCreate, post runnable is used 
     */ 
     mSwipeRefreshLayout.post(new Runnable() { 

      @Override 
      public void run() { 

       if(mSwipeRefreshLayout != null) { 
        mSwipeRefreshLayout.setRefreshing(true); 
       } 
       // TODO Fetching data from server 
       fetchContacts(); 
      } 
     }); 



    @Override 
    public void onRefresh() { 
     fetchContacts(); 
    }