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

Android中viewPager使用指南

viewpagerAndroid 2022-06-06 09:06:05 328人浏览 安东尼
摘要

viewPager是谷歌官方提供的一种方便实现页面滑动效果的控件,可以直接使用也可以和fragment联合使用。这里只简单说下直接使用。  使用viewPager的步

viewPager是谷歌官方提供的一种方便实现页面滑动效果的控件,可以直接使用也可以和fragment联合使用。这里只简单说下直接使用。
 使用viewPager的步骤如下:

(1)在布局中放入viewPager的控件
 (2)设置加载到viewPager中的view
 (3)编写viewPager特有的adapter
 (4)实例化viewPager并给他绑定上步设置的adapter

这个步骤体现的也是mvc思想,可以参考我之前的文章//www.jb51.net/article/78174.htm

这里为了方便说明 我新建一个项目来说明viewPager的使用

步骤一 在布局中新建一个viewPager

布局文件如下:


<Android.support.v4.view.ViewPager
    android:id="@+id/view_pager"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
</android.support.v4.view.ViewPager>

设置加载到viewPager中的view

这里为了方便,显示设置2个不同背景的颜色的view,放入viewPager中,每个view的布局如下图:
 item_one


<LinearLayout xmlns:android="Http://schemas.android.com/apk/res/android"
       android:layout_width="match_parent"
       android:layout_height="match_parent"
  android:background="@android:color/holo_red_light">
</LinearLayout>

item_two


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
       android:layout_width="match_parent"
       android:layout_height="match_parent"
  android:background="@android:color/holo_blue_bright">
</LinearLayout>

编写viewPager特有的adpter

这里我们继承viewPager的PagerAdapter,主要重写getCount方法、destroyItem 、instantiateItem 、isViewFromObject 、。代码如下:


public class Adapter extends PagerAdapter{
    private List<View> views;
    public Adapter(List<View> views){
      this.views = views;
    }
    @Override
    public int getCount() {
      return views.size();
    }
    @Override
    public void destroyItem(View arg0, int arg1, Object arg2) {
      ((ViewPager) arg0).removeView(views.get(arg1));
    }
    @Override
    public void finishUpdate(View arg0) {
    }
    @Override
    public Object instantiateItem(View arg0, int arg1) {
      ((ViewPager) arg0).addView(views.get(arg1), 0);
      return views.get(arg1);
    }
    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
      return arg0 == (arg1);
//      return false;
    }
    @Override
    public void restoreState(Parcelable arg0, ClassLoader arg1) {
    }
    @Override
    public Parcelable saveState() {
      return null;
    }
    @Override
    public void startUpdate(View arg0) {
    }
  }

实例化viewPager并绑定Adapter

这里,实例化viewPager 为mpager ,然后将建好的view:item_one 和item_two 通过LayoutInflater加载到建好的View类型的数组中。将数组加到List<View>里面。作为参数传入到adapter。代码如下:


private ViewPager mpager;
  private List<View> myview = new ArrayList<>();
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mpager = (ViewPager) findViewById(R.id.view_pager);
    LayoutInflater mInflater = getLayoutInflater();
    View [] pagers = {mInflater.inflate(R.layout.item_one ,null),
              mInflater.inflate(R.layout.item_two , null)};
    for(int i = 0; i < pagers.length ; i++) {
      myview.add(pagers[i]);
    }
    Adapter ad = new Adapter(myview);
    mpager.setAdapter(ad);
    mpager.setCurrentItem(0);
  }

PS :实现viewPager手动无限循环

这里用一种设置页面跳转的方式来实现无限循环。在myviews数组中加入两个view,分别在第0个位置加入最后一个itemview,和最后一个位置加入第一个itemview。代码如下所示:


final View [] pagers = {mInflater.inflate(R.layout.item_one ,null),
              mInflater.inflate(R.layout.item_two , null),
              mInflater.inflate(R.layout.item_three,null)};
    for(int i = 0; i < pagers.length ; i++) {
      myview.add(pagers[i]);
    }
    myview.add(0,mInflater.inflate(R.layout.item_three , null));
    myview.add(4, mInflater.inflate(R.layout.item_one, null));

这里为了测试方便,这里在上个基础上加入了一个item,就是三张view循环播放
 用来实现衔接。当向右滑动到最后一个页面的时候,将这个页指定为第一个view所在的页,向左滑动到第一个页面的时候,将这个页面制定为最后一个view所在页。注意这里的view最后一个不是指数组的最后一个 而是指三个view中最后一个。

设置viewPager的实例化对象的方法setOnPageChangeListener 虽然此方法显示不推荐使用,但为了实现这个功能,还是先将就用吧。等日后谷歌更新viewPager,能有属性自动实现循环。
 代码如下:


 mpager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
      @Override
      public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
      }
      @Override
      public void onPageSelected(int position) {
        int index = position;
        if(index == 0){
        //注意这里pagers数组,不是myviews数组
          index = pagers.length;
        }else if(position == pagers.length + 1){
          index = 1;
        }
        if(position != index){
          mpager.setCurrentItem(index, false);
        }
      }
      @Override
      public void onPageScrollStateChanged(int state) {
      }
    });

重写Adapter中的instantiateItem 方法来显示view


public Object instantiateItem(View arg0, int arg1) {
      if(arg1 == 0){
        ((ViewPager) arg0).removeView(views.get(myview.size() - 3));
        ((ViewPager) arg0).addView(views.get(myview.size() - 3), 0);
      }else if(arg1 == myview.size() - 1){
        ((ViewPager) arg0).removeView(views.get(0));
        ((ViewPager) arg0).addView(views.get(0), 0);
      }else{
        ((ViewPager) arg0).addView(views.get(arg1), 0);
      }
      return views.get(arg1);
    }

