android TabLayout使用方法详解

 更新时间:2016年08月30日 16:32:52   作者:xiangzhihong8  
这篇文章主要为大家详细介绍了android TabLayout使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Google在2015的IO大会上,给我们带来了更加详细的Material Design设计规范,同时,也给我们带来了全新的Android Design Support Library,在这个support库里面,Google给我们提供了更加规范的MD设计风格的控件。最重要的是,Android Design Support Library的兼容性更广,直接可以向下兼容到Android 2.2。

这两天需要做一个仿京东详情的页面,上面的Tab切换,以前都是自己写Viewpager+fragment,或者Indicator的深度定制,一直想尝试一下TabLayout,于是就有了下面的坑。


然后下面是我简单的实现效果(个人觉得很坑,还不如自己自定义的导航器)


添加引用库

dependencies {
  compile fileTree(dir: 'libs', include: ['*.jar'])
  compile 'com.android.support:appcompat-v7:24.2.0'
  compile 'com.android.support:design:24.2.0'
  compile 'com.android.support:recyclerview-v7:24.2.0'
  compile 'com.android.support:cardview-v7:24.2.0'
}

Toolbar与TabLayout

我们来看一下实现的布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical">

  <android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="48dp"
    android:gravity="center_vertical"
    app:navigationIcon="@drawable/back_icon"
   >

    <LinearLayout
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:gravity="center"
      android:orientation="horizontal">

      <android.support.design.widget.TabLayout
        android:id="@+id/tabLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        style="@style/style_c7_s20"
        />

    </LinearLayout>

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_gravity="right"
      android:background="@drawable/more_icon" />

  </android.support.v7.widget.Toolbar>

  <View style="@style/horizontal_line" />

  <android.support.v4.view.ViewPager
    android:id="@+id/viewPager"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />
</LinearLayout>

这布局文件最关键的一点就是android.support.design.widget.TabLayout 标签中的app:tabMode=”scrollable”,他设置tab的模式为“可滑动的”。

其他的用法和Indicator的用法差不多,都需要设置适配器,然后通过数据实现页面的适配。直接上代码

Adapter

public class ProductDetailPagerAdapter extends FragmentPagerAdapter {

  private List<String> mTitles;

  public ProductDetailPagerAdapter(FragmentManager fm, List<String> mTitles) {
    super(fm);
    this.mTitles = mTitles;
  }

  @Override
  public Fragment getItem(int position) {
    if (position == 0) {
      return new ProductFragment();
    } else if (position == 1) {
      return new ProductDetailFragment();
    }
    return new ProductFragment();
  }

  @Override
  public int getCount() {
    return mTitles.size();
  }

  @Override
  public CharSequence getPageTitle(int position) {
    return mTitles.get(position);
  }
}

主页面的相关逻辑,这里的Fragment就是简单的Fragment。

public class ProductDetailsActivity extends BaseActivity {

  @BindView(R.id.viewPager)
  ViewPager viewPager;
  @BindView(R.id.tabLayout)
  TabLayout tabLayout;
  @BindView(R.id.toolbar)
  Toolbar toolbar;

  private TextView tabProduct;
  private TextView tabDetail;

