我的编程空间,编程开发者的网络收藏夹
学习永远不晚

TabLayout如何使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

TabLayout如何使用

这篇文章给大家分享的是有关TabLayout如何使用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

TabLayout是design库提供的控件,可以方便的使用指示器,功能类似ViewPagerIndicator.
使用非常方便,Android Studio只需要在gradle中引入即可使用 .

compile 'com.android.support:design:23.3.0'

TabLayout即可以单独使用,也可以配合ViewPager来使用.

先来看看单独使用的Demo,实现如下图的效果:

TabLayout如何使用

代码如下:

package blog.csdn.net.mchenys.tablayoudemo;import android.graphics.Color;import android.os.Bundle;import android.support.design.widget.TabLayout;import android.support.v7.app.AppCompatActivity;import android.view.Gravity;import android.view.ViewGroup;import android.widget.Toast;public class TabLayoutOnlyActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  //创建TabLayout  TabLayout tabLayout = new TabLayout(this);  tabLayout.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, 60));  //tab可滚动  tabLayout.setTabMode(TabLayout.MODE_SCROLLABLE);  //tab居中显示  tabLayout.setTabGravity(TabLayout.GRAVITY_CENTER);  //tab的字体选择器,默认黑色,选择时红色  tabLayout.setTabTextColors(Color.BLACK, Color.RED);  //tab的下划线颜色,默认是粉红色  tabLayout.setSelectedTabIndicatorColor(Color.BLUE);  for (int i = 0; i < 20; i++) {   //添加tab   tabLayout.addTab(tabLayout.newTab().setText("TAB" + i));  }  final Toast toast = Toast.makeText(this, "", Toast.LENGTH_SHORT);  toast.setGravity(Gravity.CENTER, 0, 0);  //设置tab的点击监听器  tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {   @Override   public void onTabSelected(TabLayout.Tab tab) {    toast.setText(tab.getPosition() + ":" + tab.getText());    toast.show();   }   @Override   public void onTabUnselected(TabLayout.Tab tab) {   }   @Override   public void onTabReselected(TabLayout.Tab tab) {   }  });  setContentView(tabLayout); }}

下面再来看看配合ViewPager的使用方式,实现如下效果图:

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"> <!-- app:tabGravity="center" 对齐方式,可选fill和center app:tabIndicatorColor="@color/colorAccent" 设置tab下划线的颜色 app:tabMode="scrollable" scrollable是可以横行滚动,fixed是指固定个数 app:tabSelectedTextColor="@color/colorPrimaryDark" 选择tab的文本颜色 app:tabTextColor="@color/colorPrimary" 普通tab字体颜色 --> <android.support.design.widget.TabLayout  android:id="@+id/tl_tab"  android:layout_width="match_parent"  android:layout_height="55dp"  app:tabGravity="center"  app:tabIndicatorColor="@color/colorAccent"  app:tabMode="scrollable"  app:tabSelectedTextColor="@color/colorPrimaryDark"  app:tabTextColor="@color/colorPrimary" /> <android.support.v4.view.ViewPager  android:id="@+id/vp_pager"  android:layout_width="match_parent"  android:layout_height="match_parent" /></LinearLayout>

代码如下:

