TabLayout_tablayou tabgravity-程序员宅基地

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

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

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

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

这里写图片描述

代码如下:

?

packageblog.csdn.net.mchenys.tablayoudemo;
 
importandroid.graphics.Color;
importandroid.os.Bundle;
importandroid.support.design.widget.TabLayout;
importandroid.support.v7.app.AppCompatActivity;
importandroid.view.Gravity;
importandroid.view.ViewGroup;
importandroid.widget.Toast;
 
/**
 * Created by mChenys on 2016/5/28.
 */
publicclass TabLayoutOnlyActivity extendsAppCompatActivity {
 @Override
 protectedvoid onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  //创建TabLayout
  TabLayout tabLayout = newTabLayout(this);
  tabLayout.setLayoutParams(newViewGroup.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(inti = 0; i < 20; i++) {
   //添加tab
   tabLayout.addTab(tabLayout.newTab().setText("TAB"+ i));
  }
  finalToast toast = Toast.makeText(this,"", Toast.LENGTH_SHORT);
  toast.setGravity(Gravity.CENTER,0,0);
  //设置tab的点击监听器
  tabLayout.setOnTabSelectedListener(newTabLayout.OnTabSelectedListener() {
   @Override
   publicvoid onTabSelected(TabLayout.Tab tab) {
    toast.setText(tab.getPosition() + ":"+ tab.getText());
    toast.show();
   }
 
   @Override
   publicvoid onTabUnselected(TabLayout.Tab tab) {
 
   }
 
   @Override
   publicvoid onTabReselected(TabLayout.Tab tab) {
 
   }
  });
  setContentView(tabLayout);
 }
}

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

这里写图片描述

布局文件如下:

?

<?xmlversion="1.0"encoding="utf-8"?>
<LinearLayoutxmlns: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>

代码如下:

?

packageblog.csdn.net.mchenys.tablayoudemo;
 
importandroid.os.Bundle;
importandroid.support.design.widget.TabLayout;
importandroid.support.v4.app.Fragment;
importandroid.support.v4.app.FragmentPagerAdapter;
importandroid.support.v4.view.ViewPager;
importandroid.support.v7.app.AppCompatActivity;
 
/**
 * Created by mChenys on 2016/5/28.
 */
publicclass TabLayoutWithViewPagerActivity extendsAppCompatActivity {
 
 String[] mTitle = newString[20];
 String[] mData = newString[20];
 TabLayout mTabLayout;
 ViewPager mViewPager;
 
 @Override
 protectedvoid onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_tab_view_pager);
  initData();
  initView();
 }
 
 privatevoid initData() {
  for(inti = 0; i < 20; i++) {
   mTitle[i] = "TAB"+ (i + 1);
   mData[i] = "当前选中的是第"+ (i + 1) + "Fragment";
  }
 }
 
 privatevoid initView() {
  mTabLayout = (TabLayout) findViewById(R.id.tl_tab);
  mViewPager = (ViewPager) findViewById(R.id.vp_pager);
  mViewPager.setAdapter(newFragmentPagerAdapter(getSupportFragmentManager()) {
   //此方法用来显示tab上的名字
   @Override
   publicCharSequence getPageTitle(intposition) {
    returnmTitle[position % mTitle.length];
   }
 
   @Override
   publicFragment getItem(intposition) {
    //创建Fragment并返回
    TabFragment fragment = newTabFragment();
    fragment.setTitle(mData[position % mTitle.length]);
    returnfragment;
   }
 
   @Override
   publicint getCount() {
    returnmTitle.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(newTabLayout.OnTabSelectedListener() {
   @Override
   publicvoid onTabSelected(TabLayout.Tab tab) {
    //切换ViewPager
    mViewPager.setCurrentItem(tab.getPosition());
   }
 
   @Override
   publicvoid onTabUnselected(TabLayout.Tab tab) {
 
   }
 
   @Override
   publicvoid onTabReselected(TabLayout.Tab tab) {
 
   }
  });
 }
}

TabFragment 代码如下:

?

packageblog.csdn.net.mchenys.tablayoudemo;
 
importandroid.os.Bundle;
importandroid.support.v4.app.Fragment;
importandroid.util.TypedValue;
importandroid.view.Gravity;
importandroid.view.LayoutInflater;
importandroid.view.View;
importandroid.view.ViewGroup;
importandroid.widget.TextView;
 
/**
 * Created by mChenys on 2016/5/28.
 */
publicclass TabFragment extendsFragment {
 privateString mTitle;
 
 publicvoid setTitle(String title) {
  this.mTitle = title;
 }
 
 @Override
 publicView onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
  TextView textView = newTextView(getContext());
  textView.setTextSize(TypedValue.COMPLEX_UNIT_SP,30);
  textView.setGravity(Gravity.CENTER);
  textView.setText(mTitle);
  returntextView;
 }
}

扩展

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

?

publicstatic final class Tab {
 
  /**
   * An invalid position for a tab.
   *
   * @see #getPosition()
   */
  publicstatic final int INVALID_POSITION = -1;
 
  privateObject mTag;
  privateDrawable mIcon;
  privateCharSequence mText;
  privateCharSequence mContentDesc;
  privateint mPosition = INVALID_POSITION;
  privateView mCustomView;
 
  privateTabLayout mParent;
  privateTabView mView;
 
  privateTab() {
   // Private constructor
  }

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

这里写图片描述

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

?

for(inti = 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));
}

