前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android实现轮播图片展示效果

Android实现轮播图片展示效果

作者头像
砸漏
发布2020-11-04 11:16:59
1.9K0
发布2020-11-04 11:16:59
举报
文章被收录于专栏:恩蓝脚本

本文实例为大家分享了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方法中删除消息

布局文件

代码语言:javascript
复制
<?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 

核心代码

代码语言:javascript
复制
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);
}
}

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档