  private List<String> mTitles = null;
  private ProductDetailPagerAdapter productPagerAdapter = null;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_product_details);
    ButterKnife.bind(this);
    init();
  }

  private void init() {
    initToolbar();
    initViewPager();
  }

  private void initToolbar() {
    setTitle("");
    toolbar.setNavigationOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View view) {
        finish();
      }
    });
    initTab();
    initTabChange();
  }

  private void initTabChange() {
    tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
      @Override
      public void onTabSelected(TabLayout.Tab tab) {
        viewPager.setCurrentItem(tab.getPosition());
        switch (tab.getPosition()){
          case 0:
            tabProduct.setTextColor(getResources().getColor(R.color.c8));
            tabProduct.setTextSize(18);
            break;

          case 1:
            tabDetail.setTextColor(getResources().getColor(R.color.c8));
            tabDetail.setTextSize(18);
            break;
        }
      }

      @Override
      public void onTabUnselected(TabLayout.Tab tab) {
        tabProduct.setTextColor(getResources().getColor(R.color.c7));
        tabDetail.setTextColor(getResources().getColor(R.color.c7));
      }

      @Override
      public void onTabReselected(TabLayout.Tab tab) {

      }
    });
  }

  private void initTab() {
    tabLayout.setSelectedTabIndicatorColor(getResources().getColor(R.color.c8));
    tabLayout.setSelectedTabIndicatorHeight(UIUtils.dp2px(this, 2));
    tabLayout.setTabTextColors(R.color.c7, R.color.c8);

    tabLayout.addTab(tabLayout.newTab().setCustomView(R.layout.item_detail_tab_product_layout));
    tabProduct= (TextView) findViewById(R.id.tab_product);
    tabProduct.setTextColor(getResources().getColor(R.color.c8));

    tabLayout.addTab(tabLayout.newTab().setCustomView(R.layout.item_detail_tab_detail_layout));
    tabDetail= (TextView) findViewById(R.id.tab_detail);
    tabProduct.setTextColor(getResources().getColor(R.color.c7));
    
  }

  private void initViewPager() {
    mTitles = new ArrayList<>();
    mTitles.add("商品");
    mTitles.add("详情");
    productPagerAdapter = new ProductDetailPagerAdapter(getSupportFragmentManager(), mTitles);
    viewPager.setAdapter(productPagerAdapter);
    viewPager.addOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
      @Override
      public void onPageSelected(int position) {
        tabLayout.getTabAt(position).select();
      }
    });
  }


  public static void open(Context context) {
    Intent intent = new Intent(context, ProductDetailsActivity.class);
    context.startActivity(intent);
  }
}

我相信很多人看了上面的代码会觉得很麻烦,其实我也觉得,这种虽然可定制高,但是相对于以前的写法,代码丝毫没有减少,我还是建议使用自定义控件,之前有一篇Android万能的指示器,大家可以借鉴借鉴。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android 读取资源文件实例详解

    Android 读取资源文件实例详解

    这篇文章主要介绍了Android 读取资源文件实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • Android实现GPS定位代码实例

    Android实现GPS定位代码实例

    这篇文章主要介绍了Android实现GPS定位实例,对关键操作部份给出代码示例并做了一定的注释,需要的朋友可以参考下
    2014-07-07
  • Android 判断日期是否在一年以内的算法实例

    Android 判断日期是否在一年以内的算法实例

    下面小编就为大家带来一篇Android 判断日期是否在一年以内的算法实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • Android实现弹出登陆框的方案

    Android实现弹出登陆框的方案

    最近在做一个项目,要用到登陆框,几经波折,最后用的是直接将Activity的Theme属性设置成Dialog,然后达到了我想要的效果。
    2014-07-07
  • Android用户注册界面简单设计

    Android用户注册界面简单设计

    这篇文章主要为大家分享了Android用户注册界面简单设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • 从源码角度分析Android的消息机制

    从源码角度分析Android的消息机制

    这篇文章主要介绍了从源码角度分析Android的消息机制,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下
    2021-03-03
  • Android 仿微信数字键盘

    Android 仿微信数字键盘

    大部分的金融App会对默认的数字键盘进行处理,以实现自定义的数字安全键盘。基于此,本文对对微信数字键盘样式进行了仿写,实现了一套自定义的数字安全键盘(支持随机数字分布)。
    2021-05-05
  • Flutter实现文本滚动高亮效果的示例讲解

    Flutter实现文本滚动高亮效果的示例讲解

    这篇文章主要介绍了如何利用Flutter时时渲染页面从而达到文本滚动高亮的效果,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2022-03-03
  • Cocos2d-x的内存管理总结

    Cocos2d-x的内存管理总结

    这篇文章主要介绍了Cocos2d-x的内存管理总结,详解探讨了手工对象内存管理、自动对象内存管理、自动释放的时机等问题,需要的朋友可以参考下
    2014-04-04
  • Android中Glide加载圆形图片和圆角图片实例代码

    Android中Glide加载圆形图片和圆角图片实例代码

    本篇文章主要介绍了Android中Glide加载圆形图片和圆角图片实例代码,具体一定的参考价值,有兴趣的可以了解一下
    2017-05-05

最新评论