Android 5.x Material design 之 Ta

作者: kmzhao | 来源:发表于2015-12-30 19:32 被阅读918次

    Alex_孤独患者

    0__ 说在前边的话

    • 第一次玩这个,有许多不足之处。
      希望大家一起学习Android 5.x ,共同进步。。。
      Go go go ...

    01_ TabLayout的概述 和 效果 图片

    4078BCBB-C202-4234-8CF2-C3914D725255.png
    • 首先呢它是Android 5.0推出的Tab栏,之前呢 我们可能会用三方库,来实现页面切换的效果,诸如ViewPagerIndicator等。现在,Google终于自己推出了,TabLayout来实现页面切换效果。感觉棒棒哒。。。

    02_如何玩这个呢

    • 01首先得加入依赖包,在app/build.gradle 文件中
    dependencies { 
    compile   "com.android.support:appcompatv7:${supportLibVersion}" 
    compile "com.android.support:design:${supportLibVersion}"
    }
    

    注意: ${supportLibVersion} 是根据你自己拥有的版本来填写
    例如: 我的是

      compile 'com.android.support:appcompat-v7:23.1.1'
      compile 'com.android.support:design:23.1.1'
    
    • 02 我们先写布局文件
    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
    android:layout_width="match_parent"    
    android:layout_height="match_parent"    
    android:orientation="vertical">    
         <android.support.design.widget.TabLayout        
              android:id="@+id/tl_sliding"        
              android:layout_width="match_parent"        
              android:layout_height="wrap_content" />    
         <android.support.v4.view.ViewPager        
              android:id="@+id/vp_content"        
              android:layout_width="match_parent"        
              android:layout_height="0dp"        
              android:layout_weight="1">
        </android.support.v4.view.ViewPager>
    </LinearLayout>
    
    • 布局文件问简单, 一个TabLayout: 我们标签指示栏,下面是ViewPager:准备装载Fragment...没错,我们准备TabLayout+ViewPager 来实现最简单的页面切换哦。。。
    • 03 创建填充ViewPager的Fragment
          public class CommonFragment extends Fragment {
                private static final String CF_PAGE = "cf_page";
                private int mPage;
                //初始化Fragment
                public static CommonFragment newInstance(int page) {
                              Bundle args = new Bundle();
                              args.putInt(CF_PAGE, page);
                              CommonFragment fragment = new CommonFragment();
                              fragment.setArguments(args);
                              return fragment;
                }
              @Override
                public void onCreate(@Nullable Bundle savedInstanceState) {  
                      super.onCreate(savedInstanceState);   
                      mPage = getArguments().getInt(CF_PAGE);
                }
    //
                @Override
                public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {    
                          TextView tv = new TextView(getActivity());                                            
                          tv.setText("fragments---" + mPage);  
                          return tv;
                 }
    

    简书的代码,写的我好蛋疼啊。。。怎么格式化。。。累死宝宝了。。。

    • 04 创建ViewPager的适配器FragmentPagerAdapter
    public class PagerAdaper extends FragmentPagerAdapter {  
              /** 标题栏 */ 
              private static final String[] mTitles = {"tab0","tab1", "tab2", "tab3", "tab4", "tab5", "tab6"};   
              public PagerAdaper(FragmentManager fm) {   
                     super(fm);    
              } 
               @Override   
               public Fragment getItem(int position) {  
                    return CommonFragment.newInstance(position); 
               }    
              @Override    
              public int getCount() {    
                  return mTitles.length;
              }   
              //设置标题
             @Override 
             public CharSequence getPageTitle(int position) {
                      return mTitles[position];
              }}
    

    已经无力吐槽~~ 这段代码很简单,主要的方法是getPageTitle(position) ,通过这个方法,可以给Tab设置标题

    • 05 最后,看看MainActivity中的代码
    public class MainActivity extends FragmentActivity {   
           @Override    
           protected void onCreate(Bundle savedInstanceState) {              
                    super.onCreate(savedInstanceState);        
                    setContentView(R.layout.activity_main);       
                    ViewPager vp_content = (ViewPager) findViewById(R.id.vp_content);
                    TabLayout tl_sliding = (TabLayout) findViewById(R.id.tl_sliding); 
                   vp_content.setAdapter(new PagerAdaper(getSupportFragmentManager()));        
                  /**让标题栏和viewpager联动起来*/        
                  tl_sliding.setupWithViewPager(vp_content);
            }}
    

    **当然,如果给TabLayout设置方法,tl_sliding.setTabMode(TabLayout.MODE_SCROLLABLE);标题栏就可以自动滚动起来了,如图所示: **

    10EDE03D-3F93-4543-B706-D11BD9C299B0.png

    最后 ,当然TabLayout的进阶,明天再写咯。。。晚安咯。。。 可以看第二篇 文章~

    Android 5.x Material design 之 TabLayout02

    相关文章

      网友评论

      • Bui_vlee:为什么我用tablayout标签不是在左边就是在中间挤着呢,求助啊
        hackware:@任振胨 TabLayout太弱了,可以试试 https://github.com/hackware1993/MagicIndicator

      本文标题:Android 5.x Material design 之 Ta

      本文链接:https://www.haomeiwen.com/subject/uevihttx.html