iis服务器助手广告
返回顶部
首页 > 资讯 > 移动开发 >Android viewpager使用
  • 258
分享到

Android viewpager使用

androidandroidstudio 2023-09-07 21:09:08 258人浏览 安东尼
摘要

一、viewpager简介 viewpager是一个简单的页面切换组件,可以通过往里面填充多个View,然后我们可以左 右滑动,从而切换不同的View。Viewpager主要是通过创建adapter给它填充多个view,左右滑动时,切换不同

一、viewpager简介

viewpager是一个简单的页面切换组件,可以通过往里面填充多个View,然后我们可以左 右滑动,从而切换不同的View。Viewpager主要是通过创建adapter给它填充多个view,左右滑动时,切换不同的view来实现效果。

二、主要方法说明

ViewPager 直接继承了 ViewGroup,所以它是一个容器类,可以在其中添加其他的 view 类。
ViewPager 需要一个 PagerAdapter 适配器类给它提供数据。
ViewPager 经常和 Fragment 一起使用,并且提供了专门的 FragmentPagerAdapter 和 FragmentStatePagerAdapter 类供 Fragment 中的 ViewPager 使用。

setAdapter(PagerAdapter adapter)
该方法为ViewPager设置适配器,ViewPager有三种适配器,它们分别有不同的特性,下面我会对这三种适配器进行讲解。
2、setCurrentItem(int item)
该方法设置显示item位置的界面。
3、setOffscreenPageLimit(int limit)
该方法用来设置当前显示页面左右两边各缓存的页面数。
4、addOnPageChangeListener(OnPageChangeListener listener)
该方法为ViewPager添加页面切换时的监听
5、setOnScrollChangeListener(OnScrollChangeListener l)
该方法为ViewPager增加滚动状态监听

OnPageChangeListener的三个方法:

onPageScrollStateChanged(int state)

该方法在手指操作屏幕的时候发生变化。有三个值:0(END),1(PRESS) ,2(UP) 。当用手指滑动翻页时,手指按下去的时候会触发这个方法,state值为1,手指抬起时,如果发生了滑动(即使很小),这个值会变为2,然后最后变为0 。总共执行这个方法三次。一种特殊情况是手指按下去以后一点滑动也没有发生,这个时候只会调用这个方法两次,state值分别是1,0 。当setCurrentItem翻页时,会执行这个方法两次,state值分别为2 ,0 。
onPageScrolled(int position, float positionOffset, int positionOffsetPixels)

该方法在滑动过程中将一直被调用,该方法的参数说明如下:
position:当用手指滑动时,如果手指按在页面上不动,position和当前页面index是一致的;如果手指向左拖动(相应页面向右翻动),这时候position大部分时间和当前页面是一致的,只有翻页成功的情况下最后一次调用才会变为目标页面;如果手指向右拖动(相应页面向左翻动),这时候position大部分时间和目标页面是一致的,只有翻页不成功的情况下最后一次调用才会变为原页面。当直接设置setCurrentItem翻页时,如果是相邻的情况(比如现在是第二个页面,跳到第一或者第三个页面),如果页面向右翻动,大部分时间是和当前页面是一致的,只有最后才变成目标页面;如果向左翻动,position和目标页面是一致的。这和用手指拖动页面翻动是基本一致的。如果不是相邻的情况,比如我从第一个页面跳到第三个页面,position先是0,然后逐步变成1,然后逐步变成2;我从第三个页面跳到第一个页面,position先是1,然后逐步变成0,并没有出现为2的情况。
positionOffset:当前页面滑动比例,如果页面向右翻动,这个值不断变大,最后在趋近1的情况后突变为0。如果页面向左翻动,这个值不断变小,最后变为0。
positionOffsetPixels:当前页面滑动像素,变化情况和positionOffset一致。

onPageSelected(int position)

position是被选中页面的索引,该方法在页面被选中或页面滑动足够距离切换到该页手指抬起时调用。

三者关系:

三个方法的执行顺序:用手指拖动翻页时,最先执行一遍onPageScrollStateChanged(1),然后不断执行onPageScrolled,放手指的时候,直接立即执行一次onPageScrollStateChanged(2),然后立即执行一次onPageSelected,然后再不断执行onPageScrollStateChanged,最后执行一次onPageScrollStateChanged(0)。
简而言之 即:

onPageScrolled:在屏幕滑动过程中被调用。

onPageSelected:代表哪个页面被选中。

onPageScrollStateChanged:在手指操作屏幕时被调用

三、viewpager实例

viewpager的实例一:

mainActivity.java中初始化并使用,如下:

mainActivity.java文件

public ViewPager vp;ArrayList viewlist;myPagerAdapter mypageradapter;vp = findViewById(R.id.viewpager);viewlist = new ArrayList<>();LayoutInflater li = getLayoutInflater();viewlist.add(li.inflate(R.layout.activity1,null,false));viewlist.add(li.inflate(R.layout.activity2,null,false));viewlist.add(li.inflate(R.layout.activity3,null,false));mypageradapter = new myPagerAdapter(viewlist);vp.setAdapter(mypageradapter);

