iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android巧用ViewPager实现左右循环滑动图片
  • 784
分享到

Android巧用ViewPager实现左右循环滑动图片

循环图片viewpagerAndroid 2022-06-06 08:06:30 784人浏览 独家记忆
摘要

ViewPager这个小demo实现的是可以左右循环滑动图片,下面带索引,滑到最后一页在往右滑动就要第一页,第一页往左滑动就到最后一页,先上效果图: 1、首先看一些layou

ViewPager这个小demo实现的是可以左右循环滑动图片,下面带索引,滑到最后一页在往右滑动就要第一页,第一页往左滑动就到最后一页,先上效果图:

1、首先看一些layout下的xml


<FrameLayout xmlns:Android="Http://schemas.android.com/apk/res/android" 
  android:layout_width="fill_parent" 
  android:layout_height="fill_parent" 
  android:orientation="vertical" > 
  <android.support.v4.view.ViewPager  
    android:id="@+id/viewPager"  
    android:layout_width="fill_parent"  
    android:layout_height="wrap_content" />  
  <RelativeLayout  
    android:layout_width="fill_parent"  
    android:layout_height="wrap_content"  
    android:orientation="vertical" >  
    <LinearLayout  
      android:id="@+id/viewGroup"  
      android:layout_width="fill_parent"  
      android:layout_height="wrap_content"  
      android:layout_alignParentBottom="true"  
      android:layout_marginBottom="30dp"  
      android:gravity="center_horizontal"  
      android:orientation="horizontal" >  
    </LinearLayout>  
  </RelativeLayout>  
</FrameLayout> 

 使用ViewPager首先需要引入Android-support-v4.jar这个jar包,自己不要忘记加


package com.example.viewpagerdemo; 
import android.app.Activity; 
import android.os.Bundle; 
import android.support.v4.view.PagerAdapter; 
import android.support.v4.view.ViewPager; 
import android.support.v4.view.ViewPager.OnPageChangeListener; 
import android.view.View; 
import android.view.ViewGroup; 
import android.view.ViewGroup.LayoutParams; 
import android.widget.ImageView; 
import android.widget.LinearLayout; 
public class TwoActivity extends Activity implements OnPageChangeListener{ 
   
  private ViewPager viewPager; 
   
  private ImageView[] tips; 
   
  private ImageView[] mImageViews; 
   
  private int[] imgIdArray ; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    ViewGroup group = (ViewGroup)findViewById(R.id.viewGroup); 
    viewPager = (ViewPager) findViewById(R.id.viewPager); 
    //载入图片资源ID 
    imgIdArray = new int[]{R.drawable.item01, R.drawable.item02, R.drawable.item03, R.drawable.item04, 
        R.drawable.item05,R.drawable.item06, R.drawable.item07, R.drawable.item08}; 
    //将点点加入到ViewGroup中 
    tips = new ImageView[imgIdArray.length]; 
    for(int i=0; i<tips.length; i++){ 
      ImageView imageView = new ImageView(this); 
      imageView.setLayoutParams(new LayoutParams(10,10)); 
      tips[i] = imageView; 
      if(i == 0){ 
        tips[i].setBackgroundResource(R.drawable.page_indicator_focused); 
      }else{ 
        tips[i].setBackgroundResource(R.drawable.page_indicator_unfocused); 
      } 
      LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(new ViewGroup.LayoutParams(LayoutParams.WRAP_CONTENT,  
          LayoutParams.WRAP_CONTENT)); 
      layoutParams.leftMargin = 5; 
      layoutParams.rightMargin = 5; 
      group.addView(imageView, layoutParams); 
    } 
    //将图片装载到数组中 
    mImageViews = new ImageView[imgIdArray.length]; 
    for(int i=0; i<mImageViews.length; i++){ 
      ImageView imageView = new ImageView(this); 
      mImageViews[i] = imageView; 
      imageView.setBackgroundResource(imgIdArray[i]); 
    } 
    //设置Adapter 
    viewPager.setAdapter(new MyAdapter()); 
    //设置监听,主要是设置点点的背景 
    viewPager.setOnPageChangeListener(this); 
    //设置ViewPager的默认项, 设置为长度的100倍,这样子开始就能往左滑动 
    viewPager.setCurrentItem((mImageViews.length) * 100); 
  } 
   
  public class MyAdapter extends PagerAdapter{ 
    @Override 
    public int getCount() { 
      return Integer.MAX_VALUE; 
    } 
    @Override 
    public boolean isViewFromObject(View arg0, Object arg1) { 
      return arg0 == arg1; 
    } 
    @Override 
    public void destroyItem(View container, int position, Object object) { 
      ((ViewPager)container).removeView(mImageViews[position % mImageViews.length]); 
    } 
     
    @Override 
    public Object instantiateItem(View container, int position) { 
      ((ViewPager)container).addView(mImageViews[position % mImageViews.length], 0); 
      return mImageViews[position % mImageViews.length]; 
    } 
  } 
  @Override 
  public void onPageScrollStateChanged(int arg0) { 
  } 
  @Override 
  public void onPageScrolled(int arg0, float arg1, int arg2) { 
  } 
  @Override 
  public void onPageSelected(int arg0) { 
    setImageBackground(arg0 % mImageViews.length); 
  } 
   
  private void setImageBackground(int selectItems){ 
    for(int i=0; i<tips.length; i++){ 
      if(i == selectItems){ 
        tips[i].setBackgroundResource(R.drawable.page_indicator_focused); 
      }else{ 
        tips[i].setBackgroundResource(R.drawable.page_indicator_unfocused); 
      } 
    } 
  } 
} 

