最近看了幾款APP的加載進度都是這種風格,感覺還不錯,在網(wǎng)上找了一些資料,自己小練兵了一把:
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供鞏義網(wǎng)站建設、鞏義做網(wǎng)站、鞏義網(wǎng)站設計、鞏義網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、鞏義企業(yè)網(wǎng)站模板建站服務,10多年鞏義做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
主要運用的開源框架:
/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代碼中進行控件聲明,設置相關參數(shù)
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);這里可以根據(jù)個人喜好設置true或者false,true則在刷新的時候,將布局里的內(nèi)容固定不動,false則是在刷新的時候進度條會將布局內(nèi)容擠下來。
監(jiān)聽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 } });
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
文章標題:AndroidMaterial加載進度條制作代碼
網(wǎng)站路徑:http://jinyejixie.com/article30/ggegso.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、商城網(wǎng)站、品牌網(wǎng)站設計、外貿(mào)網(wǎng)站建設、網(wǎng)頁設計公司、外貿(mào)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)