ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

ViewPager控件之PagerAdapter适配器

2021-09-09 16:32:16  阅读:199  来源: 互联网

标签:控件 viewList ViewPager 适配器 import android PagerAdapter view


一、ViewPager的基本用法

  1、简介

        ViewPager可以实现多个界面的左右滑动。ViewPager最典型的应用场景主要包 括引导页导航,轮转广告和页面菜单。

        ViewPager最早出自4.0版本,为了兼容低版本安卓设备,谷歌官方给我们提供了 一个的软件包android.support.v4.view。

  2、ViewPager的基本用法

1、在主界面中放置 ViewPager控件

2、创建用于滑动切 换的视图

3、将创建好的多个 视图装入View数组

4、定义PagerAdapter适配 器管理要显示的页

5、绑定适配器和 ViewPager控件

二、PagerAdapter适配器

1、PagerAdapter就是用于“将多个页面填充到ViewPager”的一个基类适配器。

2、在实际使用中,往往会自定义一个具体的适配器,并让它继承PagerAdapter。

3、继承PagerAdapter基类之后,往往需要在程序中重写相应的方法。

 三、代码部分

  1、activity_main.xml

   添加ViewPager控件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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">
    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
    </android.support.v4.view.ViewPager>
</LinearLayout>

  2、page1.xml;page2.xml;page3.xml

   添加三个界面,并且添加各自图片用于滑动显示

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" android:layout_height="match_parent">
    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:src="@drawable/view1"/>
</RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" android:layout_height="match_parent">
    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:src="@drawable/view2"/>
</RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" android:layout_height="match_parent">
    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:src="@drawable/view3"/>
</RelativeLayout>

  3、MainActivity.java

package com.example.zsviewpager;

import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
    //1.创建View对象,以及View数组
    private View view1,view2,view3;
    private List<View> viewList;
    private MyPagerAdapter myPagerAdapter;
    private ViewPager viewPager;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //2.将前面定义的滑动布局转换成view对象
        LayoutInflater  inflater = getLayoutInflater();
        view1 = inflater.inflate(R.layout.page1,null);
        view2 = inflater.inflate(R.layout.page2,null);
        view3 = inflater.inflate(R.layout.page3,null);
        //3.将前面定义的view对象存入view数组
        viewList = new ArrayList<View>();
        viewList.add(view1);
        viewList.add(view2);
        viewList.add(view3);
        //4.定义自定义适配器
        myPagerAdapter = new MyPagerAdapter(viewList);
        //5.将适配器和ViewPager控件进行绑定
        viewPager = findViewById(R.id.viewpager);
        viewPager.setAdapter(myPagerAdapter);
    }
}

  4、MyPagerAdapter.java

     这是继承于PagerAdapter的

package com.example.zsviewpager;
import android.support.annotation.NonNull;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import java.util.List;
public class MyPagerAdapter extends PagerAdapter {
    //1.定义view数组,用来接收从Activity传递过来的view数组
    private List<View> pageList;
    //2.定义MyPagerAdapter类的构造方法,接收数据
    public MyPagerAdapter(List<View> viewList){
        this.pageList = viewList;
    }
    @Override
    public int getCount() {
        return pageList.size();
    }
    @Override
    public boolean isViewFromObject(@NonNull View view, @NonNull Object o) {
        return view == o;
    }
    @Override
    public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
        //将当前位置的view视图删除
        container.removeView(pageList.get(position));
    }
    @NonNull
    @Override
    public Object instantiateItem(@NonNull ViewGroup container, int position) {
        //将当前视图添加到container中
        container.addView(pageList.get(position));
        //返回当前的view视图
        return  pageList.get(position);
    }
}

到此我们就是实现了图片滑动的效果。

标签:控件,viewList,ViewPager,适配器,import,android,PagerAdapter,view
来源: https://blog.csdn.net/indeedes/article/details/120184165

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有