当前位置: 移动技术网 > 移动技术>移动开发>Android > 安卓开发笔记(二十五):ViewPager的使用

安卓开发笔记(二十五):ViewPager的使用

2019年04月22日  | 移动技术网移动技术  | 我要评论
  • 首先我们来看看运行之后的效果:

然后我们也不多说废话了,下面是这个项目所需要的全部代码,很多博主写这个都不把代码写完,因此笔者自己也琢磨了一会儿才把这个弄出来,感觉很烦,但我肯定会把代码写全的。我这里一共引入了三个界面,三个布局的xml我都会写的。

 

1.mainactivity.java

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;

public class mainactivity extends appcompatactivity {
    private viewpager vpager_one;
    private arraylist<view> alist;
    private mypageradapter madapter;
    @override
    protected void oncreate(bundle savedinstancestate) {
        super.oncreate(savedinstancestate);
        setcontentview(r.layout.activity_main);
        vpager_one = (viewpager) findviewbyid(r.id.vpager_one);

        alist = new arraylist<view>();
        layoutinflater li = getlayoutinflater();
        alist.add(li.inflate(r.layout.view_one,null,false));
        alist.add(li.inflate(r.layout.view_two,null,false));
        alist.add(li.inflate(r.layout.view_three,null,false));
        madapter = new mypageradapter(alist);
        vpager_one.setadapter(madapter);
    }
}

2.mypageradapter.java

这个是viewpager的适配器,和listview所需要的适配器差不多,是我们创建的新类。

import android.support.v4.view.pageradapter;
import android.view.view;
import android.view.viewgroup;

import java.util.arraylist;

public class mypageradapter extends pageradapter {

    private arraylist<view> viewlists;

    public mypageradapter() {
    }

    public mypageradapter(arraylist<view> viewlists) {
        super();
        this.viewlists = viewlists;
    }

    @override
    public int getcount() {
        return viewlists.size();
    }

    @override
    public boolean isviewfromobject(view view, object object) {
        return view == object;
    }

    @override
    public object instantiateitem(viewgroup container, int position) {
        container.addview(viewlists.get(position));
        return viewlists.get(position);
    }

    @override
    public void destroyitem(viewgroup container, int position, object object) {
        container.removeview(viewlists.get(position));
    }
}

3.activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.constraintlayout 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/vpager_one"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center" />

</android.support.constraint.constraintlayout>

4.view_one

<?xml version="1.0" encoding="utf-8"?>
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ffba55"
    android:gravity="center"
    android:orientation="vertical">

    <textview
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="第一个page"
        android:textcolor="#000000"
        android:textsize="18sp"
        android:textstyle="bold" />

</linearlayout>

5.view_two

<?xml version="1.0" encoding="utf-8"?>
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ffba55"
    android:gravity="center"
    android:orientation="vertical">

    <textview
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="第二个page"
        android:textcolor="#000000"
        android:textsize="18sp"
        android:textstyle="bold" />

</linearlayout>

6.view_three

<?xml version="1.0" encoding="utf-8"?>
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ffba55"
    android:gravity="center"
    android:orientation="vertical">

    <textview
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="第三个page"
        android:textcolor="#000000"
        android:textsize="18sp"
        android:textstyle="bold" />
</linearlayout>

得解,就这么简单。我真是不知道其他博主为啥不把代码写全,尤其是每个viewpager的布局,连说都不说下有三个布局,真实让人头大。

 

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网