Android使用ViewPager實(shí)現(xiàn)導(dǎo)航
首先先了解ViewPager實(shí)現(xiàn)的出效果是能夠使視圖左右滑動(dòng)。
ViewPager在XML文件中的聲明和其他一些控件的聲明有點(diǎn)兒不一樣
而android.support.v4.view是Android界面特殊效果的第三方加載的jar包,能夠向下兼容。
<android.support.v4.view.ViewPager ... ... > </android.support.v4.view.ViewPager>
加載顯示的頁卡:需要將layout布局文件轉(zhuǎn)型為View對(duì)象
(1) LayoutInflater lf = getLayoutInfalter().from(this); lf.inflate(resource,root);
(2) View.inflate(context,resource,root); PagerTabStrip 和 PagerTitleStrip
看命名也能夠知道,這倆用來設(shè)置Title的就像微信主界面底部顯示的目錄(微信、通訊錄、發(fā)現(xiàn)、我)一樣,能夠?qū)Ш接脩羲降捻撁鎀itle。
<android.support.v4.view.ViewPager ... > <android.support.v4.view.PagerTabStrip ... ... > </android.support.v4.view.PagerTabStrip> </android.support.v4.view.ViewPager> <!-- PagerTitleStrip的定義也和PagerTabTitle一樣,在ViewPager中 -->
一般在使用時(shí),二者取一用即可,如果兩者同時(shí)使用,PagerTabStrip會(huì)失效
當(dāng)然,PagerTabStrip 和 PagerTitleStrip也通過設(shè)置一些屬性來美化導(dǎo)航目錄
private PagerTabStrip tabStrip;
tabStrip = (PagerTabStrip) findViewById(R.id.tabStrip);
tabStrip.setBackgroundColor(Color.GRAY);
tabStrip.setTextColor(Color.BLACK);
tabStrip.setDrawFullUnderline(false);
tabStrip.setTabIndicatorColor(Color.GREEN);
對(duì)于ViewPager對(duì)應(yīng)的有三種不同的適配器,所對(duì)應(yīng)的數(shù)據(jù)源也有所不同
(1)PagerAdapter ---- 數(shù)據(jù)源:List<View>
package com.Liuyt.s03_e19_viewpager;
import java.util.List;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
public class MyPagerAdapter extends PagerAdapter {
private List<View> viewList;
private List<String> titleList;
public MyPagerAdapter(List<View> viewList, List<String> titleList) {
this.viewList = viewList;
this.titleList = titleList;
}
/*
* 得到頁卡的數(shù)量
*/
@Override
public int getCount() {
// TODO Auto-generated method stub
return viewList.size();
}
/*
* 判斷View是否屬于Object對(duì)象
*/
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
// TODO Auto-generated method stub
return arg0 == arg1;
}
/*
* 實(shí)例化一個(gè)頁卡
*/
@Override
public Object instantiateItem(ViewGroup container, int position) {
// TODO Auto-generated method stub
container.addView(viewList.get(position));
return viewList.get(position);
}
/*
* 銷毀一個(gè)頁卡
*/
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// TODO Auto-generated method stub
container.removeView(viewList.get(position));
}
/*
* 設(shè)置viewPager的標(biāo)題
*/
@Override
public CharSequence getPageTitle(int position) {
// TODO Auto-generated method stub
return titleList.get(position);
}
}
(2)FragmentPagerAdapter ---- 數(shù)據(jù)源:List<Fragment>
package com.Liuyt.s03_e19_viewpager;
import java.util.List;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
public class MyFragmentPagerAdapter extends FragmentPagerAdapter{
private List<Fragment>fragList;
private List<String>titleList;
public MyFragmentPagerAdapter(FragmentManager fm,List<Fragment>fragList,List<String>titleList) {
super(fm);
// TODO Auto-generated constructor stub
this.fragList = fragList;
this.titleList = titleList;
}
@Override
public Fragment getItem(int arg0) {
// TODO Auto-generated method stub
return fragList.get(arg0);
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return fragList.size();
}
@Override
public CharSequence getPageTitle(int position) {
// TODO Auto-generated method stub
return titleList.get(position);
}
}
(3)FragmentStatePagerAdapter ---- 數(shù)據(jù)源:List<Fragment>
這兒就不貼代碼了,F(xiàn)ragmentStatePagerAdapter的代碼和FragmentPagerAdapter 的代碼差不很多,兩者差別在于一個(gè)在滑動(dòng)之后會(huì)調(diào)用destroy的方法銷毀頁卡,而另一個(gè)并不會(huì)對(duì)頁卡進(jìn)行銷毀。
最后是監(jiān)聽器,ViewPager使用OnPagerChangeListener監(jiān)聽器來監(jiān)聽所滑動(dòng)到的是哪個(gè)頁面,中間常用的方法是public void onPagerSelected(int arg0){}
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!
- Android中TabLayout+ViewPager 簡(jiǎn)單實(shí)現(xiàn)app底部Tab導(dǎo)航欄
- Android自定義ViewPagerIndicator實(shí)現(xiàn)炫酷導(dǎo)航欄指示器(ViewPager+Fragment)
- Android動(dòng)態(tài)給ViewPager添加Indicator導(dǎo)航
- Android 利用ViewPager+GridView實(shí)現(xiàn)首頁導(dǎo)航欄布局分頁效果
- Android 中 TabHost與ViewPager結(jié)合實(shí)現(xiàn)首頁導(dǎo)航效果
- ViewPager頂部導(dǎo)航欄聯(lián)動(dòng)效果(標(biāo)題欄條目多)
- Android 開發(fā)之BottomBar+ViewPager+Fragment實(shí)現(xiàn)炫酷的底部導(dǎo)航效果
- Android ViewPager制作新手導(dǎo)航頁(動(dòng)態(tài)加載)
- Android ViewPager導(dǎo)航小圓點(diǎn)實(shí)現(xiàn)無限循環(huán)效果
相關(guān)文章
Android判斷服務(wù)是否運(yùn)行及定位問題實(shí)例分析
這篇文章主要介紹了Android判斷服務(wù)是否運(yùn)行及定位問題,以實(shí)例形式較為詳細(xì)的分析了Android判斷服務(wù)運(yùn)行狀態(tài)及獲取經(jīng)緯度的相關(guān)實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
Android應(yīng)用開發(fā)中使用GridView網(wǎng)格布局的代碼示例
GridView布局比較基礎(chǔ),可以取代已經(jīng)逐漸淡出人們視線的TableLayout,這里我們就來看一下Android應(yīng)用開發(fā)中使用GridView網(wǎng)格布局的代碼示例:2016-06-06
Android Handler消息派發(fā)機(jī)制源碼分析
這篇文章主要為大家詳細(xì)分析了Android Handler消息派發(fā)機(jī)制源碼,感興趣的小伙伴們可以參考一下2016-07-07
Android數(shù)據(jù)加密之SHA安全散列算法
這篇文章主要為大家詳細(xì)介紹了Android數(shù)據(jù)加密之SHA安全散列算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
Android自定View實(shí)現(xiàn)滑動(dòng)驗(yàn)證效果的代碼
這篇文章主要介紹了Android自定View實(shí)現(xiàn)滑動(dòng)驗(yàn)證效果,代碼分為自定義屬性代碼和自定義view代碼及使用方法,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-12-12
在Android里完美實(shí)現(xiàn)基站和WIFI定位

