百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

ViewPager介绍和使用说明

wptr33 2025-05-23 20:38 57 浏览

ViewPager类提供了多界面切换的新效果。新效果有如下特征:

[1] 当前显示一组界面中的其中一个界面。

[2] 当用户通过左右滑动界面时,当前的屏幕显示当前界面和下一个界面的一部分。

[3]滑动结束后,界面自动跳转到当前选择的界面中。

引用ViewPager控件

ViewPager来源于google 的补充组件android-support-v13.jar,位置在androidSDK文件夹android-sdk-windows\extras\android\compatibility\v13 下将android-support-v13.jar 引用到项目中

下面我们用功能代码来实现效果:

@ MainActivity.java

package cn.com.farsight;

import java.util.ArrayList;

import java.util.List;

import android.app.Activity;

import android.media.Image;

import android.os.Bundle;

import android.support.v4.view.PagerAdapter;

import android.support.v4.view.ViewPager;

import android.view.View;

import android.view.ViewGroup;

import android.widget.ImageView;

public class MainActivity extends Activity {

/* 先说明一下实现ViewPager的两种形式。

* 第一种导入第三方jar包,包的名字是android-support-v4.jar

* 第二种就是应用功能性代码直接实现,在开发当中这种方法已经不用了

*

* android-support-v4.jar在 android3.0 以后出现的。

*

* 我们只要用到adapter就要想到三个步骤:

* 1.初始化控件;

* 2.初始化数据源;

* 3.初始化适配器,往适配器里填充数据。

*

* 首先在布局文件中。

* 这里我们运用第三方的jar包,没有提示功能,所以同学们要记住这届jar包,在开发当中我们经常使用。

*

首先,如果继承pageradapter,至少必须重写下面的四个方法

1. instantiateItem(ViewGroup, int)

2. destroyItem(ViewGroup, int, Object)

3. getCount()

4. isViewFromObject(View, Object)

*

*/

private List list;

private ViewPager mViewPager;

private TestAdapter adapter;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//new Thread()

//初始化控件

mViewPager = (ViewPager) findViewById(R.id.pager);

//初始化数据源,把数据添加到list集合中,

list = new ArrayList();

ImageView iv1 = new ImageView(this);

iv1.setImageResource(R.drawable.huonv);

list.add(iv1);

ImageView iv2 = new ImageView(this);

iv2.setImageResource(R.drawable.shuiren);

list.add(iv2);

ImageView iv3 = new ImageView(this);

iv3.setImageResource(R.drawable.xuemo);

list.add(iv3);

/初始化适配器

adapter = new TestAdapter();

//连接数据与适配器,把数据显示到adapter上

mViewPager.setAdapter(adapter);

}

private class TestAdapter extends PagerAdapter{

//计算页卡数量

// 获取要滑动的控件的数量,在这里我们以滑动的页卡为例,那么这里就应该是展示的页卡图片的ImageView数量

@Override

public int getCount() {//这个方法,是获取当前窗体界面数

// TODO Auto-generated method stub

return list.size();//返回页卡的数量

}

//而isViewFromObject方法是用来判断pager的一个view是否和instantiateItem方法返回的object有关联

/* ViewPager源码,你去看下addNewItem方法,会找到instantiateItem的使用方法,注意这里的mItems变量。

* 然后你再搜索下isViewFromObject,会发现其被infoForChild方法调用,返回值是ItemInfo。再去看下ItemInfo的结构,

* 其中有一个object对象,该值就是instantiateItem返回的。

*

*

* 也就是说,ViewPager里面用了一个mItems(ArrayList)来存储每个page的信息(ItemInfo),

* 当界面要展示或者发生变化时,需要依据page的当前信息来调整,但此时只能通过view来查找,

* 所以只能遍历mItems通过比较view和object来找到对应的ItemInfo。

*

*/

// 来判断显示的是否是同一张图片,这里我们将两个参数相比较返回即可

@Override

public boolean isViewFromObject(View arg0, Object arg1) {

// TODO Auto-generated method stub

return arg0 == arg1;

}

// PagerAdapter只缓存三张要显示的图片,如果滑动的图片超出了缓存的范围,就会调用这个方法,将图片销毁

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

//super.destroyItem(container, position, object);

container.removeView(list.get(position));

}

//这个方法,return一个对象,这个对象表明了PagerAdapter适配器选择哪个对象*放在当前的ViewPager中

//这个方法用来实例化页卡

// 用这个方法当要显示的图片可以进行缓存的时候,会调进行显示图片的初始化,我们将要显示的ImageView加入到ViewGroup中,然后作为返回值返回即可

@Override

public Object instantiateItem(ViewGroup container, int position) {

container.addView(list.get(position));//添加页卡

return list.get(position);

}

}

}

布局文件

@activity_main.xml

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context=".MainActivity"

<>

android:id="@+id/pager"

android:layout_width="fill_parent"

android:layout_height="match_parent"/>


这样我们的ViewPager就介绍完了。希望你们能够喜欢。

嵌入式物联网需要学的东西真的非常多,千万不要学错了路线和内容,导致工资要不上去!

无偿分享大家一个资料包,差不多150多G。里面学习内容、面经、项目都比较新也比较全!某鱼上买估计至少要好几十。加微信领取资料

相关推荐

oracle数据导入导出_oracle数据导入导出工具

关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

继续学习Python中的while true/break语句

上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...

python continue和break的区别_python中break语句和continue语句的区别

python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

简单学Python——关键字6——break和continue

Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

Python 中 break 和 continue 傻傻分不清

大家好啊,我是大田。...

python中的流程控制语句:continue、break 和 return使用方法

Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

L017:continue和break - 教程文案

continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

作为前端开发者,你都经历过怎样的面试?

已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

面试被问 const 是否不可变?这样回答才显功底

作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

2023金九银十必看前端面试题!2w字精品!

导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...

前端面试总结_前端面试题整理

记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

由浅入深,66条JavaScript面试知识点(七)

作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...

2024前端面试真题之—VUE篇_前端面试题vue2020及答案

添加图片注释,不超过140字(可选)...

今年最常见的前端面试题,你会做几道?

在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...