Android实现轮播图片展示效果

本文实例为大家分享了Android轮播图片的展示,供大家参考,具体内容如下

实现逻辑

1.创建XML布局文件,使用ViewPager完成轮播图片

2.初始化ViewPager控件,然后为控件设置适配器,创建出来的适配器实现里面的四个方法

3.四个方法分别是getCount isViewFromObject instantiateItem destroyItem

4.在onCreat方法中,加载图片资源,将图片ID存在集合中,使图片能够在页面中显示,(图片之所以能够在页面中显示,是因为在适配器中的instantiateItem方法中获取了集合中的图片元素)

5.图片下方的文字显示:图片下方之所以会有文字,可以通过初始化控件,在ViewPager监听器中的onPageSelected方法中tv_desc.setText(descs[position]);这样文字就可以跟随者图片进行切换

6.文字下方的小圆点的切换:在XML布局中设置一个Linlayout布局,然后再onCreat方法中设置小圆点,通过LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(10, 10);的方法引入小圆点(具体代码可以参考下方的initDot方法)

7.要想让小圆点随着页面的切换而切换,可以定义下方的changeDots的方法,让此方法在监听器中的onPageSelected方法中进行调用

8.图片的无限轮播的实现:可以使适配器中的getCount返回值设为一个很大很大的值,同时在instantiateItem方法中设置position position = position % imageResIds.length;防止索引越界异常,这样就可以使图片无限轮播,但是此时还有一个问题就是,右边可以无限轮播,但是左边是无法无限轮播的,这个问题的解决办法是在onCreat方法中设置当前选中的条目viewPager.setCurrentItem(count / 2);这样两边都可以实现无限轮播

9.图片自动切换的处理:使用handler机制实现页面的延时更新,同时为了防止内存溢出,需要在页面可见时,也就是activity的onStart方法中发送消息,在页面消失时,也就是onStop方法中删除消息

布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.a2_.MainActivity">

<android.support.v4.view.ViewPager
  android:id="@+id/vp"
  android:layout_width="match_parent"
  android:layout_height="250dp">
</android.support.v4.view.ViewPager>

<LinearLayout
  android:orientation="vertical"
  android:gravity="center"
  android:background="#66000000"
  android:layout_alignBottom="@id/vp"
  android:layout_width="match_parent"
  android:layout_height="50dp">

  <TextView
    android:id="@+id/desc"
    android:text="描述文本"
    android:textColor="#ffffff"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />

  <LinearLayout
    android:id="@+id/layout_dot"
    android:orientation="horizontal"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">

  </LinearLayout>
</LinearLayout>
</RelativeLayout>

核心代码

package com.example.a2_;

import android.os.Handler;
import android.os.Message;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
private static final int UPDATE_ITEM = 1;
private ArrayList<ImageView> imageViews = new ArrayList<>();
private int[] imageResIds = {R.mipmap.icon_1, R.mipmap.icon_2, R.mipmap.icon_3,
    R.mipmap.icon_4, R.mipmap.icon_5};

private String[] descs = {"为梦想坚持", "我相信我是黑马", "黑马公开课", "Google/IO", "轻松1w+"};
private ViewPager viewPager;
private TextView tv_desc;
private LinearLayout layout_dot;
private int count = 10000000;
private Handler handler = new Handler() {
  @Override
  public void handleMessage(Message msg) {
    switch (msg.what) {
      case UPDATE_ITEM:
        upDataItem();
        break;
    }
    super.handleMessage(msg);
  }
};

@Override
protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);

  //初始化控件
  viewPager = (ViewPager) findViewById(R.id.vp);
  tv_desc = (TextView) findViewById(R.id.desc);
  layout_dot = (LinearLayout) findViewById(R.id.layout_dot);
  //给viewPager设置适配器
  viewPager.setAdapter(new MyPagerAdapter());
  //对viewPager设置监听器
  viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

    //当页面滚动时触发的时间
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }

    //当页面被选中时触发的方法
    @Override
    public void onPageSelected(int position) {
      //对position进行处理
      position = position % imageViews.size();
      //当页面被选中的时候,改变描述文本
      tv_desc.setText(descs[position]);
      changeDots(position);
    }

    //当页面状态滚动状态发生改变时触发的事件
    @Override
    public void onPageScrollStateChanged(int state) {
      //当页面空闲状态被改变的时候
      if (state == viewPager.SCROLL_STATE_IDLE) {
        handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000);
      } else {
        handler.removeMessages(UPDATE_ITEM);
      }
    }
  });

  //初始化图片
  initImage();
  //初始化文字下方的点
  initDot();
  //当加载页面的时候,默认让第一个文本加载出来
//    initDescFirst();

  //使两边都可以无限轮播
  viewPager.setCurrentItem(count / 2);
