Tablayout简单使用方法总结

本文为大家分享了Tablayout简单的使用方法,供大家参考,具体内容如下

一、TabLayout普通用法

在项目中使用viewpager的时候大多数都是和TabPagerIndicator结合使用,TabPagerIndicator是第三方的,使用起来比较繁琐;

2015谷歌大会官方发布了TabLayout,可以很简单很完美的实现这种效果;

因为是官方发布的,所以使用起来不用任何第三方的东西;而且非常简单明了;

同样,如果想要使用Tablayout必须在build中配置:

dependencies {
 compile 'com.android.support:design:23.1.1'
}

先看下布局:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context="www.tablayout.com.tablayoutdemo.MainActivity"> 

 <!--
 app:tabIndicatorColor="@color/white" // 下方滚动的下划线颜色
 app:tabSelectedTextColor="@color/gray" // tab被选中后,文字的颜色
 app:tabTextColor="@color/white" // tab默认的文字颜色
 app:tabMode="scrollable" //设置标题滑动模式
 -->
 <android.support.design.widget.TabLayout
 android:id="@+id/tablayout"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:background="@android:color/holo_blue_light"
 app:tabIndicatorColor="@android:color/holo_red_dark"
 app:tabSelectedTextColor="@android:color/holo_red_dark"
 app:tabTextColor="@android:color/background_dark"
 app:tabMode="scrollable"
 /> 

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

</LinearLayout>

代码使用起来也非常简单

第一步:初始化ViewPager并设置adapter
第二步:给Tablayout设置标题
第三步:将Tablayout和ViewPager关联到一起

//第一步:初始化ViewPager并设置adapter
 viewPager = (ViewPager) findViewById(R.id.viewpager);
 viewPager.setAdapter(new MyViewPagerAdapter(getSupportFragmentManager(), fragmentList)); 

 //第二步:初始化Tablayout,给ViewPager设置标题(选项卡)
 tabLayout = (TabLayout) findViewById(R.id.tablayout); 

 tabLayout.addTab(tabLayout.newTab().setText("UFC"));//添加tab选项卡
 tabLayout.addTab(tabLayout.newTab().setText("武林风"));
 tabLayout.addTab(tabLayout.newTab().setText("昆仑决"));
 tabLayout.addTab(tabLayout.newTab().setText("荣耀"));
 tabLayout.addTab(tabLayout.newTab().setText("勇士的崛起"));
 tabLayout.addTab(tabLayout.newTab().setText("K-1")); 

 //第三步:关联ViewPager
 tabLayout.setupWithViewPager(viewPager);

好了,正常情况下就到此结束了,但是我在写这个demo的时候碰到一个坑:
标题死活显示不出来,浪费了很长时间,最后在Tablayout关联Viewpager之后添加从新设置下标题即可:

//在关联ViewPager之后添加如下代码,前三步不用更改
 tabLayout.getTabAt(0).setText("UFC");
 tabLayout.getTabAt(1).setText("武林风");
 tabLayout.getTabAt(2).setText("昆仑决");
 tabLayout.getTabAt(3).setText("荣耀");
 tabLayout.getTabAt(4).setText("勇士的崛起");
 tabLayout.getTabAt(5).setText("K-1");

总体来说Tablayout完全可以代替TabPagerIndicator,而且使用起来比较简单,最重要的还是官方的;

二、Tablayout下划线宽度更改方法:

首先说明:Google官方没有给我们提供更改下划线的宽度的方法;
我们可以通过其他方法更改:(两步)
1.首先定义setIndicator()方法

