Android基于ListView實現(xiàn)類似Market分頁加載效果示例
本文實例講述了Android基于ListView實現(xiàn)類似Market分頁加載效果。分享給大家供大家參考,具體如下:
最近幾天研究ListView實現(xiàn)分頁加載和滾動加載,發(fā)現(xiàn)可以用listView的OnScroll方法來實現(xiàn),直接上代碼
ListViewScroll.java
package zy.lucifer.ListViewScroll;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AbsListView.OnScrollListener;
import android.widget.LinearLayout.LayoutParams;
public class ListViewScroll extends Activity {
/** Called when the activity is first created. */
private LayoutParams mLayoutParams = new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT);
/**
* 設置布局顯示目標最大化屬性
*/
private LayoutParams FFlayoutParams = new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.FILL_PARENT,
LinearLayout.LayoutParams.FILL_PARENT);
ListView listView ;
private int lastItem = 0;
LinearLayout loadingLayout;
private listViewAdapter adapter;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
listView = (ListView) findViewById(R.id.myList);
Log.i("test", "onCreate(Bundle savedInstanceState)>>>>>>>>>>>>>>>");
// 線性布局
LinearLayout layout = new LinearLayout(this);
// 設置布局 水平方向
layout.setOrientation(LinearLayout.HORIZONTAL);
// 進度條
ProgressBar progressBar = new ProgressBar(this);
// 進度條顯示位置
progressBar.setPadding(0, 0, 15, 0);
// 把進度條加入到layout中
layout.addView(progressBar, mLayoutParams);
// 文本內(nèi)容
TextView textView = new TextView(this);
textView.setText("加載中...");
textView.setGravity(Gravity.CENTER_VERTICAL);
// 把文本加入到layout中
layout.addView(textView, FFlayoutParams);
// 設置layout的重力方向,即對齊方式是
layout.setGravity(Gravity.CENTER);
// 設置ListView的頁腳layout
loadingLayout = new LinearLayout(this);
loadingLayout.addView(layout, mLayoutParams);
loadingLayout.setGravity(Gravity.CENTER);
listView.addFooterView(loadingLayout);
adapter = new listViewAdapter();
listView.setAdapter(adapter);
listView.setOnScrollListener(new OnScrollListener() {
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
// TODO Auto-generated method stub
Log.i("test" , "Scroll>>>first: " + firstVisibleItem + ", visible: " + visibleItemCount + ", total: " + totalItemCount);
lastItem = firstVisibleItem + visibleItemCount - 1;
Log.i("test" , "Scroll>>>lastItem:" + lastItem);
//顯示50條ListItem,即0-49,因為onScroll是在“滑動”執(zhí)行過之后才觸發(fā),所以用adapter.count<=41作條件
int scrolllength=101;
if (adapter.count<=scrolllength) {
if (firstVisibleItem+visibleItemCount==totalItemCount) {
adapter.count += 10;
adapter.notifyDataSetChanged();
listView.setSelection(lastItem);
int currentPage=adapter.count/10;
Toast.makeText(getApplicationContext(), "第"+currentPage+"頁", Toast.LENGTH_LONG).show();
}
}
else {
listView.removeFooterView(loadingLayout);
}
}
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
// TODO Auto-generated method stub
}
});
}
class listViewAdapter extends BaseAdapter {
int count = 10; /* starting amount */
public int getCount() {
return count;
}
public Object getItem(int pos) {
return pos;
}
public long getItemId(int pos) {
return pos;
}
public View getView(int pos, View v, ViewGroup p) {
Log.i("test", "getView>>>pos:" + pos);
TextView view;
if (v == null) {
view = new TextView(ListViewScroll.this);
} else {
view = (TextView) v;
}
view.setText("ListItem " + pos);
view.setTextSize(20f);
view.setGravity(Gravity.CENTER);
view.setHeight(60);
return view;
}
}
}
main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<ListView android:cacheColorHint="#00000000" android:id="@+id/myList"
android:layout_width="fill_parent" android:layout_height="fill_parent"
>
</ListView>
</LinearLayout>
更多關于Android相關內(nèi)容感興趣的讀者可查看本站專題:《Android視圖View技巧總結》、《Android布局layout技巧總結》、《Android圖形與圖像處理技巧總結》、《Android開發(fā)入門與進階教程》、《Android調(diào)試技巧與常見問題解決方法匯總》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結》及《Android控件用法總結》
希望本文所述對大家Android程序設計有所幫助。
- Android端代碼量非常小的分頁加載庫
- android九宮格可分頁加載控件使用詳解
- Android編程實現(xiàn)分頁加載ListView功能示例
- Android中ListView分頁加載數(shù)據(jù)功能實現(xiàn)
- Android之ListView分頁加載數(shù)據(jù)功能實現(xiàn)代碼
- Android實現(xiàn)基于滑動的SQLite數(shù)據(jù)分頁加載技術(附demo源碼下載)
- Android應用中ListView利用OnScrollListener分頁加載數(shù)據(jù)
- Android中ListView如何分頁加載數(shù)據(jù)
- Android實現(xiàn)ListView分頁加載數(shù)據(jù)
相關文章
Android進階CameraX與Camera2使用比對詳解
這篇文章主要為大家介紹了Android進階CameraX與Camera2使用比示例對詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01
Android開發(fā)使用PopupMenu創(chuàng)建彈出式菜單完整實例
這篇文章主要介紹了Android開發(fā)使用PopupMenu創(chuàng)建彈出式菜單,結合完整實例形式分析了Android基于PopupMenu對象創(chuàng)建的彈出式菜單相關操作技巧與注意事項,需要的朋友可以參考下2019-03-03
android?studio?項目?:UI設計高精度實現(xiàn)簡單計算器
這篇文章主要介紹了android?studio?項目?:UI設計高精度實現(xiàn)簡單計算器,自主完成一個簡單APP的設計工作,綜合應用已經(jīng)學到的Android?UI設計技巧,下面來看看實驗實現(xiàn)過程2021-12-12
Android?RecyclerView使用ListAdapter高效刷新數(shù)據(jù)的操作方法
這篇文章主要介紹了Android?RecyclerView使用ListAdapter高效刷新數(shù)據(jù),本次也是介紹了用另外一種方法來實現(xiàn)RecyclerView高效刷新數(shù)據(jù)的功能,需要的朋友可以參考下2022-10-10
Android編程實現(xiàn)帶有單選按鈕和復選按鈕的dialog功能示例
這篇文章主要介紹了Android編程實現(xiàn)帶有單選按鈕和復選按鈕的dialog功能,結合具體實例形式分析了Android實現(xiàn)帶有單選按鈕的dialog對話框及帶有復選按鈕的dialog對話框相關操作技巧,需要的朋友可以參考下2017-09-09
Android+OpenCV4.2.0環(huán)境配置詳解(Android studio)
這篇文章主要介紹了Android+OpenCV4.2.0環(huán)境配置詳解(Android studio),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10

