详解Android中ViewPager的PagerTabStrip子控件的用法
我们先来看一个小例子:
可以看到,效果实现的也是很棒,比之前自定义的标签指示器更加的流畅。下面,简单介绍一下 pagertabstrip和它的使用。
pagertabstrip是v4支持包里面的类,是viewpager专用的类,不能在其他地方使用。在使用的时候,我们只需要在viewpager的布局里面声明即可。
如下面的代码
<?xml version="1.0" encoding="utf-8"?> <linearlayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@android:color/white" android:orientation="vertical" > <android.support.v4.view.viewpager android:id="@+id/viewpager" android:layout_width="match_parent" android:layout_height="match_parent" > <android.support.v4.view.pagertabstrip android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="top" android:background="@android:color/holo_blue_light" android:textcolor="@android:color/white" /> </android.support.v4.view.viewpager> </linearlayout>
我们可以设置layout_gravity属性,比如top或者是bottom,来控制显示的位置。除此之外,不需要进行其他设置。
剩下的,就是我们需要在代码里面实现的了。
import java.util.arraylist; import java.util.list; import android.os.bundle; import android.support.v4.app.fragment; import android.support.v4.app.fragmentactivity; import android.support.v4.app.fragmentpageradapter; import android.support.v4.view.viewpager; public class pagertabstripactivity extends fragmentactivity { private list<fragment> fragments; private viewpager viewpager; private list<string> titlelist; @override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); initview(); } private void initview() { viewpager = (viewpager) findviewbyid(r.id.viewpager); titlelist = new arraylist<string>(); titlelist.add("最新推荐"); titlelist.add("游戏娱乐"); titlelist.add("影音视频"); fragments = new arraylist<fragment>(); fragments.add(new myfragment(android.r.color.holo_green_light)); fragments.add(new myfragment(android.r.color.holo_orange_light)); fragments.add(new myfragment(android.r.color.holo_red_light)); fragmentpageradapter adapter = new fragmentpageradapter( getsupportfragmentmanager()) { @override public int getcount() { return 3; } @override public fragment getitem(int position) { return fragments.get(position); } @override public charsequence getpagetitle(int position) { return titlelist.get(position); } }; viewpager.setadapter(adapter); } }
在上面的代码里面,展现了我们如何控制标题的文字,我们只需要重写getpagertitle方法即可。
下面我们再来结合例子细说一下pagertabstrip:
pagertabstrip是viewpager的一个关于当前页面、上一个页面和下一个页面的一个可交互的指示器。它经常作为viewpager控件的一个子控件被被添加在xml布局文件中。在你的布局文件中,将它作为子控件添加在viewpager中。而且要将它的 android:layout_gravity 属性设置为top或bottom来将它显示在viewpager的顶部或底部。每个页面的标题是通过适配器的getpagetitle(int)函数提供给viewpager的。
用法与pagertitlestrip完全相同,即:
1、首先,文中提到:在你的布局文件中,将它作为子控件添加在viewpager中。
2、第二,标题的获取,是重写适配器的getpagetitle(int)函数来获取的。
看看实例:
1、xml布局
<relativelayout 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.testviewpage_2.mainactivity" > <android.support.v4.view.viewpager android:id="@+id/viewpager" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center"> <android.support.v4.view.pagertabstrip android:id="@+id/pagertab" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="top"/> </android.support.v4.view.viewpager> </relativelayout>
可以看到,同样,是将pagertabstrip作为viewpager的一个子控件直接插入其中,当然android:layout_gravity=""的值一样要设置为top或bottom。
2、重写适配器的getpagetitle()函数
全部代码:
package com.example.testviewpage_2; import java.util.arraylist; import java.util.list; import android.app.activity; import android.os.bundle; import android.support.v4.view.pageradapter; import android.support.v4.view.viewpager; import android.view.layoutinflater; import android.view.view; import android.view.viewgroup; public class mainactivity extends activity { private view view1, view2, view3; private list<view> viewlist;// view数组 private viewpager viewpager; // 对应的viewpager private list<string> titlelist; @override protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_main); viewpager = (viewpager) findviewbyid(r.id.viewpager); layoutinflater inflater = getlayoutinflater(); view1 = inflater.inflate(r.layout.layout1, null); view2 = inflater.inflate(r.layout.layout2, null); view3 = inflater.inflate(r.layout.layout3, null); viewlist = new arraylist<view>();// 将要分页显示的view装入数组中 viewlist.add(view1); viewlist.add(view2); viewlist.add(view3); titlelist = new arraylist<string>();// 每个页面的title数据 titlelist.add("王鹏"); titlelist.add("姜语"); titlelist.add("结婚"); pageradapter pageradapter = new pageradapter() { @override public boolean isviewfromobject(view arg0, object arg1) { // todo auto-generated method stub return arg0 == arg1; } @override public int getcount() { // todo auto-generated method stub return viewlist.size(); } @override public void destroyitem(viewgroup container, int position, object object) { // todo auto-generated method stub container.removeview(viewlist.get(position)); } @override public object instantiateitem(viewgroup container, int position) { // todo auto-generated method stub container.addview(viewlist.get(position)); return viewlist.get(position); } @override public charsequence getpagetitle(int position) { return titlelist.get(position); } }; viewpager.setadapter(pageradapter); } }
这里的代码与pagertitlestrip的完全相同,就不再讲解了。
就这样,我们就讲完了有关pagertabstrip的简单使用方法。下面讲一讲pagertabstrip的扩展。
3、扩展:pagertabstrip属性更改
在源码中,大家可以看到有个工程叫testviewpage_pagertabstrip_extension,运行一下,效果是这样的:
在上面两个图中可以看到,我更改了两个地方:
(1)下划线颜色,原生是黑色,我变成了绿色;
(2)在tab标题前加了一个图片;
下面说说是如何更改的:
1、更改下划线颜色:
主要靠pagertabstrip的settabindicatorcolorresource方法;
代码如下:
pagertabstrip = (pagertabstrip) findviewbyid(r.id.pagertab); pagertabstrip.settabindicatorcolorresource(r.color.green);
2、添加标题——重写适配器charsequence getpagetitle(int)方法
在charsequence getpagetitle(int position)方法返回值是,我们不返回string对象,而采用spannablestringbuilder来构造了下包含图片的扩展string对像;
具体代码如下,不再细讲,大家可以看看spannablestringbuilder的使用方法,就可理解了。
@override public charsequence getpagetitle(int position) { spannablestringbuilder ssb = new spannablestringbuilder(" "+titlelist.get(position)); // space added before text // for drawable mydrawable = getresources().getdrawable( r.drawable.ic_launcher); mydrawable.setbounds(0, 0, mydrawable.getintrinsicwidth(), mydrawable.getintrinsicheight()); imagespan span = new imagespan(mydrawable, imagespan.align_baseline); foregroundcolorspan fcs = new foregroundcolorspan(color.green);// 字体颜色设置为绿色 ssb.setspan(span, 0, 1, spannable.span_exclusive_exclusive);// 设置图标 ssb.setspan(fcs, 1, ssb.length(), spannable.span_exclusive_exclusive);// 设置字体颜色 ssb.setspan(new relativesizespan(1.2f), 1, ssb.length(), spannable.span_exclusive_exclusive); return ssb; }
上一篇: java使用泛型实现栈结构示例分享
下一篇: 经典mysql连接查询例题
推荐阅读
-
详解Android中ViewPager的PagerTabStrip子控件的用法
-
举例讲解Android中ViewPager中的PagerTitleStrip子控件
-
详解Android App中创建ViewPager组件的方法
-
详解Android App中ViewPager使用PagerAdapter的方法
-
详解Android中fragment和viewpager的那点事儿
-
详解Android中fragment和viewpager的那点事儿
-
Android 中 WebView 的基本用法详解
-
详解ASP.NET数据绑定操作中Repeater控件的用法
-
详解Android中OkHttp3的例子和在子线程更新UI线程的方法
-
Android开发中的重力传感器用法实例详解