//页面加载时更新
  upDataItem();
}

private void upDataItem() {
  int index = viewPager.getCurrentItem();
  viewPager.setCurrentItem(++index);
  handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000);
}

//选中对应的原点
private void changeDots(int position) {
  //先把所有的点恢复为白色
  for (int i = 0; i < layout_dot.getChildCount(); i++) {
    View view = layout_dot.getChildAt(i);
    view.setSelected(false);
  }
  //获取当前被选中的条目 设置为选中状态
  layout_dot.getChildAt(position).setSelected(true);

}

//初始化文字下方的点
private void initDot() {
  LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(10, 10);
  layoutParams.setMargins(4, 4, 4, 4);
  for (int i = 0; i < imageViews.size(); i++) {
    View view = new View(this);
    view.setBackgroundResource(R.drawable.seletor_dot);
    view.setLayoutParams(layoutParams);
    layout_dot.addView(view);
  }
}

//当加载页面的时候,默认让第一个文本加载出来
private void initDescFirst() {
  tv_desc.setText(descs[0]);
  changeDots(0);
}

//添加图片,准备一个ImageView集合,用来交给instantiateItem添加到页面
private void initImage() {
  for (int i = 0; i < imageResIds.length; i++) {
    //创建出ImageView对象
    ImageView imageView = new ImageView(getApplicationContext());
    imageView.setImageResource(imageResIds[i]);
    imageViews.add(imageView);
  }
}

private class MyPagerAdapter extends PagerAdapter {

  @Override
  public int getCount() {
    return count;
  }

  @Override
  public boolean isViewFromObject(View view, Object object) {
    //判断这个view是不是通过instantiateItem创建出来的
    return view == object;
  }

  //用来创建条目
  @Override
  public Object instantiateItem(ViewGroup container, int position) {
    position = position % imageResIds.length;
    //获取条目
    ImageView imageView = imageViews.get(position);
    container.addView(imageView);
    return imageView;
  }

  //用来销毁条目,,且最多会创建出三个条目,多出来的条目将会被销毁
  @Override
  public void destroyItem(ViewGroup container, int position, Object object) {

    //销毁创建的条目
    container.removeView((View) object);
  }
}

@Override
protected void onStart() {
  super.onStart();
  //当页面显示的时候,更新轮播图
  handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000);
}

