Android中viewPager使用指南
viewPager是谷歌官方提供的一種方便實(shí)現(xiàn)頁(yè)面滑動(dòng)效果的控件,可以直接使用也可以和fragment聯(lián)合使用。這里只簡(jiǎn)單說下直接使用。
使用viewPager的步驟如下:
(1)在布局中放入viewPager的控件
(2)設(shè)置加載到viewPager中的view
(3)編寫viewPager特有的adapter
(4)實(shí)例化viewPager并給他綁定上步設(shè)置的adapter
這個(gè)步驟體現(xiàn)的也是MVC思想,可以參考我之前的文章http://chabaoo.cn/article/78174.htm
這里為了方便說明 我新建一個(gè)項(xiàng)目來說明viewPager的使用
步驟一 在布局中新建一個(gè)viewPager
布局文件如下:
<android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="match_parent"> </android.support.v4.view.ViewPager>
設(shè)置加載到viewPager中的view
這里為了方便,顯示設(shè)置2個(gè)不同背景的顏色的view,放入viewPager中,每個(gè)view的布局如下圖:
item_one
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@android:color/holo_red_light"> </LinearLayout>
item_two
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@android:color/holo_blue_bright"> </LinearLayout>
編寫viewPager特有的adpter
這里我們繼承viewPager的PagerAdapter,主要重寫getCount方法、destroyItem 、instantiateItem 、isViewFromObject 、。代碼如下:
public class Adapter extends PagerAdapter{ private List<View> views; public Adapter(List<View> views){ this.views = views; } @Override public int getCount() { return views.size(); } @Override public void destroyItem(View arg0, int arg1, Object arg2) { ((ViewPager) arg0).removeView(views.get(arg1)); } @Override public void finishUpdate(View arg0) { } @Override public Object instantiateItem(View arg0, int arg1) { ((ViewPager) arg0).addView(views.get(arg1), 0); return views.get(arg1); } @Override public boolean isViewFromObject(View arg0, Object arg1) { return arg0 == (arg1); // return false; } @Override public void restoreState(Parcelable arg0, ClassLoader arg1) { } @Override public Parcelable saveState() { return null; } @Override public void startUpdate(View arg0) { } }
實(shí)例化viewPager并綁定Adapter
這里,實(shí)例化viewPager 為mpager ,然后將建好的view:item_one 和item_two 通過LayoutInflater加載到建好的View類型的數(shù)組中。將數(shù)組加到List<View>里面。作為參數(shù)傳入到adapter。代碼如下:
private ViewPager mpager; private List<View> myview = new ArrayList<>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mpager = (ViewPager) findViewById(R.id.view_pager); LayoutInflater mInflater = getLayoutInflater(); View [] pagers = {mInflater.inflate(R.layout.item_one ,null), mInflater.inflate(R.layout.item_two , null)}; for(int i = 0; i < pagers.length ; i++) { myview.add(pagers[i]); } Adapter ad = new Adapter(myview); mpager.setAdapter(ad); mpager.setCurrentItem(0); }
PS :實(shí)現(xiàn)viewPager手動(dòng)無限循環(huán)
這里用一種設(shè)置頁(yè)面跳轉(zhuǎn)的方式來實(shí)現(xiàn)無限循環(huán)。在myviews數(shù)組中加入兩個(gè)view,分別在第0個(gè)位置加入最后一個(gè)itemview,和最后一個(gè)位置加入第一個(gè)itemview。代碼如下所示:
final View [] pagers = {mInflater.inflate(R.layout.item_one ,null), mInflater.inflate(R.layout.item_two , null), mInflater.inflate(R.layout.item_three,null)}; for(int i = 0; i < pagers.length ; i++) { myview.add(pagers[i]); } myview.add(0,mInflater.inflate(R.layout.item_three , null)); myview.add(4, mInflater.inflate(R.layout.item_one, null));
這里為了測(cè)試方便,這里在上個(gè)基礎(chǔ)上加入了一個(gè)item,就是三張view循環(huán)播放
用來實(shí)現(xiàn)銜接。當(dāng)向右滑動(dòng)到最后一個(gè)頁(yè)面的時(shí)候,將這個(gè)頁(yè)指定為第一個(gè)view所在的頁(yè),向左滑動(dòng)到第一個(gè)頁(yè)面的時(shí)候,將這個(gè)頁(yè)面制定為最后一個(gè)view所在頁(yè)。注意這里的view最后一個(gè)不是指數(shù)組的最后一個(gè) 而是指三個(gè)view中最后一個(gè)。
設(shè)置viewPager的實(shí)例化對(duì)象的方法setOnPageChangeListener 雖然此方法顯示不推薦使用,但為了實(shí)現(xiàn)這個(gè)功能,還是先將就用吧。等日后谷歌更新viewPager,能有屬性自動(dòng)實(shí)現(xiàn)循環(huán)。
代碼如下:
mpager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { int index = position; if(index == 0){ //注意這里pagers數(shù)組,不是myviews數(shù)組 index = pagers.length; }else if(position == pagers.length + 1){ index = 1; } if(position != index){ mpager.setCurrentItem(index, false); } } @Override public void onPageScrollStateChanged(int state) { } });
重寫Adapter中的instantiateItem 方法來顯示view
public Object instantiateItem(View arg0, int arg1) { if(arg1 == 0){ ((ViewPager) arg0).removeView(views.get(myview.size() - 3)); ((ViewPager) arg0).addView(views.get(myview.size() - 3), 0); }else if(arg1 == myview.size() - 1){ ((ViewPager) arg0).removeView(views.get(0)); ((ViewPager) arg0).addView(views.get(0), 0); }else{ ((ViewPager) arg0).addView(views.get(arg1), 0); } return views.get(arg1); }
這樣無限滑動(dòng)就可以簡(jiǎn)單實(shí)現(xiàn),但在滑動(dòng)時(shí)會(huì)出現(xiàn)有空白頁(yè)面的bug,可能是因?yàn)橄萺emoveView,在加入view的原因。
- Android中ViewPager的PagerTabStrip與PagerTitleStrip用法實(shí)例
- Android中的ViewPager視圖滑動(dòng)切換類的入門實(shí)例教程
- Android實(shí)現(xiàn)千變?nèi)f化的ViewPager切換動(dòng)畫
- Android自定義ViewPager實(shí)現(xiàn)個(gè)性化的圖片切換效果
- Android利用HorizontalScrollView仿ViewPager設(shè)計(jì)簡(jiǎn)單相冊(cè)
- Android ViewPager制作新手導(dǎo)航頁(yè)(動(dòng)態(tài)加載)
- Android App中用Handler實(shí)現(xiàn)ViewPager頁(yè)面的自動(dòng)切換
- 實(shí)例講解Android中ViewPager組件的一些進(jìn)階使用技巧
- 舉例講解Android中ViewPager中的PagerTitleStrip子控件
- Android App開發(fā)中ViewPager組件的入門使用教程
- Android應(yīng)用中利用ViewPager實(shí)現(xiàn)多頁(yè)面滑動(dòng)切換效果示例
- 詳解Android App中創(chuàng)建ViewPager組件的方法
- Android中ViewPager實(shí)現(xiàn)滑動(dòng)條及與Fragment結(jié)合的實(shí)例教程
相關(guān)文章
Android百度地圖定位后獲取周邊位置的實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了Android百度地圖定位后獲取周邊位置的實(shí)現(xiàn)代碼,準(zhǔn)確獲取周邊地理位置,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01Android自定義View實(shí)現(xiàn)動(dòng)畫效果詳解
這篇文章主要為大家詳細(xì)介紹了Android如何通過自定義View實(shí)現(xiàn)動(dòng)畫效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-02-02android效果TapBarMenu繪制底部導(dǎo)航欄的使用方式示例
本篇文章主要介紹了android效果TapBarMenu繪制底部導(dǎo)航欄的使用方式,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01Android自定義view實(shí)現(xiàn)標(biāo)簽欄功能(只支持固定兩個(gè)標(biāo)簽)
這篇文章主要介紹了Android自定義view實(shí)現(xiàn)標(biāo)簽欄(只支持固定兩個(gè)標(biāo)簽),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06Android實(shí)現(xiàn)動(dòng)態(tài)顯示或隱藏密碼輸入框的內(nèi)容
這篇文章主要介紹了Android實(shí)現(xiàn)動(dòng)態(tài)顯示或隱藏密碼輸入框的內(nèi)容,主要通過設(shè)置EditText的setTransformationMethod()方法來實(shí)現(xiàn),需要的朋友可以參考下2014-09-09flutter Container容器實(shí)現(xiàn)圓角邊框
這篇文章主要為大家詳細(xì)介紹了flutter Container容器實(shí)現(xiàn)圓角邊框,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07