一、概述

ViewPager是android-support-v4中提供的类,它是一个容器类,常用于页面之间的切换。

本文介绍ViewPager最基础的应用:在多个View之间进行切换,亦即ViewPager的每个页面是个View。

这种模式适合每个页面的逻辑较为简单的情况,比如去实现“小红书”引导页这样的效果:

二、实现思路

2.1 页面如何布局

这个引导页一共有三个页面,毫无疑问上面的标题和配图是隶属于viewpager不同页面内部的,而下面的俩按钮则是直接放在Activity的布局中。

那indicator呢?虽然在不同的页面红点的位置不一样,但它不能放在页面的布局中,否则,三个点就会跟配图一样整体滑动了……

2.2 代码如何实现

ViewPager是什么鬼呢?其实它就是个ViewGroup,用法跟ListView类似,重点在于实现这样一个Adapter:

     private class ViewPagerAdapter extends PagerAdapter {
@Override
public int getCount() {
return 0; //ViewPager总共有几个页面
} @Override
public boolean isViewFromObject(View view, Object object) {
return false; //判断一个页面(View)是否与instantiateItem方法返回的Object一致
} @Override
public Object instantiateItem(ViewGroup container, int position) {
return super.instantiateItem(container, position); //创建一个页面
} @Override
public void destroyItem(ViewGroup container, int position, Object object) {
super.destroyItem(container, position, object); //销毁一个页面
}
}

[转载请保留本文地址:http://www.cnblogs.com/snser/p/5700751.html]

三、开始干活

3.1 摆出activity和每个页面的布局

viewpager_view.xml (activity的布局)

 <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"
android:background="@drawable/viewpager_view_bg"
tools:context="${relativePackage}.${activityClass}" > <android.support.v4.view.ViewPager
android:id="@+id/viewpager_view_pager"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/viewpager_view_bg" /> <ImageView
android:id="@+id/viewpager_view_point"
android:layout_width="66.7dp"
android:layout_height="10dp"
android:layout_centerHorizontal="true"
android:layout_above="@+id/viewpager_view_register"
android:layout_marginBottom="20dp"
android:src="@drawable/viewpager_view_point_1" /> <Button
android:id="@+id/viewpager_view_register"
android:layout_width="190dp"
android:layout_height="45dp"
android:layout_centerHorizontal="true"
android:layout_above="@+id/viewpager_view_login"
android:layout_marginBottom="10dp"
android:background="@drawable/viewpager_view_register_bg"
android:textSize="19sp"
android:textColor="#FFFFFF"
android:text="@string/viewpager_view_register" /> <Button
android:id="@+id/viewpager_view_login"
android:layout_width="190dp"
android:layout_height="45dp"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="50dp"
android:background="@drawable/viewpager_view_login_bg"
android:textSize="19sp"
android:textColor="#999999"
android:text="@string/viewpager_view_login" /> </RelativeLayout>

viewpager_view_page.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="${relativePackage}.${activityClass}" > <TextView
android:id="@+id/viewpager_view_page_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
android:layout_centerHorizontal="true"
android:textSize="20sp"
android:textColor="#333333"
android:text="@string/viewpager_view_page_title_1" /> <ImageView
android:id="@+id/viewpager_view_page_content"
android:visibility="visible"
android:layout_width="match_parent"
android:layout_height="385dp"
android:layout_marginTop="75dp"
android:layout_gravity="center_horizontal"
android:scaleType="centerInside"
android:src="@drawable/viewpager_view_page_content_1" /> </RelativeLayout>

3.2 简要介绍一下即将出炉的核心代码

 public class ViewPagerViewActivity extends Activity implements View.OnClickListener {

     private ViewPager mPager;
private ImageView mImgPoint; private SparseArray<View> mPageCache = new SparseArray<View>(); @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.viewpager_view);
initView();
} private void initView() {
mPager = (ViewPager)findViewById(R.id.viewpager_view_pager);
mImgPoint = (ImageView)findViewById(R.id.viewpager_view_point);
mPager.setAdapter(new ViewPagerAdapter(ViewPagerViewActivity.this));
mPager.addOnPageChangeListener(new OnViewPageChangeListener());
findViewById(R.id.viewpager_view_register).setOnClickListener(this);
findViewById(R.id.viewpager_view_login).setOnClickListener(this);
} private class ViewPagerAdapter extends PagerAdapter {
private final int mCount = 3;
private LayoutInflater mInflater; private ViewPagerAdapter(Context context) {
mInflater = LayoutInflater.from(context);
} @Override
public int getCount() {
return mCount;
} @Override
public boolean isViewFromObject(View view, Object obj) {
return view == obj;
} @Override
public Object instantiateItem(ViewGroup container, int position) {
View page = mPageCache.get(position);
if (page == null) {
page = mInflater.inflate(R.layout.viewpager_view_page, container, false);
TextView txtTitle = (TextView)page.findViewById(R.id.viewpager_view_page_title);
ImageView imgContent = (ImageView)page.findViewById(R.id.viewpager_view_page_content);
switch (position) {
case 0:
txtTitle.setText(R.string.viewpager_view_page_title_1);
imgContent.setImageResource(R.drawable.viewpager_view_page_content_1);
break;
case 1:
txtTitle.setText(R.string.viewpager_view_page_title_2);
imgContent.setImageResource(R.drawable.viewpager_view_page_content_2);
break;
case 2:
txtTitle.setText(R.string.viewpager_view_page_title_3);
imgContent.setImageResource(R.drawable.viewpager_view_page_content_3);
break;
default:
break;
}
mPageCache.append(position, page);
}
container.addView(page);
return page;
} @Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View)object);
}
} private class OnViewPageChangeListener implements OnPageChangeListener {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
} @Override
public void onPageSelected(int position) {
switch (position) {
case 0:
mImgPoint.setImageResource(R.drawable.viewpager_view_point_1);
break;
case 1:
mImgPoint.setImageResource(R.drawable.viewpager_view_point_2);
break;
case 2:
mImgPoint.setImageResource(R.drawable.viewpager_view_point_3);
break;
default:
break;
}
} @Override
public void onPageScrollStateChanged(int state) {
}
} @Override
public void onClick(View v) {
finish();
}
}