@Override
protected void onStop() {
  super.onStop();
  //当页面不可见时,停止更新
  handler.removeCallbacksAndMessages(null);
}
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android通过Movie展示Gif格式图片

    本文实例为大家分享Android通过Movie展示Gif格式图片的相关代码,供大家参考,具体内容如下 public class CommonGifView extends View { private Resources mResources; private Movie mMovie; private long startTime = 0; private float widthRatio; private float heightRatio; public CommonGifView(Con

  • Android学习教程之九宫格图片展示(13)

    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下 MainActivity.java代码: package siso.ninegridimg; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; public class MainActivity extends AppCompatActivity { @Override protected void onCrea

  • Android编程实现下载图片及在手机中展示的方法

    本文实例讲述了Android编程实现下载图片及在手机中展示的方法.分享给大家供大家参考,具体如下: 在项目开发中从互联网上下载图片是经常用到的功能,再次总结一下 1.普通的下载方式 布局文件: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android

  • Android实现3D层叠式卡片图片展示

    本文实例为大家分享了Android实现3D层叠式卡片图片展示的具体代码,供大家参考,具体内容如下 先看效果 好了效果看了,感兴趣的往下看哦! 整体实现思路 1.重写RelativeLayout 实现 锁定宽高比例的 RelativeLayout 2.自定义一个支持滑动的面板 继承 ViewGroup 3.卡片View绘制 4.页面中使用布局 首先为了更好的展示图片我们重写一下 RelativeLayout 编写一个锁定宽高比例的 RelativeLayout AutoScaleRelativeL

  • Android开发之使用GridView展示图片的方法

    本文实例讲述了Android使用GridView展示图片的方法.分享给大家供大家参考,具体如下: 今天说说GridView的使用. 所谓GvidView翻译过来就是网格布局:是一个ViewGroup以网格显示它的子视图(view)元素,即二维的.可滚动的网格.网格元素通过ListAdapter自动插入到网格. 这个GridView用处特别多,我这里是用来展示广告的.2*3的广告位置. 废话少说先看个效果图,有图就可以说个XX,对吧,大家都懂的. 大家可以看到搜索下面的那6个块,效果布局还行吧,哈

  • Android实现轮播图片展示效果

    本文实例为大家分享了Android轮播图片的展示,供大家参考,具体内容如下 实现逻辑 1.创建XML布局文件,使用ViewPager完成轮播图片 2.初始化ViewPager控件,然后为控件设置适配器,创建出来的适配器实现里面的四个方法 3.四个方法分别是getCount isViewFromObject instantiateItem destroyItem 4.在onCreat方法中,加载图片资源,将图片ID存在集合中,使图片能够在页面中显示,(图片之所以能够在页面中显示,是因为在适配器中的

  • Android实现轮播图片效果

    本文实例为大家分享了Android实现轮播图片效果的具体代码,供大家参考,具体内容如下 一.原理 首先,将这些要轮播的图片和一些文本分别放置在不同的数据集合中,程序启动的时候默认显示一组图片和文本数据,然后启动一个定时器,每隔一段时间便替换掉显示的图片和文本数据,同时加入一些动画效果,已达到轮播的特效.同时,我们也要实现手指滑动图片达到轮播的效果. 二.实现 1.程序启动界面MainActivity public class MainActivity extends AppCompatActiv

  • Android自定义轮播图效果

    本文实例为大家分享了Android自定义轮播图效果的具体代码,供大家参考,具体内容如下 概述 1.写一个布局,其中有ViewPager,TextView,LinearLayout. ViewPager:用来承载图片 TextView:用来展示文字描述 LinearLayout:用来展示指示器 2.自定义ConstraintLayout, 在该控件中处理页面切换逻辑等. 分析 1.获取自定义属性以及设置一些属性 public BannerY(Context context, AttributeSe

  • js实现点击左右按钮轮播图片效果实例

    本文实例讲述了js实现点击左右按钮轮播图片效果的方法.分享给大家供大家参考.具体实现方法如下: $(function () { var index = 1; var pPage = 1; var $v_citemss = $(".citemss"); var $v_show = $v_citemss.find("ul"); v_width = $v_citemss.width();//图片展示区外围div的大小 //注:若为整数,前边不能再加var,否则会被提示un

  • Android实现自定义轮播图片控件详解

    首先上效果图 实现原理 要完成一个轮播图片,首先想到的应该是使用ViewPager来实现.ViewPager已经有了滑动的功能,我们只要让它自己滚动.再加上下方的小圆点就行了.所以我们本次的自定义控件就是由ViewPager和LinearLayout叠加起来组成的. 一.创建一个自定义的ViewPager 先上完整的代码 package com.kcode.autoscrollviewpager.view; import android.content.Context; import andro

  • js图片轮播手动切换效果

    利用ScrollPicLeft.js这个库实现图片的前后切换,适用于网页中的证书展示.推荐商品之类的栏目.它不像传统的marquee滚动那样,而是可以手动的去点击前后切换箭头按钮,进行图片的翻页,从而达到浏览上一张,下一张的效果. 不需要调用jquery,初始化简单,使用非常的简单,便利. 实例效果: js代码: <script type="text/javascript"> var scrollPhoto = new ScrollPicleft(); scrollPhot

  • Android实现自定义轮播图片控件示例

    要完成一个轮播图片,首先想到的应该是使用ViewPager来实现.ViewPager已经有了滑动的功能,我们只要让它自己滚动.再加上下方的小圆点就行了.所以我们本次的自定义控件就是由ViewPager和LinearLayout叠加起来组成的. 直接先上效果图: 创建一个自定义的ViewPager 先上完整的代码 package com.kcode.autoscrollviewpager.view; import android.content.Context; import android.os

  • Android实现轮播图效果

    本文实例为大家分享了Android实现轮播图效果的具体代码,供大家参考,具体内容如下 1.代码放在LinearLayout中, <com.jude.rollviewpager.RollPagerView android:id="@+id/roll_view_pager" android:layout_width="match_parent" android:layout_height="180dp" android:layout_margi

  • js实现支持手机滑动切换的轮播图片效果实例

    本文实例讲述了js实现支持手机滑动切换的轮播图片效果的方法.分享给大家供大家参考.具体如下: 运行效果如下: 完整实例代码点击此处本站下载. 使用方法案例: <script type="text/javascript" src="../src/zepto.js"></script> <script type="text/javascript" src="../src/carousel-image.js&qu

  • IOS实现图片轮播无限循环效果

    本文接着上篇文章进行叙述讲解,主要为大家分享了图片轮播无限循环效果的实现方法,具体内容如下 之前说到第一个问题,ScrollView移动到最后一张图片时无法移动了,这是因为ScrollView已经移动到最后,而图片又是依次排列,自然也就无法移动. 解决办法是,我们换一个思路实现图片轮播效果,ScrollView上只放三个ImageView,屏幕始终显示中间的ImageView,左边和右边的ImageView分别代表前一张图片和后一张图片,屏幕移动的时候,中间的ImageView变化,同时左右两边

随机推荐