国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 系統(tǒng) > Android > 正文

Android UI設(shè)計(jì)與開(kāi)發(fā)之ViewPager介紹和簡(jiǎn)單實(shí)現(xiàn)引導(dǎo)界面

2019-10-22 18:28:57
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

做Android開(kāi)發(fā)加起來(lái)差不多也有一年多的時(shí)間了,總是想寫點(diǎn)自己在開(kāi)發(fā)中的心得體會(huì)與大家一起交流分享、共同進(jìn)步,剛開(kāi)始寫也不知該如何下手,仔細(xì)想了一下,既然是剛開(kāi)始寫,那就從一個(gè)軟件給人最直觀的感受——UI設(shè)計(jì)開(kāi)始寫起吧,循序漸進(jìn),娓娓道來(lái)。博主在這里和大家一起學(xué)習(xí),希望能多多支持,話不多說(shuō),下面就開(kāi)始講解UI設(shè)計(jì)的第一篇。           

在講解如何實(shí)現(xiàn)引導(dǎo)界面的效果之前,我想先詳細(xì)介紹一下ViewPager類的使用和說(shuō)明,因?yàn)檫@是開(kāi)發(fā)引導(dǎo)界面最重要的類,沒(méi)有之一。

一、ViewPager實(shí)現(xiàn)的效果圖

 ViewPager,引導(dǎo)界面

二、ViewPager實(shí)現(xiàn)的功能

看到上面的效果圖,想必大家已經(jīng)猜出了這個(gè)類是干嗎用的了,ViewPager類提供了多界面切換的新效果,
新效果有如下特征:
<1>當(dāng)前顯示一組界面中的其中一個(gè)界面;
<2>當(dāng)用戶通過(guò)左右滑動(dòng)界面時(shí),當(dāng)前的屏幕顯示當(dāng)前界面和下一個(gè)界面的一部分;
<3>滑動(dòng)結(jié)束后,界面自動(dòng)跳轉(zhuǎn)到當(dāng)前選擇的界面中。 

三、ViewPager詳細(xì)說(shuō)明

這是谷歌官方給我們提供的一個(gè)兼容低版本安卓設(shè)備的軟件包,里面包囊了只有在安卓3.0以上可以使用的api。而viewpager就是其中之一利用它,我們可以做很多事情,從最簡(jiǎn)單的導(dǎo)航,到頁(yè)面菜單等等。那如何使用它呢,與LisstView類似,我們也需要一個(gè)適配器,他就是PagerAdapter。看一下API的圖片:         

ViewPager,引導(dǎo)界面

四、ViewPager的使用

既然我們已經(jīng)知道了ViewPager類的功能和介紹,那么這個(gè)類到底怎么使用呢?這里我們分三個(gè)步驟來(lái)使用它:
1、在住布局文件里加入。

<android.support.v4.view.ViewPager  //注意這個(gè)組件是用來(lái)顯示左右滑動(dòng)的界面的,如果不加載xml布局文件,他是不會(huì)顯示內(nèi)容的。   android:id="@+id/viewpager"   android:layout_width="wrap_content"   android:layout_height="wrap_content"   android:layout_gravity="center" >  

2、加載要顯示的頁(yè)卡。

LayoutInflater lf = getLayoutInflater().from(this);      view1 = lf.inflate(R.layout.layout1, null);      view2 = lf.inflate(R.layout.layout2, null);      view3 = lf.inflate(R.layout.layout3, null);        viewList = new ArrayList<View>();// 將要分頁(yè)顯示的View裝入數(shù)組中       viewList.add(view1);      viewList.add(view2);      viewList.add(view3);  

3、在Activity里實(shí)例化ViewPager組件,并設(shè)置它的Adapter(就是PagerAdapter,方法與ListView一樣的),在這里一般需要重寫PagerAdapter。

PagerAdapter pagerAdapter = new PagerAdapter() {          @Override        public boolean isViewFromObject(View arg0, Object arg1) {            return arg0 == arg1;        }          @Override        public int getCount() {            return viewList.size();        }          @Override        public void destroyItem(ViewGroup container, int position,            Object object) {          container.removeView(viewList.get(position));          }          @Override        public int getItemPosition(Object object) {            return super.getItemPosition(object);        }          @Override        public CharSequence getPageTitle(int position) {            return titleList.get(position);        }          @Override        public Object instantiateItem(ViewGroup container, int position) {          container.addView(viewList.get(position));          weibo_button=(Button) findViewById(R.id.button1);          weibo_button.setOnClickListener(new OnClickListener() {                        public void onClick(View v) {              intent=new Intent(ViewPagerDemo.this,WeiBoActivity.class);              startActivity(intent);            }          });          return viewList.get(position);        }        };      viewPager.setAdapter(pagerAdapter); 

這是重寫PagerAdapter的一個(gè)方法,我們還可以這樣做:

public class MyViewPagerAdapter extends PagerAdapter{      private List<View> mListViews;            public MyViewPagerAdapter(List<View> mListViews) {        this.mListViews = mListViews;//構(gòu)造方法,參數(shù)是我們的頁(yè)卡,這樣比較方便。       }        @Override      public void destroyItem(ViewGroup container, int position, Object object)  {          container.removeView(mListViews.get(position));//刪除頁(yè)卡       }         @Override      public Object instantiateItem(ViewGroup container, int position) { //這個(gè)方法用來(lái)實(shí)例化頁(yè)卡             container.addView(mListViews.get(position), 0);//添加頁(yè)卡          return mListViews.get(position);      }        @Override      public int getCount() {             return mListViews.size();//返回頁(yè)卡的數(shù)量       }            @Override      public boolean isViewFromObject(View arg0, Object arg1) {              return arg0==arg1;//官方提示這樣寫       }    }  

從上面的圖片可以看到,ViewPager的適配器是PagerAdapter,它是基類提供適配器來(lái)填充頁(yè)面ViewPager內(nèi)部,你很可能想要使用一個(gè)更具體的實(shí)現(xiàn),如FragmentPagerAdapter或FragmentStatePagerAdapter。在這里需要說(shuō)明一下,其實(shí)ViewPager應(yīng)該和Fragment一起使用,至少谷歌官方是這么想的,但是在3.0之下,我們沒(méi)有必要這么做。下面要注意,當(dāng)你實(shí)現(xiàn)一個(gè)PagerAdapter,你必須至少覆蓋以下方法:

instantiateItem(ViewGroup, int)destroyItem(ViewGroup, int, Object)getCount()isViewFromObject(View, Object)

這一篇講解完ViewPager之后,相信大家也應(yīng)該對(duì)它有了一個(gè)初步的認(rèn)識(shí),那么在后面的幾篇文章我們將繼續(xù)圍繞這個(gè)類展開(kāi)下去,希望能幫助大家對(duì)于UI的設(shè)計(jì)和開(kāi)發(fā)也會(huì)有一個(gè)更加深入的了解。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到Android開(kāi)發(fā)頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 长宁县| 罗城| 祁门县| 将乐县| 桐城市| 营口市| 达拉特旗| 石柱| 太保市| 大田县| 南投县| 高青县| 文登市| 佛坪县| 馆陶县| 广河县| 西昌市| 施秉县| 武冈市| 新巴尔虎右旗| 梓潼县| 鹿泉市| 胶州市| 长治市| 三河市| 东乡族自治县| 同心县| 海门市| 吴旗县| 玉山县| 芦山县| 连平县| 平定县| 泰州市| 新郑市| 南江县| 乡宁县| 晋宁县| 富蕴县| 上虞市| 镇坪县|