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/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="zhengliang.com.tablayout.MainActivity"> <android.support.design.widget.TabLayout android:id="@+id/tab" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/colorPrimary" > </android.support.design.widget.TabLayout> <android.support.v4.view.ViewPager android:id="@+id/pager" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" /> </LinearLayout>

里面一个Tablayout和一个ViewPager就行了

实现上面的效果需要创建几个Fragment,这里为了方便就直接创建了一个基本的Fragment需要的时候直接new就行了,实现代码如下:

public class BlankFragment extends Fragment { public BlankFragment() { } public static BlankFragment newInstance(String text){ Bundle bundle = new Bundle(); bundle.putString("text",text); BlankFragment blankFragment = new BlankFragment(); blankFragment.setArguments(bundle); return blankFragment; } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { return inflater.inflate(R.layout.fragment_blank, container, false); } @Override public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); TextView textView = (TextView) view.findViewById(R.id.pager_text); textView.setText(getArguments().getString("text")); } }

有了Fragment还需要一个实现一个ViewPagerAdapter

public class MyAdapter extends FragmentPagerAdapter { private List<String> list; public MyAdapter(FragmentManager fm, List<String> list) { super(fm); this.list = list; } @Override public Fragment getItem(int position) { return BlankFragment.newInstance(list.get(position)); } @Override public int getCount() { return list.size(); } @Override public CharSequence getPageTitle(int position) { return list.get(position); } }

Adapter的写法非常简单,在自定义Adapter的时候需要重写里面的getPagerTitle()方法,实现这个方法是为了当Tablayout与ViewPager绑定的时候能够绑定Tab标签的标题

一切准备就绪,直接看MainActivity.java中的代码

public class MainActivity extends AppCompatActivity { private TabLayout tab; private ViewPager pager; private List<String> list; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); /*初始化界面*/ initViews(); /*初始化数据*/ initData(); /*设置Adapter*/ pager.setAdapter(new MyAdapter(getSupportFragmentManager(),list)); /*Tab与ViewPager绑定*/ tab.setupWithViewPager(pager); } /*初始化数据*/ private void initData() { list = new ArrayList<>(); for (int i = 0; i < 5 ; i++) { list.add(String.format(Locale.CHINA,"第%02d页",i)); } } /*初始化界面*/ private void initViews() { this.pager = (ViewPager) findViewById(R.id.pager); this.tab = (TabLayout) findViewById(R.id.tab); } }

到这里基本就实现了上面图的效果,里面一句很关键的代码:tab.setupWithViewPager(pager);只有加了这句代码才能实现Tab和ViewPager的绑定联动...

下面介绍一些TabLayout常用的属性:

设置Tab标签的默认字体颜色:

app:tabTextColor="#ddd"

设置Tab标签选中的字体颜色:

app:tabSelectedTextColor="@color/colorAccent"

设置指示器的颜色:

app:tabIndicatorColor="@color/colorAccent"

设置指示器的高度: (当值为0dp的时候指示器为隐藏状态)

app:tabIndicatorHeight="5dp"

Tablayout中一个重要的属性: app:tabMaode

该属性有两个值:### scrollable,fixed

"fixed"

固定的,表示Tab标签不管为多少都是固定的,所以当标签很多的时候就会挤在一起,而且回造成标签上的文字显示不完整:

如下图:

app:tabMode="fixed"

scrollable

可滚动的,当Tab的标签超出屏幕的宽度,就会自动出现课滑动的效果,当标签过多的时候还可以直接滑动标签

app:tabMode="scrollable"

如下图:

好了,上面这些就是TabLayout最基本的用法...

以上所述是小编给大家介绍的Android使用TabLayout+Fragment实现顶部选项卡,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

时间: 2024-10-24 07:04:18

Android使用TabLayout+Fragment实现顶部选项卡的相关文章

Android利用Fragment实现Tab选项卡效果_Android

利用Fragment实现Tab选项卡效果:  将RadioGroup与Fragment集合,实现tab选项卡效果,这里面最关键的几个文件:  1.FragmentTabAdapter类: /** *@Description: *@Author:Nate Robinson *@Since:2015-2-12 */ public class FragmentTabAdapter implements RadioGroup.OnCheckedChangeListener { private List<

Android利用Fragment实现Tab选项卡效果

利用Fragment实现Tab选项卡效果: 将RadioGroup与Fragment集合,实现tab选项卡效果,这里面最关键的几个文件: 1.FragmentTabAdapter类: /** *@Description: *@Author:Nate Robinson *@Since:2015-2-12 */ public class FragmentTabAdapter implements RadioGroup.OnCheckedChangeListener { private List<Fr

Android 中TabLayout自定义选择背景滑块的实例代码_Android

 TabLayout是Android 的Material Design包中的一个控件,可以和V4包中的ViewPager搭配产生一个联动的效果.这里我自定义了一个滑块能够跟随TabLayout进行滑动选择的SliderLayout.效果见下图(白色方框): 下面是SliderLayout的源码: import android.content.Context; import android.content.res.TypedArray; import android.graphics.drawab

Android 中TabLayout自定义选择背景滑块的实例代码

TabLayout是Android 的Material Design包中的一个控件,可以和V4包中的ViewPager搭配产生一个联动的效果.这里我自定义了一个滑块能够跟随TabLayout进行滑动选择的SliderLayout.效果见下图(白色方框): 下面是SliderLayout的源码: import android.content.Context; import android.content.res.TypedArray; import android.graphics.drawabl

Android使用TabLayou+fragment+viewpager实现滑动切换页面效果

TabLayou 主要实现的是标题头的 滑动 这个 控件 类似于 ScrollView XML中的布局 <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <android.support.design.widget.TabLayout a

Android的ToDoList(fragment) 详解

Fragment(碎片) 可以灵活地从一个活动的Activity上添加或删除Fragment, 有良好的用户体验; 下面是Fragment的具体设计: 1. 创建new_item_fragment的资源文件: 位置: res->new_item_fragment.xml <?xml version="1.0" encoding="utf-8"?> <EditText xmlns:android="http://schemas.and

Android开发: fragment解析及案例

  Fragment 设计理念 在设计应用时特别是Android 应用 ,有众多的分辨率要去适应,而fragments 可以让你在屏幕不同的屏幕上动态管理UI.例如:通讯应用程序(QQ),用户列表可以在左边,消息窗口在右边的设计.而在手机屏幕用户列表填充屏幕当点击某一用户时,则弹出对话窗口的设计,如下图: 开发: fragment解析及案例-fragment源码解析"> Fragment的生命周期  每一个fragments 都有自己的一套生命周期回调方法和处理自己的用户输入事件. 对应生

android viewpager切换fragment显示问题

问题描述 android viewpager切换fragment显示问题 项目中viewpager的第二个fragment添加有动画效果,可是viewpager采用预加载的机制,导致如果在第一个fragment等了5s(比如已在第二个fragment设定动画效果持续时间为5s),再切换到第二个fragment时候会没有动画效果,该怎么办? 解决方案 你可以重写第二个fragment的 @Override public void setUserVisibleHint(boolean isVisib

Android系列之Fragment(三)----Fragment和Activity之间的通信(含接口回调)

[正文] 一.接口回调的简单引入: 我们先来看一个简单的接口回调的例子: 新建一个Java工程,然后新建一个包.然后新建一个A.java文件: A.java代码如下: 1 package com.cn.callback; 2 3 public class A { 4 public A() { 5 6 } 7 8 //下载图片的操作 9 public void loadImage(String image_path,final CallBack callBack) { 10 new Thread(