Android 利用ViewPager实现图片可以左右循环滑动效果附代码下载

首先给大家展示靓照,对效果图感兴趣的朋友可以继续往下阅读哦。

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{
 /**
 * ViewPager
 */
 private ViewPager viewPager;
 /**
 * 装点点的ImageView数组
 */
 private ImageView[] tips;
 /**
 * 装ImageView数组
 */
 private ImageView[] mImageViews;
 /**
 * 图片资源id
 */
 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);
 }
 /**
 *
 * @author xiaanming
 *
 */
 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]);
 }
 /**
 * 载入图片进去,用当前的position 除以 图片数组长度取余数是关键
 */
 @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);
 }
 /**
 * 设置选中的tip的背景
 * @param selectItems
 */
 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);
 }
 }
 }
} 

喜欢的朋友直接下载代码哦。代码下载

上面的代码中,当只有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)增加异常扑捉
[java] view plaincopy在CODE上查看代码片派生到我的代码片
@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实现图片可以左右循环滑动效果,希望大家喜欢。

(0)

相关推荐

  • Android使用缓存机制实现文件下载及异步请求图片加三级缓存

    首先给大家介绍Android使用缓存机制实现文件下载 在下载文件或者在线浏览文件时,或者为了保证文件下载的正确性,需要使用缓存机制,常使用SoftReference来实现. SoftReference的特点是它的一个实例保存对一个Java对象的软引用,该软引用的存在不妨碍垃圾收集线程对该Java对象的回收.也就是说,一旦SoftReference保存了对一个Java对象的软引用后,在垃圾线程对这个Java对象回收前,SoftReference类所提供的get()方法返回Java对象的强引用.另外

  • SimpleCommand实现图片下载(二)

    使用simplecommand下载网络图片,并显示到ImageView控件上. 1 在app module的build.gradle将simplecommand框架进行导入,具体请看第1节的步骤1和2 2 设置网络图片的Url地址:这里以请求百度logo图片为例 String imageUrl = "https://www.baidu.com/img/bd_logo1.png"; 3 构建图片下载的进度监听器 ImageLoader.ProgressListener listener

  • Android编程实现图片的上传和下载功能示例

    本文实例讲述了Android编程实现图片的上传和下载功能.分享给大家供大家参考,具体如下: 在实现一个Android的WEB服务客户端,比如微博,论坛客户端时,经常会使用到图片的上传和下载.在这里介绍如何利用HttpClient实现图片的上传和下载功能. 1 图片上传:上传图片时,首先获得图片的路径,创建文件,并将图片转化为字节流写入到request,并发送该请求. 客户端代码: File file = new File(imageUrl); String httpUrl = httpDomai

  • Android中使用HttpURLConnection实现GET POST JSON数据与下载图片

    Android6.0中把Apache HTTP Client所有的包与类都标记为deprecated不再建议使用所有跟HTTP相关的数据请求与提交操作都通过HttpURLConnection类实现,现实是很多Android开发者一直都Apache HTTP Client来做andoird客户端与后台HTTP接口数据交互,小编刚刚用HttpURLConnection做了一个android的APP,不小心踩到了几个坑,总结下最常用的就通过HttpURLConnection来POST提交JSON数据与

  • Android中使用七牛云存储进行图片上传下载的实例代码

    Android开发中的图片存储本来就是比较耗时耗地的事情,而使用第三方的七牛云,便可以很好的解决这些后顾之忧,最近我也是在学习七牛的SDK,将使用过程在这记录下来,方便以后使用. 先说一下七牛云的存储原理,上面这幅图片是官方给出的原理图,表述当然比较清晰了. 可以看出,要进行图片上传的话可以分为五大步: 1. 客户端用户登录到APP的账号系统里面: 2. 客户端上传文件之前,需要向业务服务器申请七牛的上传凭证,这个凭证由业务服务器使用七牛提供的服务端SDK生成: 3. 客户端使用七牛提供的客户端

  • Android使用okHttp(get方式)下载图片

    一.首先下载Jar包 https://github.com/square/okhttp 如果使用android studio只需要加入依赖compile 'com.squareup.okhttp3:okhttp:3.2.0' 二.下载一张图片并显示 使用的是hanlder的方式 package com.liunan.okhttpdemo2; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import

  • Android编程实现手绘及保存为图片的方法(附demo源码下载)

    本文实例讲述了Android编程实现手绘及保存为图片的方法.分享给大家供大家参考,具体如下: 运行效果图预览: 应 yzuo_08 要求做了此Demo,跟以前那个手写板Demo不同的是可以将画布的内容保存为图片. 附上关键代码: MainView.java package com.tszy.views; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; impor

  • Android 下载网络图片并显示到本地

    Android下载网络图片的流程是: 发送网络请求->将图片以流的形式下载下来->将流转换为Bitmap并赋给ImageView控件. 注意点 最新的Android系统不可以在主线程上请求网络,需要使用线程来请求 下载图片属于耗时任务,最优做法是放在一个AsyncTask中操作 设计思路 1.网络请求:该例中需要下载的文件类型是图片类型,可以将网络请求获取的数据类型转换为Bitmap已供ImageView直接使用,但是一个合理的网络请求类的设计是将下载的数据类型转换为最基本的InputStre

  • Android中Glide实现超简单的图片下载功能

    本文介绍了Glide实现超简单的图片下载功能,具体步骤如下: 添加依赖 compile 'com.github.bumptech.glide:glide:3.7.0' 添加权限 <uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/&

  • Android编程滑动效果之Gallery+GridView实现图片预览功能(附demo源码下载)

    本文实例讲述了Android编程滑动效果之Gallery+GridView实现图片预览功能.分享给大家供大家参考,具体如下: Android系统自带一个GridView和Gallery两个控件,GridView网格显示,Gallery单个浏览,两者结合起来可以真正实现Gallery浏览图片效果. 本示例通过GridView和Gallery两个控件,模仿实现一个完整的仿Gallery图像集的图片浏览效果.效果图如下: 1.GridView 首先,自定义一个GridImageAdapter图片适配器

随机推荐