Android實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)效果
本文實(shí)例為大家分享了Android分頁(yè)效果的具體代碼,供大家參考,具體內(nèi)容如下
1.實(shí)現(xiàn)分頁(yè)最主要的就是封裝分頁(yè)代碼,然后在按鈕里實(shí)現(xiàn)相關(guān)的操作
/**
* 分頁(yè)工具
*
* @Project App_Page
* @Package com.android.dividepage
* @author chenlin
* @version 1.0
* @Date 2012年6月2日
* @Note TODO
* @param <T>
*/
public class PageHelper<T> {
private List<T> allData; // 所有數(shù)據(jù)
private int perPage = 10; // 每頁(yè)條目
private int currentPage = 1;// 當(dāng)前頁(yè)
private int pageNum = 1; // 頁(yè)碼
private List<T> childData;// 子數(shù)據(jù)
private int allNum;// 總共條目
public PageHelper(List<T> datas, int perPage) {
this.allData = datas;
if (perPage > 0)
this.perPage = perPage;
// 如果數(shù)據(jù)大于10條
if (allData != null && allData.size() > perPage) {
childData = allData.subList(0, perPage - 1);
}
allNum = allData.size();
// 如果總數(shù)能除斷perPage,頁(yè)數(shù)就是余數(shù),否則+1
pageNum = allNum % perPage == 0 ? (allNum / perPage) : (allNum / perPage + 1);
}
public int getCount() {
return this.allNum;
}
public int getCurrentPage() {
return this.currentPage;
}
public int getPageNum() {
return this.pageNum;
}
public int getPerPage() {
return this.perPage;
}
public void gotoPage(int n) { // 頁(yè)面跳轉(zhuǎn)
currentPage = n > pageNum ? pageNum : (n < 1 ? 1 : n);
}
public boolean hasNextPage() {// 是否有下一頁(yè)
return currentPage < pageNum;
}
public boolean hasPrePage() {// 是否有前一頁(yè)
return currentPage > 1;
}
public void headPage() {// 第一頁(yè)
currentPage = 1;
}
public void lastPage() {// 最后一頁(yè)
currentPage = pageNum;
}
public void nextPage() {// 下一頁(yè)
currentPage = hasNextPage() ? currentPage + 1 : pageNum;
}
public void prePage() {// 前一頁(yè)
currentPage = hasPrePage() ? currentPage - 1 : 1;
}
public void setPerPage(int perPage) {// 設(shè)置上一頁(yè)面
this.perPage = perPage;
}
/**
* 獲得當(dāng)前數(shù)據(jù)
* @return
*/
public List<T> currentList() {
if (currentPage == 1) {
childData = allData.subList(0, perPage);
} else if (currentPage == pageNum) {
childData = allData.subList(perPage * (pageNum - 1), allNum);
} else {
childData = allData.subList(perPage * (currentPage - 1), perPage * currentPage);
}
return childData;
}
public void setCurrentPage(int currentPage) {
this.currentPage = currentPage;
}
}
2、主頁(yè)里我根據(jù)tab標(biāo)簽把按鈕設(shè)置進(jìn)去,然后在click里方法讀取,最后根據(jù)tag標(biāo)簽就可判斷是哪個(gè)按鈕點(diǎn)擊了
/**
* 分頁(yè)主頁(yè)
* @Project App_Page
* @Package com.android.dividepage
* @author chenlin
* @version 1.0
* @Date 2012年6月2日
* @Note TODO
*/
public class MainActivity extends Activity implements OnClickListener {
private ListView mListView;
//分頁(yè)按鈕
private Button mBtnPrePage, mBtnNextPage, mBtnPreItem, mBtnNextItem;
//顯示分頁(yè)信息
private TextView mTvPageNo;
//數(shù)據(jù)實(shí)現(xiàn)
private PageHelper<String> mPageDaoImpl;
private DataAdapter mAdapter;
private List<String> mDatas;
//被選著的索引
private int selectIndex = 0;
private static final int PREPAGE = 0;
private static final int NEXTPAGE = 1;
private static final int PREITEM = 2;
private static final int NEXTITEM = 3;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initViews();
initDatas();
}
private void initDatas() {
//從資源文件里讀數(shù)據(jù)
mDatas = Arrays.asList(getResources().getStringArray(R.array.channellist));
//每次讀8條數(shù)據(jù)
mPageDaoImpl = new PageHelper<String>(mDatas, 8);
mAdapter = new DataAdapter(this, mPageDaoImpl.currentList());
mListView.setAdapter(mAdapter);
//設(shè)置當(dāng)前頁(yè)碼與總頁(yè)碼
mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
}
private void initViews() {
mListView = (ListView) findViewById(R.id.page_list);
mBtnPrePage = (Button) findViewById(R.id.pre_page);
mBtnPrePage.setTag(PREPAGE);
mBtnPrePage.setOnClickListener(this);
mBtnNextPage = (Button) findViewById(R.id.next_page);
mBtnNextPage.setTag(NEXTPAGE);
mBtnNextPage.setOnClickListener(this);
mBtnPreItem = (Button) findViewById(R.id.pre_item);
mBtnPreItem.setTag(PREITEM);
mBtnPreItem.setOnClickListener(this);
mBtnNextItem = (Button) findViewById(R.id.next_item);
mBtnNextItem.setTag(NEXTITEM);
mBtnNextItem.setOnClickListener(this);
mTvPageNo = (TextView) findViewById(R.id.pagenum);
}
@Override
public void onClick(View v) {
final int flag = (Integer) v.getTag();
switch (flag) {
case PREPAGE:// 首頁(yè)
headPage();
break;
case NEXTPAGE:// 尾頁(yè)
lastPage();
break;
case PREITEM:// 上一條
prePage();
break;
case NEXTITEM:// 下一條
nextPage();
break;
}
}
private void prePage() {
if (selectIndex == 0) {
if (mPageDaoImpl.getCurrentPage() >= 1) {
mPageDaoImpl.prePage();
}
mAdapter.setData(mPageDaoImpl.currentList());
mListView.setSelection(mAdapter.getCount() - 1);
mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
} else {
return;
}
}
private void nextPage() {
if (mPageDaoImpl.getCurrentPage() <= mPageDaoImpl.getPageNum()) {
mPageDaoImpl.nextPage();
}
mAdapter.setData(mPageDaoImpl.currentList());
mListView.setSelection(0);
mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
}
private void lastPage() {
if (mPageDaoImpl.getCurrentPage() != mPageDaoImpl.getPageNum()) {
mPageDaoImpl.lastPage();
}
mAdapter.setData(mPageDaoImpl.currentList());
mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
}
private void headPage() {
if (mPageDaoImpl.getCurrentPage() != 1) {
mPageDaoImpl.headPage();
}
mAdapter.setData(mPageDaoImpl.currentList());
mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
}
}
3、適配器代碼,太簡(jiǎn)單了,我就不說了
public class DataAdapter extends BaseAdapter {
private Context mContext;
private List<String> mDatas;
public DataAdapter(Context context, List<String> datas) {
this.mContext = context;
this.mDatas = datas;
}
@Override
public int getCount() {
return mDatas == null ? 0 : mDatas.size();
}
@Override
public Object getItem(int position) {
return mDatas == null ? null : mDatas.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder mHolder;
if (convertView == null) {
convertView = LayoutInflater.from(mContext).inflate(R.layout.channel_item, parent, false);
mHolder = new ViewHolder();
mHolder.nameView = (TextView) convertView.findViewById(R.id.channel_name);
convertView.setTag(mHolder);
}
mHolder = (ViewHolder) convertView.getTag();
mHolder.nameView.setText(mDatas.get(position));
return convertView;
}
static class ViewHolder {
public TextView nameView;
}
public void setData(List<String> datas) {
mDatas = datas;
notifyDataSetChanged();
}
}
4、代碼下載:http://xiazai.jb51.net/201611/yuanma/AndroidAppPage(jb51.net).rar
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android中實(shí)現(xiàn)多行、水平滾動(dòng)的分頁(yè)的Gridview實(shí)例源碼
- Android中RecyclerView實(shí)現(xiàn)分頁(yè)滾動(dòng)的方法詳解
- Android之ListView分頁(yè)加載數(shù)據(jù)功能實(shí)現(xiàn)代碼
- Android實(shí)現(xiàn)ListView分頁(yè)自動(dòng)加載數(shù)據(jù)的方法
- android實(shí)現(xiàn)listview分頁(yè)的方法
- Android Recyclerview實(shí)現(xiàn)水平分頁(yè)GridView效果示例
- Android提高之SQLite分頁(yè)表格實(shí)現(xiàn)方法
- Android開發(fā)中滑動(dòng)分頁(yè)功能實(shí)例詳解
- Android端代碼量非常小的分頁(yè)加載庫(kù)
相關(guān)文章
Android中dataBinding使用的簡(jiǎn)單封裝
前面一段時(shí)間學(xué)習(xí)了一下Android中的DataBinding,但是只是很簡(jiǎn)單地實(shí)現(xiàn)了一下,DataBinding中最強(qiáng)大的地方還沒有認(rèn)真地學(xué)習(xí)過,有很多地方還不理解,下面這篇文章主要給大家介紹了關(guān)于Android中dataBinding使用的簡(jiǎn)單封裝,需要的朋友可以參考下2023-06-06
Android Bitmap和Drawable的對(duì)比
這篇文章主要介紹了Android Bitmap和Drawable的對(duì)比的相關(guān)資料,需要的朋友可以參考下2017-05-05
Android文件存儲(chǔ)SharedPreferences源碼解析
SharedPreferences是安卓平臺(tái)上一個(gè)輕量級(jí)的存儲(chǔ)類,用來保存應(yīng)用的一些常用配置,比如Activity狀態(tài),Activity暫停時(shí),將此activity的狀態(tài)保存到SharedPereferences中;當(dāng)Activity重載,系統(tǒng)回調(diào)方法onSaveInstanceState時(shí),再?gòu)腟haredPreferences中將值取出2022-08-08
Android實(shí)現(xiàn)底部導(dǎo)航欄效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)底部導(dǎo)航欄效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
Android多線程斷點(diǎn)續(xù)傳下載實(shí)現(xiàn)代碼
這篇文章主要介紹了Android多線程斷點(diǎn)續(xù)傳下載實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
android 中win10 使用uwp控件實(shí)現(xiàn)進(jìn)度條Marquez效果
這篇文章主要介紹了android 中win10 使用uwp控件實(shí)現(xiàn)進(jìn)度條Marquez效果,需要的朋友可以參考下2017-06-06

