affichage dynamic en ajoutant «Charger plus d’éléments» à la fin du défilement

J’ai une liste qui récupère les données de la firebase database sqlite par Json.

Je veux en faire une liste dynamic à la fin du défilement, un “charger plus d’éléments” apparaît dans le bas de la liste lors du chargement de plus d’éléments et de les append à l’adaptateur (par exemple 10 éléments à chaque fois). J’ai du mal à implémenter cette fonctionnalité. Je vous prie aider moi avec ceci. Merci.

public class AllProductsActivity extends Activity { ... defining variables...; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); new LoadAllProducts().execute(); } class LoadAllProducts extends AsyncTask { @Override protected void onPreExecute() { super.onPreExecute(); ... progress dialog... } protected Ssortingng doInBackground(Ssortingng... args) { countryList = new ArrayList(); List params = new ArrayList(); JSONObject json = jParser.makeHttpRequest(url_all_products, "GET", params); Log.d("All Products: ", json.toSsortingng()); try { // Checking for SUCCESS TAG int success = json.getInt(TAG_SUCCESS); if (success == 1) { // products found // Getting Array of Products products = json.getJSONArray(TAG_PRODUCTS); // looping through All Products for (int i = 0; i < products.length(); i++) { JSONObject c = products.getJSONObject(i); // Storing each json item in variable String id = c.getString(TAG_PID); String name = c.getString(TAG_NAME); String description = c.getString(TAG_DESCRIPTION); String due_date = c.getString(TAG_DUE_DATE); String staff = c.getString(TAG_STAFF); String status = c.getString(TAG_STATUS); country = new Country(id,name,description, due_date, staff, status); countryList.add(country); } } } catch (JSONException e) { e.printStackTrace(); } return null; } protected void onPostExecute(String file_url) { pDialog.dismiss(); runOnUiThread(new Runnable() { public void run() { displayListView(); } }); } } private void displayListView() { dataAdapter = new MyCustomAdapter(this, R.layout.country_info, countryList); ListView listView = (ListView) findViewById(R.id.listView1); listView.setAdapter(dataAdapter); } private class MyCustomAdapter extends ArrayAdapter { ... blah blah blah ... @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder = null; Log.v("ConvertView", Ssortingng.valueOf(position)); if (convertView == null) { ... blah blah blah ... } return convertView; } } } 

vous essayez le code suivant

 list.setOnScrollListener(new OnScrollListener() { public void onScrollStateChanged(AbsListView view, int scrollState) { } public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) { if(firstVisibleItem+visibleItemCount == totalItemCount && totalItemCount!=0) { if(flag_loading == false) { flag_loading = true; additems(); } } } }); 

Dans additem() ajoutez les 10 éléments suivants à la liste des tableaux et définissez le flag_loading sur false . et appelez notifydatasetchanged . ça devrait marcher.

Il y a la solution, l’activité doit implémenter l’interface AbsListView.OnScrollListener

En activité:

 int currentFirstVisibleItem = 0; int currentVisibleItemCount = 0; int totalItemCount = 0; int currentScrollState = 0; boolean loadingMore = false; Long startIndex = 0L; Long offset = 10L; View footerView; @Override public void onScroll(AbsListView absListView, int firstVisibleItem, int visibleItemCount, int totalItemCount) { this.currentFirstVisibleItem = firstVisibleItem; this.currentVisibleItemCount = visibleItemCount; this.totalItemCount = totalItemCount; } @Override public void onScrollStateChanged(AbsListView absListView, int scrollState) { this.currentScrollState = scrollState; this.isScrollCompleted(); } private void isScrollCompleted() { if (this.currentVisibleItemCount > 0 && this.currentScrollState == SCROLL_STATE_IDLE && this.totalItemCount == (currentFirstVisibleItem + currentVisibleItemCount)) { /*** In this way I detect if there's been a scroll which has completed ***/ /*** do the work for load more date! ***/ if (!loadingMore) { loadingMore = true; new LoadMoreItemsTask(this).execute(); } } } private class LoadMoreItemsTask extends AsyncTask> { private Activity activity; private View footer; private LoadMoreItemsTask(Activity activity) { this.activity = activity; loadingMore = true; footer = activity.getLayoutInflater().inflate(R.layout.base_list_item_loading_footer, null); } @Override protected void onPreExecute() { list.addFooterView(footer); list.setAdapter(adapter); super.onPreExecute(); } @Override protected List doInBackground(Void... voids) { return getNextItems(startIndex, offset); } @Override protected void onPostExecute(List listItems) { if (footer != null) { list.removeFooterView(footer); } list.setAdapter(adapter); loadingMore = false; if (listItems.size() > 0) { startIndex = startIndex + listItems.size(); setItems(listItems); } super.onPostExecute(listItems); } } 

Oncréer:

 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.base_list); list = (ListView) findViewById(R.id.list); list.setOnItemClickListener(this); list.setOnScrollListener(this); footerView = ((LayoutInflater) getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE)).inflate(R.layout.base_list_item_loading_footer, null, false); initAdapter(); new LoadMoreItemsTask(this).execute(); } 

base_list_item_loading_footer.xml

        

J’espère que ça aide.

Le meilleur moyen d’implémenter Dynamic Expandaple LW avec le pied de page expliqué ci-dessous:

 private int firstVisibleItem, visibleItemCount,totalItemCount; expandapleListView.setOnScrollListener(new AbsListView.OnScrollListener() { @Override public void onScroll(AbsListView view, int firstVisibleItemm, int visibleItemCountt, int totalItemCountt) { firstVisibleItem = firstVisibleItemm; visibleItemCount = visibleItemCountt; totalItemCount = totalItemCountt; } @Override public void onScrollStateChanged(AbsListView view, int scrollState) { final int lastItem = firstVisibleItem + visibleItemCount; if (lastItem == totalItemCount && scrollState == SCROLL_STATE_IDLE) { expandapleInt++; new AsyncTask().execute(); //get next 10-20 items(your choice)items } } }); 

Mise en œuvre du pied de page:

Étant donné le code xml, devrait être en bas de la disposition que votre ListView à l’intérieur de lui …

      

Liez-le dans votre activité

 footer = (RelativeLayout) findViewById(R.id.footer); footer.setVisibility(View.GONE); 

onPreExecute

 footer.setVisibility(View.VISIBLE); 

onPostExecute

 footer.setVisibility(View.GONE);