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阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容