IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> android 使用viewpager实现图片轮播效果 -> 正文阅读

[移动开发]android 使用viewpager实现图片轮播效果

第一步:创建xml布局,如下图所示;

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="200dp"
    android:background="#DFDFDF"
    tools:context=".MainActivity">


    <androidx.viewpager.widget.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@color/white" />

    <!--        android:layout_centerHorizontal="true"-->
    <LinearLayout
        android:id="@+id/viewGroup"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_alignParentEnd="true"
        android:layout_margin="10dp"
        android:background="#00ff00"
        android:orientation="horizontal" />
</RelativeLayout>

第二步:创建drawable,选中和非选中的小圆点

a, 非选中样式的圆点

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval"
    android:useLevel="false">
    <solid android:color="#FFFFFF" />
    <size
        android:width="5dp"
        android:height="5dp" />
</shape>

b, 选中样式的圆点

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval"
    android:useLevel="false">
    <solid android:color="#fb435b" />
    <size
        android:width="5dp"
        android:height="5dp" />
</shape>

第三步:创建ViewPagerAdapter适配器

package com.example.myapplication_10;

import android.content.Context;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import androidx.annotation.NonNull;
import androidx.viewpager.widget.PagerAdapter;

import com.example.myapplication_10.R;

public class MyPagerAdapter extends PagerAdapter {
    private int[] banners = new int[]{R.mipmap.img_1, R.mipmap.img_2, R.mipmap.img_3};
    private Context context;
    private View.OnClickListener onBannerClickListener;
    private static final String TAG = "MyPagerAdapter";

    public MyPagerAdapter(Context context) {
        this.context = context;
    }

    @Override
    public int getCount() {
        //返回int的最大值 可以一直滑动
        return Integer.MAX_VALUE;
    }

    @Override
    public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
        return view == object;
    }

    @NonNull
    @Override
    public Object instantiateItem(@NonNull ViewGroup container, int position) {
        Log.e(TAG, "instantiateItem1: " + position);
        position %= banners.length;
        Log.e(TAG, "instantiateItem2: " + position);
        ImageView imageView = new ImageView(context);
        //设置图片缩放类型
        imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
        //把当前的下标通过setTag方法设置进去
        imageView.setTag(position);
        imageView.setImageResource(banners[position]);
        imageView.setOnClickListener(onClickListener);
        container.addView(imageView);
        return imageView;
    }

    private View.OnClickListener onClickListener = new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            onBannerClickListener.onClick(v);
        }
    };

    @Override
    public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
        container.removeView((View) object);
    }

    public void setOnBannerClickListener(View.OnClickListener onBannerClickListener) {
        this.onBannerClickListener = onBannerClickListener;
    }

    public int[] getBanners() {
        return banners;
    }
}

第四步:MainActivity函数代码如下;

package com.example.myapplication_10;

import androidx.appcompat.app.AppCompatActivity;
import androidx.viewpager.widget.ViewPager;

import android.os.Bundle;
import android.os.Handler;
import android.os.SystemClock;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Toast;


public class MainActivity extends AppCompatActivity {

    private static final String TAG = "MainActivity";
    private MyPagerAdapter myPagerAdapter;
    private ViewPager viewPager;
    private LinearLayout viewGroup;

    private int currentItem = 0;
    private final Handler handler = new Handler();
    private static final int CAROUSEL_TIME = 3000;




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


        viewPager = findViewById(R.id.viewPager);
        viewGroup = findViewById(R.id.viewGroup);
        myPagerAdapter = new MyPagerAdapter(this);
        myPagerAdapter.setOnBannerClickListener(onBannerClickListener);
        //设置缓存页数
        viewPager.setOffscreenPageLimit(myPagerAdapter.getBanners().length - 1);
        viewPager.setAdapter(myPagerAdapter);
        //添加页面更改监听器
        viewPager.addOnPageChangeListener(onPageChangeListener);

        //将点点的图添加到视图ViewGroup中
        for (int i = 0; i < myPagerAdapter.getBanners().length; i++) {
            ImageView imageView = new ImageView(this);
            //设置图片的宽高 为10像素
            imageView.setLayoutParams(new ViewGroup.LayoutParams(10, 10));
            if (i == 0) {
                //第一个为默认选中状态
                imageView.setImageResource(R.drawable.icon_page_select);
            } else {
                imageView.setImageResource(R.drawable.icon_page_normal);
            }
            LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
            params.leftMargin = 5;
            params.rightMargin = 5;
            viewGroup.addView(imageView, params);
        }
        //给ViewPager设置当前页,这样刚打开软件也能向左滑动
        currentItem = myPagerAdapter.getBanners().length * 50;
        viewPager.setCurrentItem(currentItem);
        handler.postDelayed(mTicker, CAROUSEL_TIME);
    }

    private final Runnable mTicker = new Runnable() {
        @Override
        public void run() {
            long now = SystemClock.uptimeMillis();
            Log.d(TAG, "now:" + now);
//            long next = now + (CAROUSEL_TIME - now % CAROUSEL_TIME);
            //等同于
            long next = now + CAROUSEL_TIME;
            Log.d(TAG, "next: " + next);
            //回调应该运行的绝对时间 3秒后发送消息
            handler.postAtTime(mTicker, next);
            currentItem++;
            viewPager.setCurrentItem(currentItem);
        }
    };

    private View.OnClickListener onBannerClickListener = new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            int position = (int) v.getTag();
            Toast.makeText(MainActivity.this, "当前点击位置:" + position, Toast.LENGTH_SHORT).show();
        }
    };

    private ViewPager.OnPageChangeListener onPageChangeListener = new ViewPager.OnPageChangeListener() {
        /**
         * function: 当前页面滚动的时候回调这个方法
         * @param position 当前页面的位置
         * @param positionOffset 滑动页面的百分比
         * @param positionOffsetPixels 滑动的像素数
         * @return
         */
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

        }

        /**
         * function: 当页面被选中时,会回调这个方法
         * @param position 被选中的页面的位置
         * @return
         */
        @Override
        public void onPageSelected(int position) {
            Log.e(TAG, "onPageSelected: MainActivity" + position);
            currentItem = position;
            //当新页面选中时调用此方法,position 为新选中页面的位置索引
            //在所选页面的时候,点点图片也要发生变化
            setImageBackground(position %= myPagerAdapter.getBanners().length);
            Log.e(TAG, "onPageSelected: " + myPagerAdapter.getBanners().length);
        }

        /**
         * function: 当页面滚动状态变化时,会回调这个方法
         * 有三种状态:静止、滑动、拖拽(这里区别滑动和拖拽,以手指是否接触页面为准)
         * @param state 当前状态
         * @return
         */
        @Override
        public void onPageScrollStateChanged(int state) {

        }
    };

    /**
     * 改变点点点的切换效果
     *
     * @param selectItem 当前选中的页面索引
     */
    private void setImageBackground(int selectItem) {
        for (int i = 0; i < myPagerAdapter.getBanners().length; i++) {
            ImageView imageView = (ImageView) viewGroup.getChildAt(i);
            imageView.setBackground(null);
            if (i == selectItem) {
                imageView.setImageResource(R.drawable.icon_page_select);
            } else {
                imageView.setImageResource(R.drawable.icon_page_normal);
            }
        }
    }

}

以上是总结了网络上资源,效果图如下;

?

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:32:51  更:2022-04-01 23:33:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 19:39:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码