Android开发实战之ViewPager的轮播
在安卓开发的许多控件中,如果你没有使用过ViewPager,就不能算是一个安卓开发工程师,在本篇博文中,我会总结ViewPager的使用方法,
以及一些开发中的拓展。希望本篇博文对你的学习和工作有所帮助。
**ViewPager的基本使用**
ViewPager的使用遵循MVC模式,M(模型),V(视图),C(控制器)。模型就是viewpager对象,视图就是xml视图,控制器就是适配器adapter。所以,
要实现一个完整的ViewPager这三个东西一个都不能少。
xml:
<?xml version="1.0" encoding="utf-8"?>
<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.yakir.myapplication.MainActivity">
<android.support.v4.view.ViewPager
android:layout_width="match_parent"
android:layout_height="200dp"
android:id="@+id/vp"
android:background="#7c3535"></android.support.v4.view.ViewPager>
</RelativeLayout>
viewpager对象:
ViewPager viewPager= (ViewPager) findViewById(R.id.vp);
适配器adapter:
一般的需要我们重写四个方法:
getCount(),返回viewpager显示页数。
isViewFromObject(View view, Object object),返回view==object,这里其实是对viewpager起到了一个优化的作用,具体不细讲,本人比较懒,这里是一般的通用写法。
destroyItem,让viewgroup移除view。
instantiateItem,这个方法用于显示viewpager中的每个view的内容,返回的是object对象。
private class MyAdapter extends PagerAdapter {
@Override
public int getCount() {
//返回viewpager的可滑动页数
return 5;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view==object;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
TextView textView=new TextView(getApplicationContext());
textView.setText("这是第"+(position+1)+"页");
textView.setTextSize(20);
//将这个view加都父容器中
container.addView(textView);
//返回view
return textView;
}
}
将viewpager和adapter关联起来:
viewPager.setAdapter(new MyAdapter());
好了一个简单的viewpager就写好了,让我们看看效果:

**ViewPager拓展实现自动轮播**
自动轮播的viewpager其实很常见了,淘宝手机版,网易新闻等等许多的app都有自动轮播。这就需要我们用到消息传递机制。
首先,让他跳转到下一个界面,我们可以通过viewpager的setCurrentItem设置让其跳转到下一个界面。通过handler的消息机制,
让其在固定的时间发送一条消息,让其更新UI。但是,如果单单只是休息固定时间是远远不够的,因为handler会不断处理消息,这样
我们所要的轮播时间会越来越快,需要在让他轮滑后,再休息一段时间,再进行轮换。具体代码如下:
Handler handler=new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
viewPager.setCurrentItem((viewPager.getCurrentItem()+1)%viewPager.getAdapter().getCount());
handler.postDelayed(new Runnable() {
@Override
public void run() {
handler.obtainMessage().sendToTarget();
}
}, 1000);
}
};
handler.postDelayed(new Runnable() {
@Override
public void run() {
handler.obtainMessage().sendToTarget();
}
},1000);
以下是效果图:

这就是轮播的核心代码思想,为了使用方便我将它封装了起来:
/**
* 对轮播的事件进行封装
*/
private class PagerTask extends Handler implements Runnable {
public void startTask() {
stopTask();
postDelayed(this, 2000);
} public void stopTask() {
removeCallbacksAndMessages(null);
} @Override
public void run() {
vp_carousel.setCurrentItem((vp_carousel.getCurrentItem() + 1) % vp_carousel.getAdapter().getCount());
postDelayed(this, 2000);
}
}
关于轮播,如果你够细心你会发现,当轮播到最后一张图的时候,它是重新跳转到最后一页,而类似于网易新闻,即时位于第一页往左滑动也能进入最后一页,
也就是viewpager的左右滑动,那么这又是如何出现的呢?其实实现方式也比较简单,首先要知道,当Viewpager处于第一页和最后一页的时候是不能滑动的,
那么,只有当viewpager的页数无限大的时候,才可以实现无限的滑动。也就是count为无穷,当你设置最大的时候如何保证显示页数不为无穷呢,我们就需要
对viewpager的位置取余,让他固定显示我们需要显示的viewpager页数。同时还要计算好默认显示的第一页,这样就可以实现无限循环的viewpager了。
viewPager.setCurrentItem(Integer.MAX_VALUE/2-Integer.MAX_VALUE/2%5);//设置当前位置,后面参数为偏差量
@Override
public int getCount() {
//返回viewpager的可滑动页数
return Integer.MAX_VALUE;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
position=position%5;//取余让他只显示5张
TextView textView=new TextView(getApplicationContext());
textView.setText("这是第"+(position+1)+"页");
textView.setTextSize(20);
container.addView(textView);
return textView;
}
以下是效果图:

