PagerTabStrip及自定义的PagerTab
如图是效果图
开发中经常会用到上面是一个Tab下面是一个ViewPager(ViewPager再包含几个Fragment),当点击Tab或是滑动ViewPager,Tab及ViewPager都会发生对应的变化
如图我实现的上面一个Tab是自己定义的布局让其继承HorizontalScrollView,下面一个使用系统PagerTabStrip很简单,
当然引用别人的框架Android-ViewPagerIndicator(https://github.com/JakeWharton/ViewPagerIndicator)实现更简单
如下是主要代码
package com.it.hello.activity.assets; import java.util.ArrayList;
import com.it.hello.R;
import com.it.hello.activity.entity.ChannelItem;
import com.it.hello.activity.fragment.FourFragment;
import com.it.hello.activity.fragment.MThreeFragment;
import com.it.hello.activity.fragment.OneFragment;
import com.it.hello.activity.myfragment.MyFragmentOne;
import com.it.hello.activity.myfragment.MyFragmentTwo;
import com.it.hello.activity.util.DensityUtils;
import com.it.hello.activity.widget.ColumnHorizontalScrollView;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.support.v4.view.PagerTabStrip;
import android.support.v4.view.ViewPager;
import android.util.SparseArray;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.TextView;
import android.widget.RelativeLayout.LayoutParams; /**
* PagerTabStrip实现ViewPager的滑动
* @author zh
*
*/
public class MyStripActivity extends FragmentActivity { private ViewPager mViewPager;
private PagerTabStrip pager_tab_strip; /** 自定义的HorizontalScrollView */
private ColumnHorizontalScrollView mColumnHorizontalScrollView;
private LinearLayout mRadioGroup_content;
/** 用户选择的分类列表 */
private ArrayList<ChannelItem> userChannelItems = new ArrayList<ChannelItem>();
/** 当前选中的栏目 */
private int columnSelectIndex = 0;
/** 屏幕的宽度 */
private int mScreeWidth = 0;
/** Item宽度 */
private int mItemWidth = 0;
private View view; @Override
protected void onCreate(Bundle arg0) {
// TODO Auto-generated method stub
super.onCreate(arg0);
setContentView(R.layout.activity_strip);
mScreeWidth = DensityUtils.getWindowsWidth(this);
mItemWidth = mScreeWidth / 3; // 一个Item宽度为屏幕的3分之一
mViewPager = (ViewPager) findViewById(R.id.vp);
pager_tab_strip = (PagerTabStrip) findViewById(R.id.pager_tab_strip);
// 设置标签下划线的颜色
mColumnHorizontalScrollView = (ColumnHorizontalScrollView) findViewById(R.id.mColumnHorizontal);
mRadioGroup_content = (LinearLayout) findViewById(R.id.mRadioGroup); initColumData();
//取消Tab 下面的长横线
pager_tab_strip.setDrawFullUnderline(false);
//改变Tab线的颜色
pager_tab_strip.setTabIndicatorColor(getResources().getColor(
R.color.indecolor));
mViewPager.setOffscreenPageLimit(3);
mViewPager.setAdapter(new MainAdapter(getSupportFragmentManager()));
} private void initColumData() {
// TODO Auto-generated method stub
userChannelItems = new ArrayList<ChannelItem>();
ChannelItem item = new ChannelItem(0, "标签0", 0, 0);
ChannelItem item1 = new ChannelItem(0, "标签1", 0, 0);
ChannelItem item2 = new ChannelItem(0, "标签2", 0, 0);
ChannelItem item3 = new ChannelItem(0, "标签3", 0, 0);
ChannelItem item4 = new ChannelItem(0, "标签4", 0, 0);
userChannelItems.add(item);
userChannelItems.add(item1);
userChannelItems.add(item2);
userChannelItems.add(item3);
userChannelItems.add(item4); initTabColumn(); /**
* ViewPager切换监听的方法
*/
mViewPager
.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() { @Override
public void onPageSelected(int position) {
// TODO Auto-generated method stub
mViewPager.setCurrentItem(position);
selectTab(position);
initColumData();
} });
} /**
* 初始化TabColumn栏目项
*/
private void initTabColumn() {
// TODO Auto-generated method stub
mRadioGroup_content.removeAllViews();
int count = userChannelItems.size();
mColumnHorizontalScrollView.setParam(this, mScreeWidth,
mRadioGroup_content);
for (int i = 0; i < count; i++) {
RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(
mItemWidth, LayoutParams.WRAP_CONTENT);
params.leftMargin = 5;
params.rightMargin = 5;
view = View.inflate(this, R.layout.item_mytab, null);
TextView tv = (TextView) view.findViewById(R.id.tab_title);
View line = (View) view.findViewById(R.id.tab_line);
tv.setId(i);
tv.setText(userChannelItems.get(i).getName());
if (columnSelectIndex == i) {
tv.setSelected(true);
line.setSelected(true);
}
view.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View arg0) {
// TODO Auto-generated method stub
for (int i = 0; i < mRadioGroup_content.getChildCount(); i++) {
View localView = mRadioGroup_content.getChildAt(i);
if (localView != arg0) {
localView.setSelected(false);
} else {
localView.setSelected(true);
mViewPager.setCurrentItem(i);
}
}
}
});
mRadioGroup_content.addView(view, i, params);
}
} /**
* 选择的Column里面的Tab
* */
private void selectTab(int tab_postion) {
columnSelectIndex = tab_postion;
for (int i = 0; i < mRadioGroup_content.getChildCount(); i++) {
View checkView = mRadioGroup_content.getChildAt(tab_postion);
int k = checkView.getMeasuredWidth();
int l = checkView.getLeft();
int i2 = l + k / 2 - mScreeWidth / 2;
mColumnHorizontalScrollView.smoothScrollTo(i2, 0);
}
// 判断是否选中
for (int j = 0; j < mRadioGroup_content.getChildCount(); j++) {
View checkView = mRadioGroup_content.getChildAt(j);
boolean ischeck;
if (j == tab_postion) {
ischeck = true;
} else {
ischeck = false;
}
checkView.setSelected(ischeck);
}
} /**
* ViewPager的适配器
* @author zh
*
*/
private class MainAdapter extends FragmentStatePagerAdapter { public MainAdapter(FragmentManager fm) {
super(fm);
// TODO Auto-generated constructor stub
} // 每个条目返回的Fragment
@Override
public Fragment getItem(int position) {
// TODO Auto-generated method stub
return createFragment(position);
} // 一共多少个条目
@Override
public int getCount() {
// TODO Auto-generated method stub
return 5;
} // 返回每个条目的标题
@Override
public CharSequence getPageTitle(int position) {
return "标签" + position;
}
}
//private static Map<Integer, Fragment> mFragmentMap = new HashMap<Integer, Fragment>();
private static SparseArray<Fragment> mFragmentMap = new SparseArray<Fragment>();
public Fragment createFragment(int position) {
// TODO Auto-generated method stub
Fragment fragment = null;
fragment = mFragmentMap.get(position);//在集合中去除Fragment
if(fragment == null){//如果没在集合中取出来 需要重新创建
if (position == 0) {
fragment = new MyFragmentOne();
} else if (position == 1) {
fragment = new MyFragmentTwo();
} else if (position == 3) {
fragment = new MThreeFragment();
} else if (position == 4) {
fragment = new FourFragment();
} else {
fragment = new OneFragment();
}
if(fragment != null){
mFragmentMap.put(position, fragment);//把创建好的Fragment存放到集合中缓存起来
}
}
return fragment;
}
}
布局代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <com.it.hello.activity.widget.ColumnHorizontalScrollView
android:id="@+id/mColumnHorizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:scrollbars="none" > <LinearLayout
android:id="@+id/mRadioGroup"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#333"
android:gravity="center_vertical"
android:orientation="horizontal" />
</com.it.hello.activity.widget.ColumnHorizontalScrollView> <android.support.v4.view.ViewPager
android:id="@+id/vp"
android:layout_width="match_parent"
android:layout_height="match_parent" > <android.support.v4.view.PagerTabStrip
android:id="@+id/pager_tab_strip"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="top"
android:background="#ffffff"
android:paddingBottom="4dp"
android:paddingTop="4dp"
android:textColor="#000" />
</android.support.v4.view.ViewPager> </LinearLayout>
自定义的ColumnHorizontalScrollView
package com.it.hello.activity.widget; import android.app.Activity;
import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
import android.widget.HorizontalScrollView; public class ColumnHorizontalScrollView extends HorizontalScrollView {
/** 传入整体布局 */
private View ll_content;
/** 传入拖动栏布 */
// private View rl_column;
/** 屏幕宽度 */
private int mScreenWitdh = 0;
/** 父类的活动activity */
private Activity activity; public ColumnHorizontalScrollView(Context context) {
super(context);
} public ColumnHorizontalScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
} public ColumnHorizontalScrollView(Context context, AttributeSet attrs,
int defStyle) {
super(context, attrs, defStyle);
} /**
* 在拖动的时
* */
// @Override
// protected void onScrollChanged(int paramInt1, int paramInt2, int
// paramInt3, int paramInt4) {
// super.onScrollChanged(paramInt1, paramInt2, paramInt3, paramInt4);
// //shade_ShowOrHide();
// if(!activity.isFinishing() && ll_content !=null){
// }else{
// return;
// }
// if(paramInt1 ==0){
// return;
// }
// if(ll_content.getWidth() - paramInt1 + rl_column.getLeft() ==
// mScreenWitdh){
// return;
// }
// }
/**
* 传入父类布局中的资源文件
* */
public void setParam(Activity activity, int mScreenWitdh, View paramView1) {
this.activity = activity;
this.mScreenWitdh = mScreenWitdh;
this.ll_content = paramView1;
} /**
* 判断左右阴影的显示隐藏效
* */
public void shade_ShowOrHide() {
if (!activity.isFinishing() && ll_content != null) {
measure(0, 0);
// 如果整体宽度小于屏幕宽度的话,那左右阴影都隐藏
if (mScreenWitdh >= getMeasuredWidth()) {
// leftImage.setVisibility(View.GONE);
// rightImage.setVisibility(View.GONE);
}
} else {
return;
}
// 如果滑动在最左边时,左边阴影隐藏,右边显示
if (getLeft() == 0) {
// leftImage.setVisibility(View.GONE);
// rightImage.setVisibility(View.VISIBLE);
return;
}
// 如果滑动在最右边时,左边阴影显示,右边隐藏
if (getRight() == getMeasuredWidth() - mScreenWitdh) {
// leftImage.setVisibility(View.VISIBLE);
// rightImage.setVisibility(View.GONE);
return;
}
// 否则,说明在中间位置,左、右阴影都显示
// leftImage.setVisibility(View.VISIBLE);
// rightImage.setVisibility(View.VISIBLE);
}
}
/**获取屏幕的宽*/
public final static int getWindowsWidth(Activity activity) {
DisplayMetrics dm = new DisplayMetrics();
activity.getWindowManager().getDefaultDisplay().getMetrics(dm);
return dm.widthPixels;
}
3.最近用TabLayout + ViewPager也可以实现效果 而且代码很简单
要先添加倚赖
compile 'com.android.support:design:25.3.1'
如下是所有代码 先看布局
<?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"> <android.support.design.widget.TabLayout
android:id="@+id/tablayout"
android:layout_width="match_parent"
android:layout_height="60dp"
app:tabIndicatorColor="#49dd12"
app:tabSelectedTextColor="#49dd12"
app:tabTextColor="@android:color/darker_gray" /> <android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
package com.item.jiejie.lite.tab; import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.content.ContextCompat;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.LinearLayout;
import android.widget.TableLayout; import com.item.jiejie.lite.R; import java.util.ArrayList;
import java.util.List; public class MyTabActivity extends AppCompatActivity {
private ViewPager viewPager;
private TabLayout tabLayout;
private List<Fragment> fragments = new ArrayList<>();
private List<String> tabs = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my_tab);
initData();
} private void initData() {
tabs.add("新消息");
tabs.add("朋友圈");
tabs.add("公众号");
fragments.add(new TabFrament(this,tabs.get(0)));
fragments.add(new TabFrament(this,tabs.get(1)));
fragments.add(new TabFrament(this,tabs.get(2))); tabLayout = (TabLayout) findViewById(R.id.tablayout);
viewPager = (ViewPager)findViewById(R.id.viewpager);
//设置TabLayout的模式
tabLayout.setTabMode(TabLayout.MODE_FIXED);
viewPager.setAdapter(new TabAdapter(getSupportFragmentManager()));
//关联ViewPager和TabLayout
tabLayout.setupWithViewPager(viewPager);
//设置分割线
LinearLayout linear = (LinearLayout)tabLayout.getChildAt(0);
linear.setShowDividers(LinearLayout.SHOW_DIVIDER_MIDDLE);
linear.setDividerDrawable(ContextCompat.getDrawable(this,R.drawable.divider));
//设置分割线间隔
linear.setDividerPadding(dip2px(15));
}
//像素单位转换
public int dip2px(int dip) {
float density = getResources().getDisplayMetrics().density;
return (int) (dip * density + 0.5);
}
class TabAdapter extends FragmentPagerAdapter{ public TabAdapter(FragmentManager fm) {
super(fm);
} @Override
public Fragment getItem(int position) {
return fragments.get(position);
} @Override
public int getCount() {
return fragments.size();
}
//显示标签上的文字
@Override
public CharSequence getPageTitle(int position) {
return tabs.get(position);
}
}
}
package com.item.jiejie.lite.tab; import android.content.Context;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView; /**
* Created by jiejie on 2017/5/3.
*/ public class TabFrament extends Fragment {
private Context context;
private String content; public TabFrament() {
} public TabFrament(Context contexts, String content) {
this.context = contexts;
this.content = content;
} @Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
TextView textView = new TextView(context);
textView.setText(content);
textView.setTextSize(30);
textView.setGravity(Gravity.CENTER);
return textView;
}
}
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#80c0c0c0"/>
<size android:width="1dp"/>
</shape>
PagerTabStrip及自定义的PagerTab的更多相关文章
- Android界面实现----PagerTabStrip绚丽的滑动标签
在ViewPager这种可以滑动的控件上,总是有很多的文章可以做.Android自带的控件,实现一个指示器,这个控件,就是support-v4包里面的PagerTabStrip控件. 首先,我们先看一 ...
- 【Android开发日记】之入门篇(十五)——ViewPager+自定义无限ViewPager
ViewPager 在 Android 控件中,ViewPager 一直算是使用率比较高的控件,包括首页的banner,tab页的切换都能见到ViewPager的身影. viewpager 来源自 v ...
- ViewPager及PagerTabStrip 的使用详解
ViewPager 就是一个滑屏效果的一个控件,使用比较简单.使用过程思路流程基本如下: 在需要添加的ViewPager的布局文件中添加ViewPager控件--->准备好滑屏所有的View-- ...
- ViewPager 详解(三)---PagerTabStrip与PagerTitleStrip添加标题栏的异同
前言:在前两篇文章中,我们讲解了滑动页面的的实现方法与四大函数的意义,但有时,仅仅实现页面滑动是不够的,还要有标题栏才会显得更友好.所以在这篇文章中,我将会向大家展示在Android.support. ...
- Android多画面幻灯片:ViewPager基础上,利用与PagerTabStrip出生缺陷(源代码)
近期使用ViewPager.读了几个人说是不是很清晰的信息,干脆自己写demo总结下. 样例非常easy.Activity里有三个界面能够滑动.每个界面都有一个button并设置好了监听.PagerT ...
- [转]ViewPager 详解(三)---PagerTabStrip与PagerTitleStrip添加标题栏的异同
目录(?)[-] 一PagerTitleStrip Class Overview XML布局文件 重写适配器的getPageTitle函数 变量 初始化 重写CharSequence getPag ...
- Android开发之ViewPager实现多页面切换及动画效果(仿Android的Launcher效果)
Android开发中经常会有引导页或者切换页面等效果,本文采用ViewPager结合动画效果来实现仿Launcher以及页面切换的效果.源码地址在文章最后给出下载. 效果图如下: 1.Vi ...
- Android 高级UI组件(二)
1.ExpandableListView 显示垂直滚动两级列表的条目,只允许两个层次 整体思路: 要给ExpandableListView设置适配器,那么必须先设置数据源. 数据源,就是此处的适配器类 ...
- ViewPager的使用
在上培训课的时候,老师一直在将ViewPager是现在的主流,一直想去好好的了解一下,今天去网上学习了一下 ,做一个总结: ViewPager其实就是后来谷歌提供给我们的一个组件,就像TextVi ...
随机推荐
- CSS水平垂直居中的几种方法2
直接进入主题! 一.脱离文档流元素的居中 方法一:margin:auto法 CSS代码: div{ width: 400px; height: 400px; position: relative; b ...
- Oracle函数脚本记录
--内置函数 --聚合函数 返回单个值 '; --count()记录条数 select sum(degree) from score t; --sum(degree)求成绩总和 select avg( ...
- js笔记——理解js中的call及apply
call及apply在js里经常碰得到,但一直感觉很陌生,不能熟练使用.怎样才能熟练应用呢? 为什么存在call和apply? 在javascript OOP中,我们经常会这样定义: function ...
- 用css来写一些简单的图形
在写网页的过程中,有时我们需要用到一些简单的图片但是手头又没有合适的,我们其实可以自己来写,下面我就简单的介绍几个例子: 1.上三角 Triangle Up #triangle-up { width: ...
- fir.im Weekly - 除了写代码,还需要了解什么
雾霾天,宜撸代码.吹牛,不宜出门约会(¬_¬)ノ 本期 fir.im Weekly 亦如往期,收集了优秀的 iOS/Android 开发资源,GitHub 源码.前端方面的热点分享.除了代码,也许你 ...
- jQuery_03之事件、动画、类数组操作
一.事件: 1.模式触发事件: ①DOM:elem.onXXX();只能触发直接用onXXX绑定的事件处理函数:用addEventistener添加的事件监听无法模拟出发触发: ②jQuery:$ ...
- 【原创】NIO框架入门(二):服务端基于MINA2的UDP双向通信Demo演示
前言 NIO框架的流行,使得开发大并发.高性能的互联网服务端成为可能.这其中最流行的无非就是MINA和Netty了,MINA目前的主要版本是MINA2.而Netty的主要版本是Netty3和Netty ...
- OpenCascade Primitives BRep - Sphere
OpenCascade Primitives BRep - Sphere eryar@163.com Abstract. BRep is short for Boundary Representati ...
- Angular从0到1:function(下)
1.前言 2.function(下) 2.13.angular.isArray(★★) angular.isArray用于判断对象是不是数组,等价于Array.isArray console.log( ...
- 基于PHP实现阿里云开放存储服务
开放存储服务(OpenStorageService,简称OSS),是阿里云对外提供的海量,安全,低成本,高可靠的云存储服务.用户可以通过简单的API(REST方式的接口),在任何时间.任何地点.任何互 ...