myPagerAdapter类的实现

适配器myPagerAdapter.java文件

package com.testviewpager;import Android.view.View;import android.view.ViewGroup;import androidx.annotation.NonNull;import androidx.viewpager.widget.PagerAdapter;import java.util.ArrayList;public class myPagerAdapter extends PagerAdapter{private ArrayList viewlist;public myPagerAdapter(ArrayList viewList){viewlist = viewList;}@Overridepublic int getCount() {return viewlist == null ? 0: viewlist.size();}@Overridepublic Object instantiateItem(ViewGroup container, int position) {container.addView(viewlist.get(position));return viewlist.get(position);}@Overridepublic void destroyItem(ViewGroup container, int position, Object object) {container.removeView(viewlist.get(position));}@Overridepublic boolean isViewFromObject(@NonNull View view, @NonNull Object object) {return view == object;}}

主xml文件布局配置如下:

activity_main.xml文件

各个activity xml的实现

activity1.xml文件

activity2.xml文件

activity2.xml文件

activity3.xml文件

注:

使用PagerAdapter必须重写的四个方法:

getCount(): 获得viewpager中有多少个view

destroyItem(): 移除一个给定位置的页面。适配器有责任从容器中删除这个视图。 这是为了确保在finishUpdate(viewGroup)返回时视图能够被移除。

instantiateItem(): ①将给定位置的view添加到ViewGroup(容器)中,创建并显示出来 ②返回一个代表新增页面的Object(key),通常都是直接返回view本身就可以了,当然你也可以 自定义自己的key,但是key和每个view要一一对应的关系

isViewFromObject(): 判断instantiateItem(ViewGroup, int position)函数所返回来的Key与一个页面视图是否是 代表的同一个视图(即它俩是否是对应的,对应的表示同一个View),通常我们直接写 return view == object!

实例二:

带有标题的滑动

PagerTabStrip: 带有下划线

activity_main.xml

适配器文件myPagerAdapterSec.java

package com.testviewpager;import android.view.View;import android.view.ViewGroup;import androidx.annotation.NonNull;import androidx.annotation.Nullable;import androidx.viewpager.widget.PagerAdapter;import java.util.ArrayList;public class myPagerAdapterSec extends PagerAdapter{private ArrayList viewlist;private ArrayList titleList;public myPagerAdapterSec(ArrayList viewList, ArrayList titleList){viewlist = viewList;this.titleList = titleList;}@Overridepublic int getCount() {return viewlist == null ? 0: viewlist.size();}@Overridepublic Object instantiateItem(ViewGroup container, int position) {container.addView(viewlist.get(position));return viewlist.get(position);}@Overridepublic void destroyItem(ViewGroup container, int position, Object object) {container.removeView(viewlist.get(position));}@Overridepublic boolean isViewFromObject(@NonNull View view, @NonNull Object object) {return view == object;}@Nullable@Overridepublic CharSequence getPageTitle(int position) {return titleList.get(position);}}

主mainActivity.java文件