package blog.csdn.net.mchenys.tablayoudemo;import android.os.Bundle;import android.support.design.widget.TabLayout;import android.support.v4.app.Fragment;import android.support.v4.app.FragmentPagerAdapter;import android.support.v4.view.ViewPager;import android.support.v7.app.AppCompatActivity;public class TabLayoutWithViewPagerActivity extends AppCompatActivity { String[] mTitle = new String[20]; String[] mData = new String[20]; TabLayout mTabLayout; ViewPager mViewPager; @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_tab_view_pager);  initData();  initView(); } private void initData() {  for (int i = 0; i < 20; i++) {   mTitle[i] = "TAB" + (i + 1);   mData[i] = "当前选中的是第" + (i + 1) + "Fragment";  } } private void initView() {  mTabLayout = (TabLayout) findViewById(R.id.tl_tab);  mViewPager = (ViewPager) findViewById(R.id.vp_pager);  mViewPager.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) {   //此方法用来显示tab上的名字   @Override   public CharSequence getPageTitle(int position) {    return mTitle[position % mTitle.length];   }   @Override   public Fragment getItem(int position) {    //创建Fragment并返回    TabFragment fragment = new TabFragment();    fragment.setTitle(mData[position % mTitle.length]);    return fragment;   }   @Override   public int getCount() {    return mTitle.length;   }  });  //将ViewPager关联到TabLayout上  mTabLayout.setupWithViewPager(mViewPager);//  设置监听,注意:如果设置了setOnTabSelectedListener,则setupWithViewPager不会生效//  因为setupWithViewPager内部也是通过设置该监听来触发ViewPager的切换的.//  mTabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {//   @Override//   public void onTabSelected(TabLayout.Tab tab) {//   }////   @Override//   public void onTabUnselected(TabLayout.Tab tab) {////   }////   @Override//   public void onTabReselected(TabLayout.Tab tab) {////   }//  });//  那我们如果真的需要监听tab的点击或者ViewPager的切换,则需要手动配置ViewPager的切换,例如:  mTabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {   @Override   public void onTabSelected(TabLayout.Tab tab) {    //切换ViewPager    mViewPager.setCurrentItem(tab.getPosition());   }   @Override   public void onTabUnselected(TabLayout.Tab tab) {   }   @Override   public void onTabReselected(TabLayout.Tab tab) {   }  }); }}

TabFragment 代码如下:

package blog.csdn.net.mchenys.tablayoudemo;import android.os.Bundle;import android.support.v4.app.Fragment;import android.util.TypedValue;import android.view.Gravity;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.TextView;public class TabFragment extends Fragment { private String mTitle; public void setTitle(String title) {  this.mTitle = title; } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {  TextView textView = new TextView(getContext());  textView.setTextSize(TypedValue.COMPLEX_UNIT_SP,30);  textView.setGravity(Gravity.CENTER);  textView.setText(mTitle);  return textView; }}

扩展

TabLayout除了上面效果图展示的文本以外,从源码中发现它还可以支持Drawable,以及自定义View

public static final class Tab {    public static final int INVALID_POSITION = -1;  private Object mTag;  private Drawable mIcon;  private CharSequence mText;  private CharSequence mContentDesc;  private int mPosition = INVALID_POSITION;  private View mCustomView;  private TabLayout mParent;  private TabView mView;  private Tab() {   // Private constructor  }

如下效果图,就是通过添加自定义View实现的.

TabLayout如何使用

代码如下,只需要修改TabLayout的addTab方法即可:

for (int i = 0; i < 20; i++) { //1.支持添加字符串文本tab  //tabLayout.addTab(tabLayout.newTab().setText("TAB" + i)); //2.支持添加图片tab  //tabLayout.addTab(tabLayout.newTab().setIcon(R.mipmap.ic_launcher)); //3.支持添加View View tabView = View.inflate(TabLayoutOnlyActivity.this, R.layout.view_tab, null); ((TextView)tabView.findViewById(R.id.tv_title)).setText("TAB" + i); tabLayout.addTab(tabLayout.newTab().setCustomView(tabView));}

替换默认的tab选择效果

如果你即想使用TabLayout,又想不用它的选中效果,例如我们不想要tab下面的那条下划线作为指示效果.我们应该怎么处理呢?

要替换默认的选中效果,只能通过添加自定义View作为tab了.这样就可以很方便的处理View的选中和未选中状态了.

同时我们还要隐藏默认的下划线,这个怎么处理呢,这里有个很好的建议.我们可以通过设置下滑线的颜色和tab的背景 颜色一致,这样就看不出来了.

例如下面我们要实现选中tab的效果是将tab放大1.3倍,没有选中则恢复原来比例.效果图:

TabLayout如何使用

修改代码如下:

package blog.csdn.net.mchenys.tablayoudemo;import android.graphics.Color;import android.os.Bundle;import android.support.design.widget.TabLayout;import android.support.v7.app.AppCompatActivity;import android.view.Gravity;import android.view.View;import android.view.ViewGroup;import android.widget.TextView;import android.widget.Toast;public class TabLayoutOnlyActivity extends AppCompatActivity { int initPosition; //默认位置 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //创建TabLayout final TabLayout tabLayout = new TabLayout(this); tabLayout.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, 100)); //tab可滚动 tabLayout.setTabMode(TabLayout.MODE_SCROLLABLE); //tab居中显示 tabLayout.setTabGravity(TabLayout.GRAVITY_CENTER); //tab的字体选择器,默认黑色,选择时红色 tabLayout.setTabTextColors(Color.BLACK, Color.RED); //tab的下划线颜色,默认是粉红色,如果要自定义选中效果,则可以将下划线设置为和背景色一样. tabLayout.setSelectedTabIndicatorColor(Color.WHITE); for (int i = 0; i < 20; i++) {  //1.支持添加字符串文本tab  //tabLayout.addTab(tabLayout.newTab().setText("TAB" + i));  //2.支持添加图片tab  //tabLayout.addTab(tabLayout.newTab().setIcon(R.mipmap.ic_launcher));  //3.支持添加View  View tabView = View.inflate(TabLayoutOnlyActivity.this, R.layout.view_tab, null);  ((TextView) tabView.findViewById(R.id.tv_title)).setText("TAB" + i);  tabLayout.addTab(tabLayout.newTab().setCustomView(tabView)); } //设置tab的点击监听器 tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {  @Override  public void onTabSelected(TabLayout.Tab tab) {  //将默认位置选中为false  isSelected(tabLayout.getTabAt(initPosition), false);  //选中当前位置  isSelected(tab, true);  }  @Override  public void onTabUnselected(TabLayout.Tab tab) {  //tab未选中  isSelected(tab, false);  }  @Override  public void onTabReselected(TabLayout.Tab tab) {  //tab重新选中  isSelected(tab,true);  } }); //进来默认选中位置第3个item initPosition = 2; isSelected(tabLayout.getTabAt(initPosition), true); setContentView(tabLayout); }  private void isSelected(TabLayout.Tab tab, boolean isSelected) { View view = tab.getCustomView(); if (null != view) {  view.setScaleX(isSelected ? 1.3f : 1.0f);  view.setScaleY(isSelected ? 1.3f : 1.0f); } }}

感谢各位的阅读!关于“TabLayout如何使用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

TabLayout如何使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

TabLayout如何使用

这篇文章给大家分享的是有关TabLayout如何使用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。TabLayout是design库提供的控件,可以方便的使用指示器,功能类似ViewPagerIndicator.
2023-05-30

Android TabLayout选项卡如何使用

这篇“Android TabLayout选项卡如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Android TabL
2023-07-05

android TabLayout使用方法详解

Google在2015的IO大会上,给我们带来了更加详细的Material Design设计规范,同时,也给我们带来了全新的Android Design Support Library,在这个support库里面,Google给我们提供了更
2022-06-06

Android控件-TabLayout使用介绍

TabLayout简述简单示例TabLayout属性介绍tabIndicatorFullWidthtabRippleColortabTextAppearancetabModetabIndicatorColortabIndicatorHeig
2022-06-06

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

先看效果图:使用Tablayout,首先需要在项目中加入Design包dependencies { compile 'com.android.support:design:24.1.1' }
2023-05-31

crystaldiskinforh如何使用

这篇文章主要介绍“crystaldiskinforh如何使用”,在日常操作中,相信很多人在crystaldiskinforh如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”crystaldiskinfo
2023-02-09

pandas如何使用

小编给大家分享一下pandas如何使用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、生成数据表 1、首先导入pandas库,一般都会用到numpy库,所以我们
2023-06-02

Nmap如何使用

本篇内容介绍了“Nmap如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Nmap(Network Mapper)是一款开放源代码的网络
2023-06-27

wget如何使用

这篇文章主要讲解了“wget如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“wget如何使用”吧!wget 是一个从网络上自动下载文件的自由工具,支持通过 HTTP、HTTPS、FTP
2023-06-28

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录