public void setIndicator(TabLayout tabs,int leftDip,int rightDip){
 Class<?> tabLayout = tabs.getClass();
 Field tabStrip = null;
 try {
 tabStrip = tabLayout.getDeclaredField("mTabStrip");
 } catch (NoSuchFieldException e) {
 e.printStackTrace();
 } 

 tabStrip.setAccessible(true);
 LinearLayout llTab = null;
 try {
 llTab = (LinearLayout) tabStrip.get(tabs);
 } catch (IllegalAccessException e) {
 e.printStackTrace();
 } 

 int left = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, leftDip, Resources.getSystem().getDisplayMetrics());
 int right = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, rightDip, Resources.getSystem().getDisplayMetrics()); 

 for (int i = 0; i < llTab.getChildCount(); i++) {
 View child = llTab.getChildAt(i);
 child.setPadding(0, 0, 0, 0);
 LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(0, LinearLayout.LayoutParams.MATCH_PARENT, 1);
 params.leftMargin = left;
 params.rightMargin = right;
 child.setLayoutParams(params);
 child.invalidate();
 }
}

2.在关联ViewPager之前添加

tabLayout.post(new Runnable() {
 @Override
 public void run() {
 setIndicator(tabLayout,25,25);
 }
 });

最后记得更改滑动方式:   app:tabMode="fixed"
左右距离可根据自己项目设置;(更改下划线宽度需在第一步(Tablayout普通用法)的基础上更改使用)

三、更改标签对齐方式

在xml文件中:
删除 app:tabMode="" ;
添加 app:tabGravity="center" ;
还可以通过   app:tabMaxWidth="150dp"  限制标签宽度
(更改更改标签对齐方式需在第一步(Tablayout普通用法)的基础上更改使用)

四、标题之间添加分割线;

1.在drawable文件夹下创建 shape

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
 <solid android:color="#aa00ff00" />
 <size android:width="1dp"/>
</shape>

2,在主类设置完tablayout后添加如下代码:

LinearLayout linearLayout = (LinearLayout) tabLayout.getChildAt(0);
linearLayout.setShowDividers(LinearLayout.SHOW_DIVIDER_MIDDLE);
linearLayout.setDividerDrawable(ContextCompat.getDrawable(this, R.drawable.layout_divider_vertical));
linearLayout.setDividerPadding(15);

点击打开链接免费下载源码

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

(0)

