ViewPager类直接继承了ViewGroup类,所有它是一个容器类,可以在其中添加其他的View类。

  ViewPager类需要一个PagerAdapter适配器类给它提供数据。

  ViewPager经常和Fragment一起使用,并且提供了专门的FragmentPagerAdapter和FragmentStatePagerAdapter类供Fragment中的ViewPager使用。

ViewPager的功能就是可以使视图滑动,就像Lanucher左右滑动那样。分三个步骤来使用它:

  1.在住布局文件里加入

  2.加载要显示的页卡

  3.在Activity里实例化ViewPager组件,并设置它的Adapter(就是PagerAdapter,方法与ListView一样的),在这里一般需要重写PagerAdapter。

当你实现一个PagerAdapter,你必须至少覆盖以下方法:

  1. instantiateItem(ViewGroup, int) //返回视图对象

  2. destroyItem(ViewGroup, int, Object) //销毁视图对象

  3. getCount() //视图个数

  4. isViewFromObject(View, Object) //一般传入arg0==arg1.用来判断两个视图是否是等价的

XML配置

  <android.support.v4.view.ViewPager

    android:id="@+id/viewpager"  

    android:layout_width="wrap_content"

    android:layout_height="wrap_content" >  

  </android.support.v4.view.ViewPager>

在res/drawable下建立选择器

point_selector.xml 
 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"> <LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<!-- <android.support.design.widget.TabLayout
android:id="@+id/tablelayout"
android:layout_width="match_parent"
android:layout_height="wrap_content" />--> <android.support.v4.view.ViewPager
android:id="@+id/viewPager"
android:layout_width="match_parent"
android:layout_height="match_parent">
<!--系统默认PagerTabStrip和PagerTabStrip指示器的唯一区别是
PagerTabStrip可以点,PagerTabStrip不能点-->
<android.support.v4.view.PagerTabStrip
android:id="@+id/pts"
android:layout_width="match_parent"
android:layout_height="wrap_content"> </android.support.v4.view.PagerTabStrip> </android.support.v4.view.ViewPager>
</LinearLayout>
<LinearLayout
android:id="@+id/ll_points"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_alignParentBottom="true"
android:layout_marginBottom="50dp"
android:layout_centerHorizontal="true"> </LinearLayout>
</RelativeLayout>

activity_main.xml

 public class MainActivity extends AppCompatActivity {

     ViewPager viewPager;
Timer timer;
LinearLayout ll_points;
//TabLayout tablayout; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); viewPager = (ViewPager) findViewById(R.id.viewPager);
initPoints(); //tablayout = (TabLayout) findViewById(R.id.tablayout); viewPager.setAdapter(new MyPagerAdapter()); //指示器也需要在设置适配器之后,还有默认不能设置成无限滚动,所以
//tablayout.setupWithViewPager(viewPager); //必须在设置适配器之后设置默认中间页
//viewPager.setCurrentItem(Integer.MAX_VALUE / 2); viewPager.setCurrentItem(Integer.MAX_VALUE / 2 - Integer.MAX_VALUE / 2 % 6);
//viewPager.setCurrentItem(0);
//设置自动轮播
startAuto(); viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
//无限页
} int currentIndex = 0;//一开始是第0页,已经被选中
@Override
public void onPageSelected(int position) {
//页面选择时
Toast.makeText(MainActivity.this,position+"页",Toast.LENGTH_SHORT).show();
ll_points.getChildAt(currentIndex).setSelected(false);
ll_points.getChildAt(position % 6).setSelected(true);
currentIndex = position % 6;
} @Override
public void onPageScrollStateChanged(int state) {
//状态改变
if (state == ViewPager.SCROLL_STATE_DRAGGING) {
//停止自动滚动
} else {
//开始滚动
}
}
}); } private void initPoints() {
ll_points = (LinearLayout) findViewById(R.id.ll_points);
for (int i = 0; i < 6; i++) {
View view = new View(getBaseContext());
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(20,20);
params.setMargins(10,10,10,10);
view.setBackgroundResource(R.drawable.point_selector);
view.setLayoutParams(params);
ll_points.addView(view);
} //默认第0个被选中
ll_points.getChildAt(0).setSelected(true); } public void startAuto(){
//计时器
timer = new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
//修改UI子线程中修改
runOnUiThread(new Runnable() {
@Override
public void run() {
viewPager.setCurrentItem(viewPager.getCurrentItem()+1);
}
}); }
}, 3000, 3000);
} public void stop(){
if(timer != null){
timer.cancel();
}
} class MyPagerAdapter extends PagerAdapter {
//每一个ViewPager就是一个页面
List<View> mList = new ArrayList<>();
int[] imgId = new int[]{R.mipmap.img01, R.mipmap.img02, R.mipmap.img03, R.mipmap.img04, R.mipmap.img05, R.mipmap.img06}; public MyPagerAdapter(){
for(int i=0; i<6; i++){
ImageView img = new ImageView(getBaseContext());
img.setImageResource(imgId[i]);
img.setScaleType(ImageView.ScaleType.FIT_XY);
mList.add(img);
}
}
@Override
public int getCount() {
//return mList.size();
//轮播设置最大值
return Integer.MAX_VALUE;
} @Override
public boolean isViewFromObject(View view, Object object) {
//判断两页是否相同,google要求这样写
return view == object;
} //加载视图对象,不要弄成View container的函数,这个已经是过期的了
@Override
public Object instantiateItem(ViewGroup container, int position) {
//添加视图到ViewGroup中
container.addView(mList.get(position % 6));
return mList.get(position % 6);
} //销毁一个视图
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView(mList.get(position % 6));
} String[] titles = {"第一页","第二页","第三页","第四页","第五页","第六页"}; //给定系统的指示器的时候,需要重写getPageTitle方法
@Override
public CharSequence getPageTitle(int position) {
return titles[position % 6];
}
} }

