Android实现轮播图片展示效果

 更新时间:2020年12月22日 11:41:33   作者:常利兵  
这篇文章主要为大家详细介绍了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);
}
}

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

相关文章

  • Android自定义View之自定义评价打分控件RatingBar实现自定义星星大小和间距

    Android自定义View之自定义评价打分控件RatingBar实现自定义星星大小和间距

    Android开发中,我们经常会用到对商家或者商品的评价,运用星星进行打分。这篇文章介绍了Android自定义View之自定义评价打分控件RatingBar可以自定义星星大小和间距的相关资料,感兴趣的朋友一起看看吧
    2016-10-10
  • Android自定义view之太极图的实现教程

    Android自定义view之太极图的实现教程

    这篇文章主要给大家介绍了关于Android自定义view之太极图的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • Flutter中数据库的使用教程详解

    Flutter中数据库的使用教程详解

    在Flutter开发过程中,有时需要对数据进行本地的持久化存储,使用sp文件形式虽然也能解决问题,但是有时数据量较大的时候,显然我们文件形式就不太合适了,这时候我们就需要使用数据库进行存储。本文将详细讲讲Flutter中数据库的使用,需要的可以参考一下
    2022-04-04
  • Android编程实现擦除Bitmap中某一块的方法

    Android编程实现擦除Bitmap中某一块的方法

    这篇文章主要介绍了Android编程实现擦除Bitmap中某一块的方法,涉及Android操作Bitmap颜色像素值调整的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • Flutter GridView显示随机单词效果

    Flutter GridView显示随机单词效果

    这篇文章主要为大家详细介绍了Flutter GridView显示随机单词效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Android Broadcast原理分析之registerReceiver详解

    Android Broadcast原理分析之registerReceiver详解

    这篇文章主要介绍了Android Broadcast原理分析之registerReceiver详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • android简易文件管理器实例(列表式文件目录)

    android简易文件管理器实例(列表式文件目录)

    下面小编就为大家带来一篇android简易文件管理器实例(列表式文件目录)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • Android签名知识小结

    Android签名知识小结

    不止一次有用到Android签名相关的知识,每次都几乎从零开始在Google上搜索找,不想在继续这样了,找了个时间好好整理了一下自己用到的一些碎片知识,于是乎放到这里,一是备忘,二是帮助别人
    2016-03-03
  • Android搜索框组件SearchView的基本使用方法

    Android搜索框组件SearchView的基本使用方法

    这篇文章主要为大家详细介绍了Android搜索框组件SearchView的基本使用方法,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • Flutter UI如何使用Provide实现主题切换详解

    Flutter UI如何使用Provide实现主题切换详解

    这篇文章主要给大家介绍了关于Flutter UI如何使用Provide实现主题切换的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Flutter具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04

最新评论