相关推荐

  • android TabLayout使用方法详解

    Google在2015的IO大会上,给我们带来了更加详细的Material Design设计规范,同时,也给我们带来了全新的Android Design Support Library,在这个support库里面,Google给我们提供了更加规范的MD设计风格的控件.最重要的是,Android Design Support Library的兼容性更广,直接可以向下兼容到Android 2.2. 这两天需要做一个仿京东详情的页面,上面的Tab切换,以前都是自己写Viewpager+fragment

  • TabLayout使用方法详解

    TabLayout是design库提供的控件,可以方便的使用指示器,功能类似ViewPagerIndicator. 使用非常方便,Android Studio只需要在gradle中引入即可使用 . compile 'com.android.support:design:23.3.0' TabLayout即可以单独使用,也可以配合ViewPager来使用. 先来看看单独使用的Demo,实现如下图的效果: 代码如下: package blog.csdn.net.mchenys.tablayoudem

  • Android使用TabLayout+Fragment实现顶部选项卡

    先看效果图: 使用Tablayout,首先需要在项目中加入Design包 dependencies { compile 'com.android.support:design:24.1.1' } 在activity_main.xml布局文件中 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/

  • Android MarginDesign控件TabLayout导航栏使用详解

    TabLayout的使用简单介绍 比如在平常的项目中实现这样的效果,一般都是都会使用viewPageIndicate等几个开源框架直接实现,或者使用自定义的HorizontalScroll再配合ViewPage+Fragment实现.在谷歌推出marginDesign之后,实现这种效果可以直接使用TabLayout实现.另外Tablayout可以通过自定义View自定义导航栏的效果.这样使用的时候更加灵活多变. 首先需要导入design包 在app的build.gradle下添加design的包

  • Tablayout简单使用方法总结

    本文为大家分享了Tablayout简单的使用方法,供大家参考,具体内容如下 一.TabLayout普通用法 在项目中使用viewpager的时候大多数都是和TabPagerIndicator结合使用,TabPagerIndicator是第三方的,使用起来比较繁琐: 2015谷歌大会官方发布了TabLayout,可以很简单很完美的实现这种效果: 因为是官方发布的,所以使用起来不用任何第三方的东西:而且非常简单明了: 同样,如果想要使用Tablayout必须在build中配置: dependenci

  • AngularJS表格样式简单设置方法示例

    本文实例讲述了AngularJS表格样式简单设置方法.分享给大家供大家参考,具体如下: 1.问题背景 AngularJS表格table,利用样式设置表格间隔色 2.实现源码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>AngularJS之表格设置样式</title> <link rel="stylesheet" h

  • ASP.Net MVC_DotNetZip简单使用方法,解决文件压缩的问题

    准备工作: 在vs工具栏中找到NuGet 下载DotNetZip 现在就可以使用DotNetZip强大的类库了,在这里我给出一些简单的使用. public ActionResult Export() { using (ZipFile zip = new ZipFile(System.Text.Encoding.Default)) { zip.AddFile(Server.MapPath("~/Img/2.png"), "Images"); zip.AddFile(S

  • Android开发之背景动画简单实现方法

    本文实例讲述了Android开发之背景动画简单实现方法.分享给大家供大家参考,具体如下: 1.先创建动画层,有三张图片 <?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" > <item android:drawable="@draw

  • jQuery获取多种input值的简单实现方法

    获取input的checked值是否为true: 第一种: if($("input[name=item][value='val']").attr('checked')==true) //判断是否已经打勾 --注:name即控件name属性,value即控件value属性 第二种: 可以不指定属性值,因一组checkbox的value值都会保存其在数据库中对应的id,最好写成如下方式: if($("input[name=row_checkbox]").attr('ch

  • 轮播的简单实现方法

    1.闪现方式的轮播 不论述,实现比较简单,效果也比较好 2.滑动轮播 以下面的html代码为例(向左滑动) <div class="example" style="overflow: hidden; width: 266px;"> <ul style="width: 798px; float: left; height: 216px; margin-left: 0px;"> <li style="width

  • jquery获取复选框checkbox的值的简单实现方法

    jQuery API : each(callback) :以每一个匹配的元素作为上下文来执行一个函数. :checked :匹配所有选中的被选中元素(复选框.单选框等,不包括select中的option) js: //js获取复选框值 var obj = document.getElementsByName("interest");//选择所有name="interest"的对象,返回数组 var s='';//如果这样定义var s;变量s中会默认被赋个null值

  • JavaScript对象封装的简单实现方法(3种方法)

    本文实例讲述了JavaScript对象封装的简单实现方法.分享给大家供大家参考,具体如下: Javascript在HTML中变得越来越强大,富客户端,HTML5中的WebGL等.但是我们书写Javascript的时候往往很随意,使用对象的封装是极好的.这里介绍Javascipt三种创建对象的方法. 1. 使用关键字new创建对象 function Person(name, age) { this.name = name; this.age = age; } var p = new Person(

  • JS二叉树的简单实现方法示例

    本文实例讲述了JS二叉树的简单实现方法.分享给大家供大家参考,具体如下: 今天学习了一下 二叉树的实现,在此记录一下 简单的二叉树实现,并且实现升序和降序排序输出 function Node(data , left,right){ this.data = data; this.left = left; this.right = right; this.show = show; function show(){ return this.data; } }; function Bst(){ this

  • Nginx负载均衡配置简单配置方法

    背景 当一个网站从小到大,访问量逐渐增大现有的服务器已经支撑不住,一般的解决方案就是缓存.加服务器.数据库读写分离.实行负载均衡分布式等等,本人对这些技术方案都没有在项目中具体的实践过, 但是一直听同事过说起,利用空闲时间自我学习了解下: 负载均衡 什么是负载均衡,就是当快要承受不住的时候,又给你一台服务器来分担压力,请求会分配到两台服务器上,两台服务器上部署相同的内容相当于一个分身,可以处理相同的事情: Nginx作为负载均衡服务器,用户请求先到达nginx,再由nginx根据负载配置将请求转

随机推荐