MainActivity.java

下面是使用

  android.support.design.widget.TabLayout的效果,需要导入jar studio可以远程依赖

  在布局中添加TabLayout
  在viewPager设置适配器后,调用setupWithViewPager(vp);但是默认不能设置无限页滚动

Android ViewPager PagerAdapter 图片轮播的更多相关文章

  1. Android Viewpager实现图片轮播(仿优酷效果)

    1 http://blog.csdn.net/t12x3456/article/details/8160128 2 http://www.cnblogs.com/androidez/archive/2 ...

  2. 通过ViewPager 实现图片轮播

    通过ViewPager 实现图片轮播 首先来个效果图 布局文件: LinearLayout 用来存放下方的几个小白点. <?xml version="1.0" encodin ...

  3. 用viewpager实现图片轮播

    应用中常常遇到图片轮播的需求,这时候就需要用到viewpager这个组件.viewpager是android support v4 中提供的一个组件.viewpager使用需要以下几步骤: 1.在布局 ...

  4. Android ViewPager实现图片标题轮播和点击事件

    我看别人的文章,最喜欢看有图的.然后先找图看. 那我就先上效果图: 实现了图片自动轮播,手动滑动,轮播标题,以及点击事件.下面开始: 一.资源文件: 首先是布局: <?xml version=& ...

  5. android ViewPager实现的轮播图广告自定义视图,网络获取图片和数据

    public class SlideShowAdView extends FrameLayout { //轮播图图片数量    private static int IMAGE_COUNT = 3;  ...

  6. Viewpager实现图片轮播

    //-------------主布局文件------------------------------------- <LinearLayout xmlns:android="http: ...

  7. Android 使用ViewPager 做的半吊子的图片轮播

    Android 使用ViewPager 做的半吊子的图片轮播 效果图 虽然不咋样,但是最起码的功能是实现了,下面我们来一步步的实现它. 界面 下面我们来分析一下界面的构成 整体的布局: 因为我们要做出 ...

  8. Android 图片轮播(最简单的)

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

  9. Android学习笔记之图片轮播...

    PS:一个bug又折腾了一个下午....哎... 学习内容: 1.Android利用ViewPager和PagerAdapter实现图片轮播... 2.使用反射机制获取Android的资源信息... ...

随机推荐

  1. 做了一个类似天猫鼠标经过icon的动画,记录一下

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. 关于fork( )函数父子进程返回值的问题

    fork()是linux的系统调用函数sys_fork()的提供给用户的接口函数,fork()函数会实现对中断int 0x80的调用过程并把调用结果返回给用户程序. fork()的函数定义是在init ...

  3. BIOS中断大全

    BIOS中断大全 BIOS中断:1.显示服务(Video Service——INT 10H)  00H —设置显示器模式0CH —写图形象素01H —设置光标形状0DH —读图形象素02H —设置光标 ...

  4. Winform使用DevExpress的WaitDialogForm画面

    使用了DevExpress的WaitDialogForm 在应用程序加载开始时新建一个线程,并将loading画面show起来,在应用程序画面弹出前将该线程终止. 代码: private DevExp ...

  5. 详解函数声明VS函数表达式

    函数声明 比方如下:1.我们以一个完整的语句以function开头,不加任何东西. 2.有一个函数名(add) 3.参数可带可不带(x,y) 4.有一个数体 满足以上要求的我们统称为函数声明! 附加小 ...

  6. __call方法简介

    作用:当程序试图调用不存在或不可见的成员方法时,PHP会先调用__call方法来储方法名及参数. __call方法包含两个参数:即方法名和方法参数.其中,方法参数是以数组形式存在的.

  7. jquery.lazyload.js图片延迟加载

    转:http://www.jb51.net/article/50273.htm 这篇文章主要介绍了Jquery图片延迟加载插件jquery.lazyload.js的使用方法,需要的朋友可以参考下   ...

  8. 1s延时程序

    #include <reg52.h>sbit P1_0 = P1^0;void Delay(); // 下面引用时一定要和这里的大小写一致否则会有警告或错误 void Main(){whi ...

  9. DOS命令行使用pscp实现远程文件和文件夹传输(转)

    转自 http://snailwarrior.blog.51cto.com/680306/141201   pscp是putty安装包所带的远程文件传输工具,使用和Linux下scp命令相似,具体的使 ...

  10. 分布式系统间通信之RPC简单Demo(七)

    看似终点,回到起点.第一次接触C#,编写的第一个真正的Demo是基于Socket的简单通信,现在JAVA开始的第一个RPC的Demo也是基于Socket.. 下面通过java原生的序列化,Socket ...