編輯:關於Android編程
最近看了幾款APP的加載進度都是這種風格,感覺還不錯,在網上找了一些資料,自己小練兵了一把:

主要運用的開源框架:
/ViewPagerIndicator_library 主要就是tab頁切換指示器
/ptr-lib 進度條 下載地址:https://github.com/liaohuqiu/android-Ultra-Pull-To-Refresh
一、使用方法
布局文件
<?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:background="@color/bg_color"
android:orientation="vertical" >
<in.srain.cube.views.ptr.PtrFrameLayout
xmlns:cube_ptr="http://schemas.android.com/apk/res-auto"
android:id="@+id/material_style_ptr_frame"
android:layout_width="match_parent"
android:layout_height="match_parent"
cube_ptr:ptr_duration_to_close="100"
cube_ptr:ptr_duration_to_close_header="100"
cube_ptr:ptr_keep_header_when_refresh="true"
cube_ptr:ptr_pull_to_fresh="false"
cube_ptr:ptr_ratio_of_header_height_to_refresh="1.2"
cube_ptr:ptr_resistance="1.7" >
<ListView
android:id="@+id/article_listview"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:cacheColorHint="#00000000"
android:divider="@color/line"
android:dividerHeight="10dp" />
</in.srain.cube.views.ptr.PtrFrameLayout>
</LinearLayout>
在java代碼中進行控件聲明,設置相關參數
mPtrFrameLayout = (PtrFrameLayout) mRootView.findViewById(R.id.material_style_ptr_frame);
// header
final MaterialHeader header = new MaterialHeader(getActivity());
int[] colors = getResources().getIntArray(R.array.google_colors);
header.setColorSchemeColors(colors);
header.setLayoutParams(new PtrFrameLayout.LayoutParams(-1, -2));
header.setPadding(0, Utils.dip2px(getActivity(), 15), 0, Utils.dip2px(getActivity(), 10));
header.setPtrFrameLayout(mPtrFrameLayout);
mPtrFrameLayout.setPinContent(true);
mPtrFrameLayout.setLoadingMinTime(100);
mPtrFrameLayout.setDurationToCloseHeader(100);
mPtrFrameLayout.setHeaderView(header);
mPtrFrameLayout.addPtrUIHandler(header);
mPtrFrameLayout.setPtrHandler(new PtrHandler() {
@Override
public boolean checkCanDoRefresh(PtrFrameLayout frame, View content, View header) {
return PtrDefaultHandler.checkContentCanBePulledDown(frame, article_listview, header);
}
@Override
public void onRefreshBegin(final PtrFrameLayout frame) {
pageNum = 1;
doRequest(pageNum, true);
}
});
手動刷新:mPtrFrameLayout.autoRefresh();
結束刷新:mPtrFrameLayout.refreshComplete();
mPtrFrameLayout.setPinContent(true);這裡可以根據個人喜好設置true或者false,true則在刷新的時候,將布局裡的內容固定不動,false則是在刷新的時候進度條會將布局內容擠下來。
監聽ListView是否滑動到底部,如果到達底部,則顯示底部加載更多的進度條。
moreView = Finder.inflate(getActivity(), R.layout.loading_more_footer);
moreView.setVisibility(View.GONE);
article_listview = (ListView) mRootView.findViewById(R.id.article_listview);
article_listview.addFooterView(moreView);
adapter = new ArticleListAdapter(getActivity());
article_listview.setAdapter(adapter);
article_listview.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
Article article = (Article) adapter.getItem(position);
Intent intent = new Intent(getActivity(),
AppBrowserActivity.class);
intent.putExtra("w_url", article.getUrl());
intent.putExtra("share_desc", article.getTitle());
intent.putExtra("share_pic", article.getPicUrl());
startActivity(intent);
}
});
article_listview.setOnScrollListener(new OnScrollListener(){
@Override
public void onScrollStateChanged(AbsListView view, int scrollState){
// 當不滾動時
if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
// 判斷是否滾動到底部
if (view.getLastVisiblePosition() == view.getCount() - 1) {
//加載更多功能的代碼
moreView.setVisibility(View.VISIBLE);
pageNum++;
doRequest(pageNum, false);
}
}
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
// TODO Auto-generated method stub
}
});
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
TextView實戰
寫在前面的話對於TextView,我想大家都已經熟的不能再熟了。但是它的用法我們真的熟麼?為了避免總是一言不合就去翻官方文檔,在這裡我總結一下我也可能是你容易忽視的一些細
Android圖片裁剪功能實現代碼
在Android應用中,圖片裁剪也是一個經常用到的功能。Android系統中可以用隱式意圖調用系統應用進行裁剪,但是這樣做在不同的手機可能表現出不同的效果,甚至在某些奇葩
eclipse再見,android studio 新手入門教程(一)
寫在前面:作為一個剛半只腳踏入android開發的新手,在使用eclipse開發了兩個自我感覺不甚成熟的商城類app之後,遇到了一些問題,總結為如下:1,代碼復用性。fi
Android(Lollipop/5.0) Material Design(四) 創建列表和卡片
在你的應用程序,創建復雜的列表和卡片與材料設計風格,您可以使用RecyclerView和CardView部件。 創建列表RecyclerView組件