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

ViewPager介绍和使用说明

csdh11 2025-03-11 14:50 16 浏览

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。里面学习内容、面经、项目都比较新也比较全!某鱼上买估计至少要好几十。加微信领取资料

相关推荐

IDEA界面太丑??尝试一下这几个插件

前言IntelliJIDEA主要用于支持Java、Scala、Groovy等语言的开发工具,同时具备支持目前主流的技术和框架,擅长于企业应用、移动应用和Web应用的开发。IntelliJi...

小巧 Vue 页面滚动进度条组件ScrollProgress

今天给大家分享一个轻量级Vue.js全屏滚动进度条组件VueScrollProgress。vue-scroll-progress一款基于vue.js构建的页面滚动进度条组件,...

基于vue实现可视化拖拽编辑器,页面生成工具,提升前端开发效率

项目介绍基于vue实现的可视化拖拽编辑器,实现页面生成工具,提升前端开发效率。可以基层到移动端项目作为自定义json直接生成UI页面。项目特点功能特点...

优秀 vue+heyui 后端管理系统HeyUI-Admin

今天再给小伙伴们推荐一款成熟的企业中后台管理系统HEYUI-Admin。heyui-admin基于vue.js和heyui组件库构建的后台管理系统。包含基础表单/表格功能,拓展组件(图表、富文本编辑...

响应式 Vue.js 前端组件化框架Xvue-UI

今天给小伙伴们推荐一款超不错的Vue轻量级组件框架XVueUI。xvue-ui基于vue2.x构建的响应式前端组件化框架。轻量级、易于上手,提供...

《基于SpringBoot+Vue的在线视频系统设计与实现》开题报告

【计算机毕业设计案例】基于SpringBoot+Vue的在线视频系统设计与实现_哔哩哔哩_bilibili...

超好用 Vue.js 图片裁切组件Vue-ImgCutter

今天给小伙伴们分享一个超棒的Vue图片任意裁剪插件VueImgCutter。vue-img-cutter基于vue2.x构建的轻量级剪切图片组件。支持移动图像、放大缩小图片、任意移动图片、固定比...

Vue 3 进阶用法:异步组件(vue 异步组件原理)

一、代码分割一个大型前端应用,如果所有代码都放在单一文件,体积会特别大,下载时间长,白屏时间久,用户体验差。...

源码补丁神器—patch-package(源码助手怎么用)

作者:张浩一、背景vue项目中使用vue-pdf第三方插件预览pdf,书写业务代码完美运行,pdf文件内容正常预览无问题。后期需求有变,业务需求增加电子签章功能。这个时候pdf文件的内容可以显示出...

经验分享:Vue2 项目升级 Vue3 + Element Plus,借助Deepseek手动升级

Vue3出来好久了,我开发的项目还在使用Vue2框架,一般情况下不考虑升级,但是最近需要接入工作流程引擎之类的,看了下Vue2生态下操作空间不是很好,那索性尝试升级Vue3吧。一番操作下来,升级成功,...

34K Star!史上最全JavaScript资源库 awesome-javascript

34KStar!史上最全JavaScript资源宝库大揭秘引言在GitHub上,有一个备受瞩目的JavaScript资源仓库,以其全面的内容和精心的分类,成为了众多开发者的必备参考。这个拥有超过...

基于 Vue.js 磁片栅格布局组件VueGridLayout

#头条创作挑战赛#今天给大家分享一个超优秀的vue.js拖拽栅格布局插件VueGridLayout。...

6款高颜值 Vue3 PC端UI组件库(vue3开发组件库)

马上到国庆了,还没学习或者想学习vue3的小伙伴们有安排上没?这次推荐几个比较流行的VUE3UI组件库,合理利用,又或者学习借鉴都是不错的选择。1、element-pluselement-plus...

高性能 vue.js+ztree 树形组件Vue-GiantTree

今天给大家分享一款超棒的Vue海量数据渲染树形组件VueGiantTree。vue-giant-tree基于ztree封装的Vue树形组件。轻松实现大数据高性能渲染,适合海量数据渲染场景。zTr...

【推荐】2024年推荐的6款开源免费 Vue 后台管理系统模板,建议收藏

前言在现今的软件开发领域,...