源码下载:左右滑动ViewPager 

2、上面的代码中,当只有3张图片或者2张图片的时候,滑动存在BUG问题的修改如下
destroyItem(View container, int position, Object object)方法中不removeView


 @Override 
    public void destroyItem(View container, int position, Object object) { 
//     ((ViewPager)container).removeView(mImageViews[position % mImageViews.length]); 
    } 
instantiateItem(View container, int position)增加异常扑捉

@Override 
  public Object instantiateItem(View container, int position) { 
    try {  
      ((ViewPager)container).addView(mImageViews[position % mImageViews.length], 0); 
    }catch(Exception e){ 
      //handler something 
    } 
    return mImageViews[position % mImageViews.length]; 
  } 
您可能感兴趣的文章:Android开发之使用ViewPager实现图片左右滑动切换效果Android实现Banner界面广告图片循环轮播(包括实现手动滑动循环)Android 利用ViewPager实现图片可以左右循环滑动效果附代码下载Android手势滑动实现ImageView缩放图片大小Android 使用ViewPager实现图片左右循环滑动自动播放Android实现手势滑动多点触摸缩放平移图片效果Android实现图片左右滑动效果Android中ViewPager组件的基本用法及实现图片切换的示例Android自定义ViewPager实现个性化的图片切换效果Android使用ViewFlipper实现图片切换功能Android开发实现高仿优酷的客户端图片左右滑动切换功能实例【附源码下载】


--结束END--

本文标题: Android巧用ViewPager实现左右循环滑动图片

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

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

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

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