重点关注下 ViewPagerAdapter :

在 instantiateItem 方法中会inflate出新的页面,再根据不同的position对页面进行对应的初始化工作,同时在ViewPager中添加当前页面。

而在 destroyItem 方法中,只需要将当前页面从ViewPager中移除即可。

同时,需要给ViewPager设置一个 OnPageChangeListener ,以便在页面切换的时候更新Indicator对应的小红点位置。

3.3 关于缓存

可以看到,上面的代码在 instantiateItem 方法中用到了页面缓存,亦即每个position对应的页面只需要inflate一次。

那为什么会有缓存的需求呢?这是因为ViewPager每次加载当前页面的同时,会自动预加载(instantiateItem)与当前页面左右相隔的两个页面,同时会销毁(destroyItem)与当前页面不相邻的页面。

设想一下,滑动到第三个页面时,第一个页面会被销毁掉,而滑回第二个页面时,又会重新创建第一个页面。如果不加以缓存,就会造成页面的重复inflate从而浪费资源、降低性能。

[转载请保留本文地址:http://www.cnblogs.com/snser/p/5700751.html]

四、demo工程

保存下面的图片,扩展名改成 .zip 即可

 [转载请保留本文地址:http://www.cnblogs.com/snser/p/5700751.html] 

ViewPager之引导页的更多相关文章

  1. ViewPager实现引导页

    1. 要使用ViewPager,必须要创建 PagerAdapter. 这里创建一个 ViewPagerAdapter来继承PagerAdapter public class ViewPagerAda ...

  2. ViewPager实现引导页(添加导航点,判断是否第一次进入主界面)

    1.引导页的4个界面布局,里面加载一张背景图片 插入到guide的界面布局中(这里不用fragment) guide_background_fragment1.xml <?xml version ...

  3. ViewPager滑动引导页

    ViewPager实现Animation动画引导页   http://blog.csdn.net/ye_scofield/article/details/44831357 SurfaceView实现动 ...

  4. ViewPager—01引导页的制作

    布局文件 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:t ...

  5. 安卓第一次启动引导页使用ViewPager实现

    我们在安装某个APP的时候,基本都会有一个引导页的提示,他们可以打广告,或者介绍新功能的加入和使用说明等.一般都支持滑动并且下面有几个点,显示共有多少页和当前图片的位置,在IOS上这个实现起来比较简单 ...

  6. ViewPager打造轮播图(Banner)\引导页(Guide)

    今年7月时,在Github发布了一个开源的Banner库,虽然Star不多,但还是有少部分人使用. Banner效果:  昨天,有使用此库的同学提出需求,想在引导页的时候用这个库并且最后一页有进入按钮 ...

  7. Android ViewPager欢迎页+引导页+进入首页

    import android.app.Activity; import android.content.Intent; import android.content.SharedPreferences ...

  8. android使用ViewPager实现欢迎引导页

    android使用ViewPager实现欢迎引导页 大多数APP第一次启动的时候,都会有一个引导界面,左右滑动,到最后一张,用户点击才再次进入主界面.当第二次启动的时候,则直接进入主界面. 这种效果一 ...

  9. Android特效专辑(二)——ViewPager渲染背景颜色渐变(引导页)

    Android特效专辑(二)--ViewPager渲染背景颜色渐变(引导页) 首页:http://blog.csdn.net/qq_26787115/article/details/50439020 ...

随机推荐

  1. MonoDevelop 4.2.2/Mono 3.4.0 in CentOS 6.5 安装笔记

    MonoDevelop 4.2.2/Mono 3.4.0 in CentOS 6.5 安装笔记 说明 以root账户登录Linux操作系统,注意:本文中的所有命令行前面的 #> 表示命令行提示符 ...

  2. Flume1 初识Flume和虚拟机搭建Flume环境

    前言:       工作中需要同步日志到hdfs,以前是找运维用rsync做同步,现在一般是用flume同步数据到hdfs.以前为了工作简单看个flume的一些东西,今天下午有时间自己利用虚拟机搭建了 ...

  3. UWP开发:APP之间的数据交互(以微信为例)

    目录 说明 UWP应用唤醒方式 跟微信APP交互数据 APP之间交互数据的前提 说明 我们经常看到,在手机上不需要退到桌面,APP之间就可以相互切换,并且可以传递数据.比如我在使用知乎APP的时候,需 ...

  4. MapReduce剖析笔记之七:Child子进程处理Map和Reduce任务的主要流程

    在上一节我们分析了TaskTracker如何对JobTracker分配过来的任务进行初始化,并创建各类JVM启动所需的信息,最终创建JVM的整个过程,本节我们继续来看,JVM启动后,执行的是Child ...

  5. 小丁带你走进git的世界二-工作区暂存区分支

    小丁带你走进git的世界二-工作区暂存区分支 一.Git基本工作流程 1.初始化一个仓库 git  init git  clone git仓库分为两种情况: 第一种是在现有项目或目录下导入所有文件到 ...

  6. Module Zero学习目录

    Module-Zero是实现了ASP.NET Boilerplate框架抽象概念的模块,对于企业web应用也添加了一些有用的东西: 实现了ASP.NET Identity框架的用户和角色管理. 提供了 ...

  7. maven archetype二三事

    maven plugin 创建maven archetype 骨架的plugin是 <plugin> <groupId>org.apache.maven.plugins< ...

  8. Nginx服务器之Nginx与tomcat结合访问jsp

    本文使用linux centos系统 本文概述: JSP是一种动态网页技术标准.使用的方式是在HTML文件中插入程序段和JSP标记,而形成JSP文件.使用JSP开发WEB应用可以跨平台开发.但jsp需 ...

  9. 游戏服务器菜鸟之C#初探四游戏服务

    经过多次折腾之后,在一次进行了一次重大的重构,去解决问题 主要重构如下 1.将原来的单一协议修改多协议进行,一些查询.认证的功能都采用HTTP进行,避免全部采用TCP链接资源的消耗: 2.原来单一的部 ...

  10. VS2015企业版本(安装包+key)+ .NET Reflector 9.0

    Reflector9.0系下载:https://yunpan.cn/cMQj9zWbffSqy  访问密码 55eb VS2015中文企业版: http://pan.baidu.com/s/1eRIo ...