018_Android ViewPager

ViewPage的继承关系

 

8917395-3b7110a08dba3e60.png

ViewPager的继承关系.png

  • 是android中专门用来实现左右滑动切换View效果的系统控件
  • 是android-support-v4.jar包提供的
  • 只能左右滑动

ViewPage实现轮播图

MainActivity类

import android.os.Bundle;
import android.os.Handler;
import android.os.Message;

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

import java.util.Timer;
import java.util.TimerTask;

public class MainActivity extends AppCompatActivity {

    //要加载的图片
    private int[] imgIds = {
            R.mipmap.pic1,
            R.mipmap.pic2,
            R.mipmap.pic3,
    };
    private ViewPager viewPager;
    private Handler handler = new Handler() {
        @Override
        public void handleMessage(@NonNull Message msg) {
            super.handleMessage(msg);
            if (msg.what == 1) {
                //获得当前的位置
                int currentItem = viewPager.getCurrentItem();
                //跳转到指定位置
                viewPager.setCurrentItem(currentItem + 1);
            }
        }
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        viewPager = findViewById(R.id.viewPager);
        //设置适配器
        viewPager.setAdapter(new MyAdapter(imgIds, this));

        //定时器 每两秒执行一次
        new Timer().schedule(new TimerTask() {
            @Override
            public void run() {
                handler.sendEmptyMessage(1);
            }
        }, 0, 2000);
    }
}

MyAdapter类

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

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

public class MyAdapter extends PagerAdapter {

    private int[] imagesResource;
    private Context context;

    public MyAdapter(int[] imagesResource, Context context) {
        this.imagesResource = imagesResource;
        this.context = context;
    }

    //获取ViewPager显示数据个数
    @Override
    public int getCount() {
        if (imagesResource == null || imagesResource.length <= 0) {
            return 0;
        }
        return Integer.MAX_VALUE;
    }

    //判断view和obj是否为同一个view
    @Override
    public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
        return view == object;
    }


    //当前项离开屏幕时执行的方法
    @Override
    public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
        container.removeView((View) object);
    }

    //实例化数据集合中的每一个数据
    @NonNull
    @Override
    public Object instantiateItem(@NonNull ViewGroup container, int position) {

        //获得布局
        View view =  LayoutInflater.from(context).inflate(R.layout.layout, null);
        //获得数量
        ImageView imageView = view.findViewById(R.id.imageView);
        //设置资源
        imageView.setImageResource(imagesResource[position % imagesResource.length]);
        container.addView(view);
        return view;

    }


}

​ 主布局

<?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="match_parent"
    tools:context=".MainActivity">

    <androidx.viewpager.widget.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="wrap_content"
        android:layout_height="280dp"/>

</RelativeLayout>

​ ViewPage加载的布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ImageView
        android:id="@+id/imageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:contentDescription="@string/app_name"/>

</LinearLayout>

效果图

 

8917395-3b60ce374ceb8f81.gif

ViewPager效果图.gif

(小姐姐图片来源于知乎)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值