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开发中,我们经常会用到对商家或者商品的评价,运用星星进行打分。这篇文章介绍了Android自定义View之自定义评价打分控件RatingBar可以自定义星星大小和间距的相关资料,感兴趣的朋友一起看看吧2016-10-10Android Broadcast原理分析之registerReceiver详解
这篇文章主要介绍了Android Broadcast原理分析之registerReceiver详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下2021-08-08
最新评论