这样无限滑动就可以简单实现,但在滑动时会出现有空白页面的bug,可能是因为先removeView,在加入view的原因。

您可能感兴趣的文章:Android中ViewPager的PagerTabStrip与PagerTitleStrip用法实例Android中的ViewPager视图滑动切换类的入门实例教程Android实现千变万化的ViewPager切换动画Android自定义ViewPager实现个性化的图片切换效果Android利用HorizontalScrollView仿ViewPager设计简单相册Android ViewPager制作新手导航页(动态加载)Android App中用Handler实现ViewPager页面的自动切换实例讲解Android中ViewPager组件的一些进阶使用技巧举例讲解Android中ViewPager中的PagerTitleStrip子控件Android App开发中ViewPager组件的入门使用教程Android应用中利用ViewPager实现多页面滑动切换效果示例详解Android App中创建ViewPager组件的方法Android中ViewPager实现滑动条及与Fragment结合的实例教程


--结束END--

本文标题: Android中viewPager使用指南

本文链接: https://www.lsjlt.com/news/25880.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小圆点指示器
    一个很常用的功能,一个ViewPager会自动滚动,并且有一排小圆点黑和白来指示当前的滚动进度 首先写一个ViewPager的适配器,这里这个适配器为了方便里面的元素全都是Imag...
    99+
    2024-04-02
  • Android关于BottomNavigationView使用指南
    目录前言一、初识BottomNavigationView二、BottomNavigationView中的颜色关键实现代码解析(举例)三、开始解决问题1.如何修改图标颜色2.如何使图标...
    99+
    2024-04-02
  • Android 之 ViewPager 的简单使用
    本节引言: 本节带来的是Android 3.0后引入的一个UI控件——ViewPager(视图滑动切换工具),实在想不到 如何来称呼这个控件,他的大概功能:通过手势滑动可以完成View的切换,一般是用来做APP 的引导页或者实现图片轮播...
    99+
    2023-09-13
    android 动画
  • Android在ViewPager中如何使用Fragment的懒加载
    这篇文章给大家分享的是有关Android在ViewPager中如何使用Fragment的懒加载的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。我们先看一下效果:首先,我们要知道什么是懒加载:懒加载,就是先初始化控件...
    99+
    2023-05-31
    android fragment viewpager
  • Android使用ViewPager实现翻页效果
    本文实例为大家分享了Android使用ViewPager实现翻页效果的具体代码,供大家参考,具体内容如下 效果如图所示: 代码实现: 1.布局代码:activity_view_pa...
    99+
    2024-04-02
  • Android中fragment+viewpager实现布局
    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下先布局实现mian.xml<?xml version="1.0" encoding="utf-8"?> <Relative...
    99+
    2023-05-30
    fragment viewpager 布局
  • Android音视频开发之VideoView使用指南
    目录VideoView介绍MediaController使用源码分析进度显示播放尺寸适配VideoView介绍 之前介绍过使用MediaPlayer+SurfaceView实现播放视...
    99+
    2024-04-02
  • Android应用中如何动态加载ViewPager
    本篇文章为大家展示了Android应用中如何动态加载ViewPager,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。今天做项目时,纠结了很久,动态添加view,刚开始按照其他的adapter处理,但...
    99+
    2023-05-31
    android viewpager age
  • 在android中使用ViewPager怎么实现无限轮播功能
    这篇文章给大家介绍在android中使用ViewPager怎么实现无限轮播功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、布局<&#63;xml version="1.0" en...
    99+
    2023-05-31
    viewpager android age
  • android viewpager的用法是什么
    Android ViewPager是一种用户界面组件,用于在应用程序中显示多个页面,并允许用户通过滑动手势在这些页面之间进行切换。它...
    99+
    2023-09-29
    android
  • grasscutter 使用指南——Android/Windows/IOS端均已支持
    grasscutter 使用指南——Android/Windows/IOS端均已支持 前言 grasscutter是某二次元手游的开源后端,目前功能并不完整,但正在contributers正在全速开发中,未来可期。可以部署在linux和wi...
    99+
    2023-08-20
    android ios linux centos
  • 如何在Android中利用Viewpager取消滑动
    这期内容当中小编将会给大家带来有关如何在Android中利用Viewpager取消滑动,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言现在很多app,首页不允许滑动切换(因为页面加载吧),但是又用vie...
    99+
    2023-05-31
    android viewpager age
  • Android开发中使用ViewPager实现一个轮翻图效果
    Android开发中使用ViewPager实现一个轮翻图效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。具体方法如下:import java.util.ArrayList...
    99+
    2023-05-31
    android viewpager age
  • Pysvn使用指南
    这是一篇关于pysvn模块的指南. 完整和详细的API请参考 http://pysvn.tigris.org/docs/pysvn_prog_ref.html pysvn是操作Sub...
    99+
    2023-02-20
    Pysvn 使用
  • Android中ViewPager的原理是什么
    ViewPager是Android中的一个布局容器控件,主要用于实现页面切换效果。它的原理是通过管理多个Fragment或View的...
    99+
    2023-09-25
    Android ViewPager
  • 如何在Android项目中使用ViewPager对radiogroup进行关联
    如何在Android项目中使用ViewPager对radiogroup进行关联?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Android ViewPager与radiog...
    99+
    2023-05-31
    android viewpager radiogroup
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作