ViewPager實現微信Tab主界面

首先,我們已經知道微信布局是包含三塊部分,一塊頂部,一塊底部,剩下的就是中間的部分。最終實現的效果就是點擊底部的圖標,中間的內容區域相應變化,圖標顏色也相應的變化;左右滑動內容區域,內容區域變化,底部相應的圖標顏色也相應的變化,在這里我們只講述ViewPager部分,頂部和底部的設計,可以觀看代碼自行了解。

ViewPager

ViewPager的功能就是可以使視圖滑動,使用它需要三個步驟:

1.在布局文件中加入

 <android.support.v4.view.ViewPager
        android:id="@+id/id_viewpager"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="#fff">
    </android.support.v4.view.ViewPager>

2.加載要顯示的頁面

 LayoutInflater mInflater = LayoutInflater.from(this);

        View tab01 = mInflater.inflate(R.layout.tab01, null);
        View tab02 = mInflater.inflate(R.layout.tab02, null);
        View tab03 = mInflater.inflate(R.layout.tab03, null);
        View tab04 = mInflater.inflate(R.layout.tab04, null);
        
//private List<View> mView = new ArrayList<View>();

        mView.add(tab01);
        mView.add(tab02);
        mView.add(tab03);
        mView.add(tab04);

3.在Activity中實例化ViewPager組件,并設置它的PagerAdapter,需要重寫PagerAdapter

 mAdapter = new PagerAdapter() {

            //PagerAdapter只緩存三張要顯示的圖片,如果滑動圖片超出了緩存范圍,就會調用這個方法,將圖片銷毀
            @Override
            public void destroyItem(ViewGroup container, int position, Object object) {

                container.removeView(mView.get(position));
            }

            // 當要顯示的圖片可以進行緩存時,會調用這個方法進行圖片的初始化,我們將要顯示的ImageView加入到ViewGroup,然后作為返回值即可
            @Override
            public Object instantiateItem(ViewGroup container, int position) {

                View view = mView.get(position);
                container.addView(view);
                return view;
            }

            //  需要獲得滑動控件的數量,這里我們以滑動的微信界面為例,那么這里就應該展示的微信界面圖片的ImageView數量
            @Override
            public int getCount() {
                return mView.size();
            }

            //來判斷顯示的是否是同一張圖片,這里我們將兩個參數比較返回即可
            @Override
            public boolean isViewFromObject(View view, Object object) {
                return view == object;
            }
        };

        mViewPager.setAdapter(mAdapter);

ViewPager的適配器就是PagerAdapter,它的基類提供適配器來填充ViewPager內部。其實ViewPager 應該和Fragment一起使用,至少google官方是這么想的,但是在3.0之下,我們沒有必要這樣做。當你實現一個PagerAdapter時,一般至少需要覆蓋以下四種方法:

  • destroyItem(ViewGroup container, int position, Object object)
  • isViewFromObject(View view, Object object)
  • instantiateItem(ViewGroup container, int position)
  • getCount()

4.為底部圖標(ImageView類型)、ViewPager 添加點擊事件

 //點擊事件就是實現tab切換時,下面圖標顏色的變化
   private void initEvents() {

       mTabWeixin.setOnClickListener(this);
       mTabFrd.setOnClickListener(this);
       mTabAdress.setOnClickListener(this);
       mTabSetting.setOnClickListener(this);

       //當ViewPager的內容區域發生變化時,相應的底部圖標也發生變化,重寫onPageSelected方法
       mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
           @Override
           public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

           }

           @Override
           public void onPageSelected(int position) {

               int currentItem = mViewPager.getCurrentItem();
               resetImg();
               switch (currentItem) {
                   case 0:
                       mWeixinImg.setImageResource(R.drawable.tab_weixin_pressed);
                       break;
                   case 1:
                       mFrdImg.setImageResource(R.drawable.tab_find_frd_pressed);
                       break;
                   case 2:
                       mAddressImg.setImageResource(R.drawable.tab_address_pressed);
                       break;
                   case 3:
                       mSettingnImg.setImageResource(R.drawable.tab_settings_pressed);
                       break;
               }
           }

           @Override
           public void onPageScrollStateChanged(int state) {

           }
       });


   }
   
 //用來實現底部圖標點擊事件
    @Override
   public void onClick(View view) {

//實現之前,首先把所有底部圖標變為暗色
       resetImg();
//然后根據點擊的是哪個圖標再進行相應圖標變成亮色
       switch (view.getId()) {
           case R.id.id_tab_weixin:
               //如果點擊的是微信圖標,就跳轉到第一個tab
               mViewPager.setCurrentItem(0);
               mWeixinImg.setImageResource(R.drawable.tab_weixin_pressed);
               break;

           case R.id.id_tab_frd:
               mViewPager.setCurrentItem(1);
               mFrdImg.setImageResource(R.drawable.tab_find_frd_pressed);
               break;

           case R.id.id_tab_address:
               mViewPager.setCurrentItem(2);
               mAddressImg.setImageResource(R.drawable.tab_address_pressed);
               break;

           case R.id.id_tab_setting:
               mViewPager.setCurrentItem(3);
             mSettingnImg.setImageResource(R.drawable.tab_settings_pressed);
               break;
               
           default:
               break;
       }
   }

結果展示


在中間區域可以左右滑動,內容區域會相應的變化,底部按鈕也會相應的變化

工程源碼

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,117評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,860評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,128評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,291評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,025評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,421評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,477評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,642評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,177評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,970評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,157評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,717評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,410評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,821評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,053評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,896評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,157評論 2 375

推薦閱讀更多精彩內容