Android中viewPager使用指南
viewPager是谷歌官方提供的一種方便實(shí)現(xiàn)頁面滑動(dòng)效果的控件,可以直接使用也可以和fragment聯(lián)合使用。這里只簡單說下直接使用。
使用viewPager的步驟如下:
(1)在布局中放入viewPager的控件
(2)設(shè)置加載到viewPager中的view
(3)編寫viewPager特有的adapter
(4)實(shí)例化viewPager并給他綁定上步設(shè)置的adapter
這個(gè)步驟體現(xiàn)的也是MVC思想,可以參考我之前的文章http://www.dbjr.com.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è)置頁面跳轉(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));
這里為了測試方便,這里在上個(gè)基礎(chǔ)上加入了一個(gè)item,就是三張view循環(huán)播放
用來實(shí)現(xiàn)銜接。當(dāng)向右滑動(dòng)到最后一個(gè)頁面的時(shí)候,將這個(gè)頁指定為第一個(gè)view所在的頁,向左滑動(dòng)到第一個(gè)頁面的時(shí)候,將這個(gè)頁面制定為最后一個(gè)view所在頁。注意這里的view最后一個(gè)不是指數(shù)組的最后一個(gè) 而是指三個(gè)view中最后一個(gè)。
設(shè)置viewPager的實(shí)例化對象的方法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)就可以簡單實(shí)現(xiàn),但在滑動(dòng)時(shí)會(huì)出現(xiàn)有空白頁面的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ì)簡單相冊
- Android ViewPager制作新手導(dǎo)航頁(動(dòng)態(tài)加載)
- Android App中用Handler實(shí)現(xiàn)ViewPager頁面的自動(dòng)切換
- 實(shí)例講解Android中ViewPager組件的一些進(jìn)階使用技巧
- 舉例講解Android中ViewPager中的PagerTitleStrip子控件
- Android App開發(fā)中ViewPager組件的入門使用教程
- Android應(yīng)用中利用ViewPager實(shí)現(xiàn)多頁面滑動(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-01
Android自定義View實(shí)現(xiàn)動(dòng)畫效果詳解
這篇文章主要為大家詳細(xì)介紹了Android如何通過自定義View實(shí)現(xiàn)動(dòng)畫效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-02-02
android效果TapBarMenu繪制底部導(dǎo)航欄的使用方式示例
本篇文章主要介紹了android效果TapBarMenu繪制底部導(dǎo)航欄的使用方式,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01
Android自定義view實(shí)現(xiàn)標(biāo)簽欄功能(只支持固定兩個(gè)標(biāo)簽)
這篇文章主要介紹了Android自定義view實(shí)現(xiàn)標(biāo)簽欄(只支持固定兩個(gè)標(biāo)簽),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
Android實(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-09
flutter Container容器實(shí)現(xiàn)圓角邊框
這篇文章主要為大家詳細(xì)介紹了flutter Container容器實(shí)現(xiàn)圓角邊框,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07