2.替换默认的tab选择效果 

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

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

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

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

这里写图片描述

修改代码如下:

?

packageblog.csdn.net.mchenys.tablayoudemo;
 
importandroid.graphics.Color;
importandroid.os.Bundle;
importandroid.support.design.widget.TabLayout;
importandroid.support.v7.app.AppCompatActivity;
importandroid.view.Gravity;
importandroid.view.View;
importandroid.view.ViewGroup;
importandroid.widget.TextView;
importandroid.widget.Toast;
 
/**
 * Created by mChenys on 2016/5/28.
 */
publicclass TabLayoutOnlyActivity extendsAppCompatActivity {
 intinitPosition; //默认位置
 
 @Override
 protectedvoid onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 //创建TabLayout
 finalTabLayout tabLayout = newTabLayout(this);
 tabLayout.setLayoutParams(newViewGroup.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(inti = 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(newTabLayout.OnTabSelectedListener() {
  @Override
  publicvoid onTabSelected(TabLayout.Tab tab) {
  //将默认位置选中为false
  isSelected(tabLayout.getTabAt(initPosition),false);
  //选中当前位置
  isSelected(tab,true);
 
  }
 
  @Override
  publicvoid onTabUnselected(TabLayout.Tab tab) {
  //tab未选中
  isSelected(tab,false);
  }
 
  @Override
  publicvoid onTabReselected(TabLayout.Tab tab) {
  //tab重新选中
  isSelected(tab,true);
  }
 });
 //进来默认选中位置第3个item
 initPosition = 2;
 isSelected(tabLayout.getTabAt(initPosition),true);
 setContentView(tabLayout);
 }
 
 /**
 * 设置选中的tab是否带缩放效果
 * @param tab
 * @param isSelected
 */
 privatevoid isSelected(TabLayout.Tab tab, booleanisSelected) {
 View view = tab.getCustomView();
 if(null!= view) {
  view.setScaleX(isSelected ? 1.3f : 1.0f);
  view.setScaleY(isSelected ? 1.3f : 1.0f);
 }
 }
}
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/yujie0514/article/details/78216483

智能推荐

float拆分_float 详细使用说明,高度塌陷等问题-程序员宅基地

文章浏览阅读146次。float在网页布局作用很大, 但也不需要如此泛用。 最后结果只有是清除浮动都不知道在什么地方下手。 这几天也自己查找了各个关于float资料, 加深对其认识,免得出现不必要的麻烦!浮动介绍(2篇)float 是 css 的定位属性。在传统的印刷布局中,文本可以按照需要围绕图片。一般把这种方式称为“文本环绕”。在网页设计中,应用了CSS的float属性的页面元素就像在印刷布局里面的被文字包围的图片..._按钮样式 float 怎么分开

洪涝有源淹没算法及淹没结果分析【转】-程序员宅基地

文章浏览阅读1.4k次。http://blog.csdn.net/giser_whu/article/details/41288761洪涝模拟仿真的实现方法主要有两种:一种是基于水动力学的洪水演进模型;另一种是基于DEM的洪水淹没分析。具体分析如下:我是GIS从业者,从我们的专业角度出发,选择基于DEM的洪水淹没分析来做洪涝的模拟仿真。而基于DEM的洪水淹没分析方法主要分为有源淹没和无源淹没。本篇...

Java Selenium Actions模拟鼠标拖动dragAndDrop总结_selenium actions.draganddropby-程序员宅基地

文章浏览阅读1.2w次。鼠标拖动APIActions action = new Actions(webdriver);##source-要拖动的元素A,target-拖动元素A到达的目标元素action.dragAndDrop(source, target);##source-要拖动的元素A,拖动元素移动多少,标准以元素A左上角为准,拖动元素相对元素A移到右边是x是正值,左边是负值,拖动元素相对元素A移到上_selenium actions.draganddropby

amd显卡RX560控制功耗问题_a卡560功耗-程序员宅基地

文章浏览阅读4.2w次。前言现在显卡市场可以说就是 amd 和 英伟达 的双雄会。经过漫长的发展,英伟达显然技高一筹,在核心技术上牢牢压了AMD一头。价格就是最有力的证明。比如说今天我要说的RX560D。都说rx560可以媲美1050ti,但是却比1050ti便宜了一半,为什么?是amd为了消费者,所以他们有商业道德,不屑于赚取多余的金钱?我想应该不会有这样的商家存在吧。遗憾的是rx560只要不是xt,或..._a卡560功耗

springboot停车场车辆定位管理可视化分析系统的设计与实现 毕业设计-附源码101702-程序员宅基地

文章浏览阅读111次。该系统采用Springboot框架、JSP技术、Ajax技术进行业务系统的编码及其开发,实现了本系统的全部功能。本系统采取组件化的方式对系统进行拆分,并对数据库中各个表的增删查改、表与表之间的约束关系进行分析与设计,最终实现符合用户需求功能的商业级应用。

vue页面报错,TypeError: Cannot read property ‘_wrapper‘ of undefined_页面报错vue.min.js:6-程序员宅基地

文章浏览阅读2.9k次。vue页面报错崩溃卡死,报了这个错TypeError: Cannot read property '_wrapper' of undefined at Qr (vue.min.js:6) at rt (vue.min.js:6) at Array.ei (vue.min.js:6) at x (vue.min.js:6) at vue.min.js:6 at x (vue.min.js:6) at vue.min.js:6 at x (vue_页面报错vue.min.js:6

随便推点

Python 获取多维数组数据_robotframework 获取 多维数组-程序员宅基地

文章浏览阅读533次。几种常用获取数据的方法。_robotframework 获取 多维数组

C++11的一些新特性|右值引用|STL中的一些变化_stl中有移动赋值-程序员宅基地

文章浏览阅读340次,点赞2次,收藏2次。如果没有自己实现移动构造,且没有实现析构,拷贝构造,拷贝赋值重载中的任意一个,那么编译器会自己生成一个默认移动构造。在类中增加移动构造,移动构造本质上是将参数右值的资源窃取,占为己有,那么就不用做深拷贝,所以叫它移动构造,就是窃取别人的资源来构造自己。原来c++类中,有6个默认成员函数:构造,析构,拷贝构造,拷贝赋值,取地址重载,const取地址重载。传统的c++语法中就有引用的语法,而c++11中新增了右值引用的语法特性,无论是左值引用还是右值引用,都是给对象取别名。可以让你更好的控制要使用的默认函数。_stl中有移动赋值

Playground v2.5最新的文本到图像生成模型,官方宣称V2.5的模型优于 SDXL、Playground v2、PixArt-α、DALL-E 3 和 Midjourney_playgrouind v2.5-程序员宅基地

文章浏览阅读724次。Playground在去年发布Playground v2.0之后再次开源新的文生图模型Playground v2.5。新版本提升了图像的美学质量,增强了颜色和对比度、改进了多纵横比图像生成,可以生成各种比例图像以及人像细节的提升。官方宣称:根据用户研究表明,V2.5的模型优于 SDXL、Playground v2、PixArt-α、DALL-E 3 和 Midjourney 5.2。_playgrouind v2.5

Python小白逆袭大神七日打卡营飞桨paddlepaddle_path = 'work/' 'pics/' name '/-程序员宅基地

文章浏览阅读782次。这里写自定义目录标题Python小白逆袭大神七日打卡营全纪录新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML 图表FLowchart流程图导出与导入导出导入P..._path = 'work/' 'pics/' name '/

px4飞控和qgc通信机制整理_airsim和qground交互-程序员宅基地

文章浏览阅读2k次,点赞6次,收藏31次。连接多架飞机时老是不反应,整理一下飞控和qgc的通信机制吧全部消息整理出来太庞大了,以心跳包做个示例,打字太累,直接贴图,qgc的后面再补上_airsim和qground交互

使用MQTT客户端连接阿里云MQTT服务器_mqtt 客户端发数据 服务器需要开端口吗-程序员宅基地

文章浏览阅读1.2w次,点赞2次,收藏49次。本文是转载的,原文请戳这里查看!~摘要: 物联网全栈教程-从云端到设备(八) 一 这一篇文章零妖老哥将给你展示两个电脑软件的使用方法,将极大地方便你调试与MQTT有关的物联网项目。一个叫MQTT客户端用来模拟设备向云端发送数据和接收云端的数据;另一个叫作MQTT单片机编程小工具,是技小新针对阿里云MQTT服务器连接过程中的痛点,自己编写的一个电脑程序,用来生成连接阿里云MQTT服务器时的账号密码..._mqtt 客户端发数据 服务器需要开端口吗