好了,ViewPager的简单应用就先介绍到这,后面我还会接着介绍有关ViewPager其他相关,如果你觉得博主写的不错,可以推荐一波~,有什么写的不对和不好的地方
欢迎留言指正,互相交流与学习,最后希望这篇博文对各位有所帮助。
Android开发实战之ViewPager的轮播的更多相关文章
- Android 开发最牛的图片轮播控件,基本什么都包含了。
Android图片轮播控件 源码下载地址: Android 图片轮播 现在的绝大数app都有banner界面,实现循环播放多个广告图片和手动滑动循环等功能.因为ViewPager并不支持循环翻页, ...
- Android开发案例 设置背景图片轮播
点击按钮实现图片轮播效果 实践案例: xml <?xml version="1.0" encoding="utf-8"?> <LinearLa ...
- Android开发实战之ViewPager实现向导界面
当我们更新应用,或者第一次进入应用时都会有一个向导界面,介绍这个app的内容和使用方式. 如果你细心你会发现其实这就是个viewpager,本篇博文将介绍应用的向导界面是如何制作的.希 望本篇博文对你 ...
- Android开发之ViewPager实现轮播图(轮播广告)效果的自定义View
最近开发中需要做一个类似京东首页那样的广告轮播效果,于是采用ViewPager自己自定义了一个轮播图效果的View. 主要原理就是利用定时任务器定时切换ViewPager的页面. 效果图如下: 主页面 ...
- Android使用ViewPager做轮播
ViewPager.html div.oembedall-githubrepos { border: 1px solid #DDD; list-style-type: none; margin: 0 ...
- Android真正意义上的无限轮播Banner
在android开发的时候,经常会使用到轮播图,对于这种效果,一般情况下,我们都会使用一种叫做ViewPager的来实现. 传统的实现逻辑是自定义一个View继承ViewPager,在适配器中 将co ...
- Android自己定义控件之轮播图控件
背景 近期要做一个轮播图的效果.网上看了几篇文章.基本上都能找到实现,效果还挺不错,可是在写的时候感觉每次都要单独去又一次在Activity里写一堆代码.于是自己封装了一下.这里仅仅是做了下封装成一个 ...
- Xamarin Android开发实战(上册)大学霸内部资料
Xamarin Android开发实战(上册)大学霸内部资料 试读文档下载地址:http://pan.baidu.com/s/1jGEHhhO 密码:vcfm 介绍: 本教程是国内唯一的Xamar ...
- Android开发实战(申明:来源于网络)
Android开发实战(申明:来源于网络) 地址:http://so.csdn.net/so/search/s.do?q=Android%E5%BC%80%E5%8F%91%E5%AE%9E%E6%8 ...
随机推荐
- Kubernetes Helm
Helm is a tool for managing Kubernetes charts. Charts are packages of pre-configured Kubernetes reso ...
- Adreno Profiler 提取手机游戏资源
https://blog.csdn.net/lly20000/article/details/79774755 step.1 准备工具 1.adb连接工具(我用的cofface adb ) [cof ...
- c#代码加密
源代码保护:怎样利用MaxtoCode加密dotNet源代码 http://www.webkaka.com/blog/archives/MaxtoCode-encrypt-dotnet-program ...
- VLOOKUP函数使用
跟财务老婆学习了个excel函数 -- vlookup函数,记录一下,省得下次用忘了. 需求:有两张表,将第一张表的第二个字段g2去搜索第二张表的字段d2,如果相等,将第二张表的第三个字段追加到第一张 ...
- ecmall 挂件开发实例一
(参考网上相关文章,进行测试点评,下述方法测试成功) 1:在页面上添加要展示的页面模块 <div class="left" area="bottom_foot&q ...
- RK3288 usb 摄像头旋转
系统:Android 5.1 下面实现了摄像头 180 度旋转,旋转角度只需修改 orientation. diff --git a/hardware/rockchip/camera/CameraHa ...
- GOF23设计模式之解释器模式(interpreter)
一.解释器模式概述 (1)它是一种不常用的设计模式: (2)由于描述如何构成一个简单的语言解释器,主要用于使用面向对象语言开发的编译器和解释器的设计: (3)当我们需要开发一种新的语言时,可以考虑使用 ...
- 嵌入式设备snmpd 移植和测试(78K为例)
一.源码目录项内容 agent:编译snmpd程序所需的文件,mibs源文件: apps:其他相关的程序:snmpwalk,snmptrap,snmptest,snmpget,snmpset: mib ...
- Android ListView的item背景色设置
1.如何改变item的背景色和按下颜色 listview默认情况下,item的背景色是黑色,在用户点击时是黄色的.如果需要修改为自定义的背景颜色,一般情况下有三种方法: 1)设置listSelecto ...
- dom4j使用的小例子
product.xml: <?xml version="1.0" encoding="UTF-8"?> <root> <produ ...