package com.testviewpager;import androidx.appcompat.app.AppCompatActivity;import androidx.viewpager.widget.ViewPager;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import java.util.ArrayList;public class MainActivity extends AppCompatActivity {public ViewPager vp;ArrayList viewlist;//myPagerAdapter mypageradapter;myPagerAdapterSec mypageradaptersec;ArrayList titleList;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);vp = findViewById(R.id.viewpager);viewlist = new ArrayList<>();LayoutInflater li = getLayoutInflater();viewlist.add(li.inflate(R.layout.activity1,null,false));viewlist.add(li.inflate(R.layout.activity2,null,false));viewlist.add(li.inflate(R.layout.activity3,null,false));// mypageradapter = new myPagerAdapter(viewlist);// vp.setAdapter(mypageradapter);titleList = new ArrayList<>();titleList.add("第一个");titleList.add("第二个");titleList.add("第三个");mypageradaptersec = new myPagerAdapterSec(viewlist,titleList);vp.setAdapter(mypageradaptersec);}}

来源地址:https://blog.csdn.net/qq_33782617/article/details/126912514

--结束END--

本文标题: Android viewpager使用

本文链接: https://www.lsjlt.com/news/399096.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android viewpager使用
    一、viewpager简介 viewpager是一个简单的页面切换组件,可以通过往里面填充多个View,然后我们可以左 右滑动,从而切换不同的View。Viewpager主要是通过创建adapter给它填充多个view,左右滑动时,切换不同...
    99+
    2023-09-07
    android android studio
  • Android中viewpager怎么使用
    在Android中,ViewPager是一个可以左右滑动的容器,可以用来显示多个页面,并且可以通过滑动或者点击指示器来切换页面。以下...
    99+
    2023-08-26
    Android viewpager
  • Android中ViewPager如何使用WebView
    小编给大家分享一下Android中ViewPager如何使用WebView,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Android 中ViewPager中使用...
    99+
    2023-05-30
    android viewpager webview
  • android viewpager组件怎么使用
    Android中的ViewPager是一种用于显示多个页面的组件,可以通过滑动来切换页面。下面是使用ViewPager的一般步骤:1...
    99+
    2023-10-08
    android
  • Android 之 ViewPager 的简单使用
    本节引言: 本节带来的是Android 3.0后引入的一个UI控件——ViewPager(视图滑动切换工具),实在想不到 如何来称呼这个控件,他的大概功能:通过手势滑动可以完成View的切换,一般是用来做APP 的引导页或者实现图片轮播...
    99+
    2023-09-13
    android 动画
  • Android使用ViewPager实现翻页效果
    本文实例为大家分享了Android使用ViewPager实现翻页效果的具体代码,供大家参考,具体内容如下 效果如图所示: 代码实现: 1.布局代码:activity_view_pa...
    99+
    2024-04-02
  • android viewpager的用法是什么
    Android ViewPager是一种用户界面组件,用于在应用程序中显示多个页面,并允许用户通过滑动手势在这些页面之间进行切换。它...
    99+
    2023-09-29
    android
  • Android使用ViewPager实现顶部tabbar切换界面
    类似的功能可以看看: 使用RadioGroup实现底部导航栏 进入正题效果图: 注:PagerSlidingTabStrip为自定义控件,用于切换界面,此处不便贴出代码 主界面xml布局中添加ViewPager控件: <android...
    99+
    2023-05-30
    viewpager tabbar 切换
  • Android使用ViewPager实现启动引导页效果
    本文实例为大家分享了Android实现启动引导页效果的具体代码,供大家参考,具体内容如下 ViewPagerTwoActivity.java package cn.edu.zu...
    99+
    2024-04-02
  • Android在ViewPager中如何使用Fragment的懒加载
    这篇文章给大家分享的是有关Android在ViewPager中如何使用Fragment的懒加载的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。我们先看一下效果:首先,我们要知道什么是懒加载:懒加载,就是先初始化控件...
    99+
    2023-05-31
    android fragment viewpager
  • Android怎么使用ViewPager实现画廊Gallery效果
    本篇内容介绍了“Android怎么使用ViewPager实现画廊Gallery效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在手机QQ上...
    99+
    2023-06-19
  • android : 底部导航栏的实现(使用ViewPager和BottomNavigationView)
      本案例中需要用的控件ViewPager和BottomNavigationView ViewPager:主要是页面的切换Fragment:碎片(也就是每个页面的内容)BottomNavigationView:底部导航栏 非常简单,主要就...
    99+
    2023-09-01
    android android studio ide
  • Android中fragment+viewpager实现布局
    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下先布局实现mian.xml<?xml version="1.0" encoding="utf-8"?> <Relative...
    99+
    2023-05-30
    fragment viewpager 布局
  • android viewpager实现轮播效果
    本文是基于ViewPager实现的无限自动轮播banner,供大家参考,具体内容如下 分为四步去实现: 第一步是有限手动轮播; 第二步是无限轮播; 第三步是自动轮播; 第四步是指示...
    99+
    2024-04-02
  • Android使用ViewPager实现启动引导页效果的案例
    这篇文章将为大家详细讲解有关Android使用ViewPager实现启动引导页效果的案例,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下ViewPagerTwoActivity.javapack...
    99+
    2023-06-14
  • 在android中使用ViewPager怎么实现无限轮播功能
    这篇文章给大家介绍在android中使用ViewPager怎么实现无限轮播功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、布局<&#63;xml version="1.0" en...
    99+
    2023-05-31
    viewpager android age
  • Android ViewPager小圆点指示器
    一个很常用的功能,一个ViewPager会自动滚动,并且有一排小圆点黑和白来指示当前的滚动进度 首先写一个ViewPager的适配器,这里这个适配器为了方便里面的元素全都是Imag...
    99+
    2024-04-02
  • Android应用中如何动态加载ViewPager
    本篇文章为大家展示了Android应用中如何动态加载ViewPager,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。今天做项目时,纠结了很久,动态添加view,刚开始按照其他的adapter处理,但...
    99+
    2023-05-31
    android viewpager age
  • Android开发中使用ViewPager实现一个轮翻图效果
    Android开发中使用ViewPager实现一个轮翻图效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。具体方法如下:import java.util.ArrayList...
    99+
    2023-05-31
    android viewpager age
  • 如何在Android项目中使用ViewPager对radiogroup进行关联
    如何在Android项目中使用ViewPager对radiogroup进行关联?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Android ViewPager与radiog...
    99+
    2023-05-31
    android viewpager radiogroup
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作