TabLayout+Fragment+ViewPager+FragmentStatePagerAdapter实现Tab标签
首先来看下实现的效果吧:
最近在项目中实现这个效果的时候。尽管自己磕磕绊绊的实现了,可是知识确实模模糊糊的,今天天气异常的冷,在加上这个知识不太熟练,实在是没有心情进行接下来的计划,干脆借着这个时间,好好的整理一下这个实现方式。也在次总结一下,记忆更加深刻。
TabLayout简单介绍
- 在2015年的Google I/O大会上,Google公布的新的Android Support Design库,里面也包括了几个新的控件,那么TabLayout就是当中一个。使用该组件我们能够非常轻松的实现TabPageIndicator效果。而且该为官方的,能够向下兼容非常多版本号而且能够更加统一Material Design效果。
使用的时候要在库依赖中增加
假设不太清楚,能够看下http://blog.csdn.net/wuyinlei/article/details/50570018
教你怎么在项目中增加依赖。
compile'com.android.support:design:23.1.1’
接下来,在TabLayout中增加
<android.support.design.widget.TabLayout
android:id="@+id/tabLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
<!-- 下方滚动的下划线颜色 -->
app:tabIndicatorColor="#33aa22"
<!-- 下方指示条的高度 -->
app:tabIndicatorHeight="5dp"
<!-- tab被选中后,文字的颜色 -->
app:tabSelectedTextColor="#33aa22"
<!--能够改变tab中的字体的大小-->
app:tabTextAppearance="@style/App_Theme"
<!-- tab中字体的颜色 -->
app:tabTextColor="#33aa22"/>
能够在这里设置字体大小,然后引用:
<style name="App_Theme" parent="Theme.AppCompat">
<item name="android:windowNoTitle">true</item>
<item name="android:textSize">18dp</item>
<item name="android:textAllCaps">false</item>
</style>
注意:上面的这个style必须在承载他的activity中theme中增加,要不然会出现
Cause by :java.lang.IllegalArgumentException: You need to use a Theme.AppCompat theme (or descendant) with the design library;(我没有加上之前各种错,加上正常执行。可是执行之后去掉,居然也能够正常执行。不得解)
好了。接下来我们看下详细怎么实现的吧,里面有解释:
MainActivity.java:
package com.example.tablayoutfragment;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
}
activity_main.xml:
<?
xml version="1.0" encoding="utf-8"?
>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.tablayoutfragment.MainActivity">
<FrameLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<!--在这里直接增加fragment。而且制定fragment类名-->
<fragment
android:id="@+id/main_info_fragment"
class="com.example.tablayoutfragment.MainFragment"
android:layout_width="fill_parent"
android:layout_height="match_parent"/>
</FrameLayout>
</LinearLayout>
MAinFragment.java:
package com.example.tablayoutfragment;
import android.os.Bundle;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import java.util.ArrayList;
import java.util.List;
/**
* A simple {@link Fragment} subclass.
*/
public class MainFragment extends Fragment {
private TabLayout mTabLayout;
private ViewPager mViewPager;
//fragment存储器
private List<Fragment> mFragments;
//tab条目中的内容
private String[]titles = {"第一个","第二个","第三个","第四个","第五个","第六个","第七个","第八个"};
private FixedPagerAdapter mAdapter;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_blank, container, false);
mTabLayout = (TabLayout) view.findViewById(R.id.tabLayout);
mViewPager = (ViewPager) view.findViewById(R.id.viewPager);
initData();
return view;
}
/**
* 初始化数据
*/
private void initData() {
mAdapter = new FixedPagerAdapter(getChildFragmentManager());
mAdapter.setTitles(titles);//标题
mFragments = new ArrayList<>();
for (int i = 0; i < titles.length; i++) {
mFragments.add(PageFragment.newInstance(titles[i]));
}
//把要显示的fragment集合传给adapter
mAdapter.setFragments(mFragments);
/**
* 设置tablayout的模式
* 模式一:MODE_SCROLLABLE 能够滑动,显示非常多个tab中的几个展示出来
* 模式二:MODE_FIXED Fixed tabs display all tabs concurrently 展示出全部的。适合三四个tab
*/
mTabLayout.setTabMode(TabLayout.MODE_SCROLLABLE);
//给viewPager设置适配器
mViewPager.setAdapter(mAdapter);
//TabLayout绑定ViewPager
mTabLayout.setupWithViewPager(mViewPager);
}
}
fragment_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:background="#fff"
android:orientation="vertical"
tools:context=".MainFragment">
<android.support.design.widget.TabLayout
android:id="@+id/tabLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabIndicatorColor="#33aa22"
app:tabIndicatorHeight="5dp"
app:tabSelectedTextColor="#33aa22"
app:tabTextAppearance="@style/App_Theme"
app:tabTextColor="#33aa22"/>
<android.support.v4.view.ViewPager
android:id="@+id/viewPager"
android:layout_width="match_parent"
android:layout_height="match_parent"
</android.support.v4.view.ViewPager>
</LinearLayout>
PageFragment.java:
package com.example.tablayoutfragment;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
/**
* Created by 若兰 on 2016/1/23.
* 一个懂得了编程乐趣的小白,希望自己
* 能够在这个道路上走的非常远,也希望自己学习到的
* 知识能够帮助很多其它的人,分享就是学习的一种乐趣
* QQ:1069584784
* csdn:http://blog.csdn.net/wuyinlei
*/
public class PageFragment extends Fragment {
private View mView;
/**
* key值
*/
private static final String KEY = "EXTRA";
private String title;
/**
* 在这里我们提供一个静态的方法来实例化PageFragment
* 在这里我们传入一个參数。用来得到title,然后我们拿到这个title设置给内容
*
* @param extra
* @return
*/
public static PageFragment newInstance(String extra){
//利用bundle传值
Bundle bundle = new Bundle();
bundle.putString(KEY,extra);
//实例化
PageFragment fragment = new PageFragment();
fragment.setArguments(bundle);
return fragment;
}
/* @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Bundle bundle = getArguments();
if (bundle != null) {
title = bundle.getString(KEY);
}
}
*/
private TextView mTextView;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
Bundle bundle = getArguments();
if (bundle != null) {
title = bundle.getString(KEY);
}
if (mView == null) {
mView = inflater.inflate(R.layout.page_fragment, container, false);
}
initView();
return mView;
}
public void initView() {
mTextView = (TextView) mView.findViewById(R.id.text_fragment);
mTextView.setText(title);
}
}
这个fragment的布局里面就一个textview,我就不写上了。
以下看下这个adapter吧
FixedPagerAdapter.java:
package com.example.tablayoutfragment;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.view.ViewGroup;
import java.util.List;
/**
* Created by 若兰 on 2016/1/23.
* 一个懂得了编程乐趣的小白,希望自己
* 能够在这个道路上走的非常远。也希望自己学习到的
* 知识能够帮助很多其它的人,分享就是学习的一种乐趣
* QQ:1069584784
* csdn:http://blog.csdn.net/wuyinlei
*/
public class FixedPagerAdapter extends FragmentStatePagerAdapter {
private String[] titles;
/**
* 设置标题
*
* @param titles
*/
public void setTitles(String[] titles) {
this.titles = titles;
}
private List<Fragment> mFragments;
/**
* 这个是在继承FragmentStatePagerAdapter会强制写入的
*
* @param fm
*/
public FixedPagerAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int position) {
return mFragments.get(position);
}
/**
* Return the number of views available.
* 返回一个能够用的view的个数
*
* @return
*/
@Override
public int getCount() {
return mFragments.size();
}
/**
* Create the page for the given position. The adapter is responsible for
* adding the view to the container given here,
* although it only must ensure this is done by the time it returns from finishUpdate(ViewGroup).
* 这个同destroyItem()相反,是对于给定的位置创建视图。适配器往container中增加
*
* @param container
* @param position
* @return
*/
@Override
public Object instantiateItem(ViewGroup container, int position) {
Fragment fragment = null;
fragment = (Fragment) super.instantiateItem(container,position);
return fragment;
}
public List<Fragment> getFragments() {
return mFragments;
}
public void setFragments(List<Fragment> fragments) {
mFragments = fragments;
}
/**
* Remove a page for the given position. The adapter is responsible for
* removing the view from its container,
* although it only must ensure this is done by the time it returns from finishUpdate(View).
* 移除给定位置的数据。适配器负责从container(容器)中取出。可是这个必须保证是在finishUpdate(view)
* 返回的时间内完毕
*
* @param container
* @param position
* @param object
*/
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
super.destroyItem(container, position, object);
}
/**
* 得到滑动页面的Title
*
* @param position
* @return
*/
@Override
public CharSequence getPageTitle(int position) {
return titles[position];
}
}
好了,到此为止。执行就能够出现了开头的效果了。如今附上github该demo的地址:https://github.com/wuyinlei/TTFVF, 有疑问能够交流哈。多谢支持!!
TabLayout+Fragment+ViewPager+FragmentStatePagerAdapter实现Tab标签的更多相关文章
- TabLayout与ViewPager同步后Tab的标题不显示
一.概述 1.1 问题描述 TabLayout+ViewPager后,TabLayout的TabItem不显示的问题: 1.2 截图 二.结论 mTabs.setupWithViewPager(mVi ...
- 巧力避免ViewPager的预加载数据,Tablayout+Fragment+viewPager
问题描述 最近在进行一个项目的开发,其中使用到了Tablayout+Fragment+viewPager来搭建一个基本的框架,从而出现了设置数据适配器的时候,item的位置错乱问题.我打印log日志的 ...
- Android tab导航的几种方法:ActionBar tab +fragment,Viewpager+pagerTitleStrip,开源框架ViewPageIndicator 和 ViewPager
action来实现tab标签 并跟fragment结合 因为要写新闻客户端这个tab导航是必须的 这里我写几个小练习,希望大家融会贯通. 1actionbar设置tab +fragment 布局是个l ...
- Android 使用TabLayout、ViewPager和Fragment实现顶部菜单可滑动切换
效果图如下 首先,要使用控件需要添加design library,在Android Studio中添加 compile 'com.android.support:design:23.4.0' 然后是布 ...
- 类似掌盟的Tab页 Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签 (转)
原博客地址 :http://blog.csdn.net/xiaanming/article/details/10766053 本文转载,记录学习用,如有需要,请到原作者网站查看(上面这个网址) 之前 ...
- 关于TabLayout与ViewPager在Fragment中嵌套Fragment使用或配合使用的思考
注意: 因为继承的是Fragment,所以getSupportFragmentManager()与getFragmentManager()方法无法使用,这里需要用到getChildFragmentMa ...
- 低版本系统兼容的ActionBar(六)用Fragment+ViewPager+Tab实现快速导航
Tab经常和Fragment结合使用,这一讲我们用3种方式来实现这种快捷导航. 0.重要的两个监听器 MyTabListener,这个我们之前已经接触过了 package com.kale.actio ...
- Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签
转载请注明出处:http://blog.csdn.net/xiaanming/article/details/10766053 之前用JakeWharton的开源框架ActionBarSherlock ...
- ViewPager + TabLayout + Fragment + MediaPlayer的使用
效果图 在gradle里导包 implementation 'com.android.support:design:28.0.0' activity_main <?xml version=&q ...
随机推荐
- CentOS 6.9下KVM虚拟机通过virt-clone克隆虚拟机(转)
一.virt-clone概述 1.virt-clone作用简介 virt-clone主要是用来克隆kvm虚拟机,并且通过Options.General Option.Storage Configura ...
- 解决URL中包含“%2F”导致Apache地址重写mod_rewrite失效的问题
在使用Apache地址重写mod_rewrite期间,发现,当URL和PATH_INFO中出现%2f(/)或者%5c(\), 会被认为这是个不合法的请求, Apache将会直接返回"404 ...
- 小程序把图片转换成base64
1.首先需要到upng.js,然后upng.js需要pako.js,先一并下载了 2.然后就可以直接用了,具体代码如下: <!--pages/base/base.wxml--> <c ...
- 三.rocketmq-console
⦁ rocketmq-console来源于https://github.com/rocketmq/rocketmq-console 1.配置IP 2.启动运行:出现此信息则表示成功 访问:in ...
- VLAN讲解
VLAN(Virtual Local Area Network)的中文名为"虚拟局域网".VLAN是一种将局域网设备从逻辑上划分成一个个网段,从而实现虚拟工作组的新兴数据交换技术. ...
- C# 中的单精度与双精度区别
单精度浮点数(float)与双精度浮点数(double)的区别: (1)在内存中占有的字节数不同 * 单精度浮点数在机内占4个字节 *双精度浮点数在机内占8个字节 (2)有效数字位数不同 *单精度浮点 ...
- vue项目如何实现剪切板功能--vue-clipboard2
一.vue项目利用vue-clipboard2实现剪切板的功能 1.安装vue-clipboard2插件:cnpm install --save vue-clipboard2 2.main.js添加 ...
- EPF与Myeclipse 增强代码自动智能提示
摘自: http://blog.csdn.net/ylchou/article/details/7639467 数字证书文件,导入用. EPF文件是著名的软件开发工具——Eclipse(IDE)的配置 ...
- DevExpress 自动匹配宽度,及其他使用笔记
摘自: http://blog.sina.com.cn/s/blog_53b58e7c0101avl4.html GridControl列自动匹配宽度 -- : 327人阅读 评论() 收藏 举报 / ...
- Struts2的动态Action实现
源自:Struts2的动态Action实现 在Struts2中动态方法调用有三种方式. 一.指定method属性在struts.xml中指定action的method属性. <package n ...