下载Word文档
猜你喜欢
  • Android实现左右滑动切换图片
    简要说明 本文采用ImageSwitcher实现左右滑动切换图片。首先调用setFactory方法,设置视图工厂;然后设置手指触碰监听,判断左滑右滑进而切换图片。 本地图片 xml ...
    99+
    2024-04-02
  • ViewPager+RadioGroup实现左右滑动卡片布局
    本文实例为大家分享了ViewPager+RadioGroup实现左右滑动卡片布局的具体代码,供大家参考,具体内容如下 效果如图所示: 1.选择某个界面时,对应的第几个小圆点亮: ...
    99+
    2024-04-02
  • Android怎么实现左右滑动切换图片
    这篇文章主要介绍“Android怎么实现左右滑动切换图片”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android怎么实现左右滑动切换图片”文章能帮助大家解决问题。简要说明本文采用ImageSwi...
    99+
    2023-06-30
  • Android 中怎么利用ViewPager实现左右滑动功能
    本篇文章给大家分享的是有关Android 中怎么利用ViewPager实现左右滑动功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Android ViewPager实现左右滑...
    99+
    2023-05-30
    android viewpager
  • 如何使用ViewPager+RadioGroup实现左右滑动卡片布局
    小编给大家分享一下如何使用ViewPager+RadioGroup实现左右滑动卡片布局,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!效果如图所示:选择某个界面时,对应的第几个小圆点亮:通过selector制造圆点...
    99+
    2023-06-29
  • 怎么用Android studio实现左右滑动切换图片
    今天小编给大家分享一下怎么用Android studio实现左右滑动切换图片的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2023-06-30
  • Androidstudio实现左右滑动切换图片
    本文实例为大家分享了Android studio实现左右滑动切换图片的具体代码,供大家参考,具体内容如下 切换图片首先要使用到图片切换器ImageSwitcher 先了解一下Imag...
    99+
    2024-04-02
  • Android基于ViewPager+Fragment如何实现左右滑屏效果
    这篇文章主要为大家展示了Android基于ViewPager+Fragment如何实现左右滑屏效果,内容简而易懂,希望大家可以学习一下,学习完之后肯定会有收获的,下面让小编带大家一起来看看吧。本文实例讲述了Android基于ViewPage...
    99+
    2023-05-31
    android viewpager fragment
  • Android怎么实现菜单左右滑动
    在Android中,实现菜单左右滑动可以通过使用ViewPager和Fragment来实现。下面是实现的步骤:1. 在布局文件中,添...
    99+
    2023-09-28
    Android
  • Android中怎么利用ViewPager实现图片滑动预览效果
    本篇文章给大家分享的是有关Android中怎么利用ViewPager实现图片滑动预览效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。xml代码:<xml ve...
    99+
    2023-05-30
    android viewpager
  • 使用Android原生WebView+Highcharts实现可左右滑动的折线图
    目录前言开发的思路如下:(一)设计Android端的View层(二)设计与JS交互的方法(三)开发html以及js逻辑总结前言 今天的内容是使用Android原生webview配合H...
    99+
    2024-04-02
  • android左右滑动切换效果怎么实现
    在Android中,可以通过使用ViewPager组件来实现左右滑动切换效果。 首先,在XML布局文件中添加一个ViewPager组...
    99+
    2023-10-23
    android
  • 如何在Android应用中利用ViewPager撤消左右滑动切换功能
    这期内容当中小编将会给大家带来有关如何在Android应用中利用ViewPager撤消左右滑动切换功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。ViewPager取消左右滑动切换功能的实例代码,具体代...
    99+
    2023-05-31
    android viewpager age
  • Android实现ViewFlipper图片动画滑动
    今天给大家实现的功能是类似于ViewFlipper的图片滑动的效果,供大家参考,具体内容如下 现在就直接上代码吧! 代码实例: 1、xml布局文件 <xml version="...
    99+
    2024-04-02
  • Jquery实现图片左右自动滚动示例
    复制代码 代码如下: <!DOCTYPE HTML> <html> <head> <title>基于jQuery的控制左右滚动效果_自...
    99+
    2022-11-15
    图片左右滚动 自动滚动
  • 怎么使用Android原生WebView+Highcharts实现可左右滑动的折线图
    这篇文章主要介绍“怎么使用Android原生WebView+Highcharts实现可左右滑动的折线图”,在日常操作中,相信很多人在怎么使用Android原生WebView+Highcharts实现可左右滑动的折线图问题上存在疑惑,小编查阅...
    99+
    2023-06-30
  • Android开发中利用HorizontalScrollView实现一个左右滑动效果
    这期内容当中小编将会给大家带来有关Android开发中利用HorizontalScrollView实现一个左右滑动效果,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。效果图一.什么是HorizontalSc...
    99+
    2023-05-31
    android horizontalscrollview roi
  • js文字左右循环滚动效果怎么实现
    要实现文字的左右循环滚动效果,可以使用以下步骤:1. 创建一个包裹文字的容器元素,并设置其宽度为容器元素的父元素宽度的倍数,这样文字...
    99+
    2023-08-09
    js
  • 使用vue怎么实现左右滑动效果
    使用vue怎么实现左右滑动效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。HTML代码<template>    &l...
    99+
    2023-06-15
  • Android中怎么利用ViewPager实现无限循环
    本篇文章为大家展示了Android中怎么利用ViewPager实现无限循环,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Android ViewPager实现无限循环的实例ViewPager自身并不...
    99+
    2023-05-31
    android viewpager
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作