1. 程式人生 > >在viewpager中動態新增view,並實現偽無限迴圈

在viewpager中動態新增view,並實現偽無限迴圈

        viewpager的使用,大家都熟悉,它可以實現頁面之間左右滑動的切換,這裡有一個需求,就是viewpager裡面載入的頁數不是確定的,而是根據資料的多少來確定的。常見的應用就是在一個新聞的詳細頁面中,顯示與此新聞有關的圖片。

        下面我們來看一下程式碼:

        activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <android.support.v4.view.ViewPager
        android:id="@+id/list_pager"
        android:layout_width="fill_parent"
        android:layout_height="150dp"
        />

</RelativeLayout>

         fragment_page.xml
<?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:gravity="center"
    android:background="#ffff44">

    <TextView
        android:id="@+id/txt_num"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:text="1"
        android:textSize="22dp"
        android:gravity="center"/>

</LinearLayout>

       viewpageAdapter.java
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;

import java.util.List;

/**
 * Created by cg on 2015/10/28.
 */
public class viewpageAdapter extends PagerAdapter {
    private List<View> list_view;

    public viewpageAdapter(List<View> list_view) {
        this.list_view = list_view;
    }

    @Override
    public int getCount() {
        return Integer.MAX_VALUE;
    }

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

    @Override
    public Object instantiateItem(ViewGroup container, int position) {

        container.addView(list_view.get(position % list_view.size()));
        return list_view.get(position % list_view.size());
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView(list_view.get(position % list_view.size()));
    }
}

MainActivity.java
import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.List;

/**
 * 動態在viewpager中新增view,並實現無限迴圈
 */
public class MainActivity extends AppCompatActivity {

    private ViewPager list_pager;

    private List<View> list_view;

    private viewpageAdapter adpter;

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

        list_pager = (ViewPager)findViewById(R.id.list_pager);

        list_view = new ArrayList<>();

        //這裡只設置了4.因為在實現應用中,我們在頁面載入的時候,你會根據資料的多少,而知道這個頁面的數量
        //一般情況下,我們會根據list<>或是string[]這樣的陣列的數量來判斷要有多少頁
        for(int i=0;i<4;i++)
        {
            View view = LayoutInflater.from(this).inflate(R.layout.fragment_page,null);
            TextView txt_num = (TextView)view.findViewById(R.id.txt_num);
            txt_num.setText(i + "");
            list_view.add(view);
        }

        adpter = new viewpageAdapter(list_view);
        list_pager.setAdapter(adpter);

        // 剛開始的時候 吧當前頁面是先到最大值的一半 為了迴圈滑動
        int currentItem = Integer.MAX_VALUE / 2;
        // 讓第一個當前頁是 0
        //currentItem = currentItem - ((Integer.MAX_VALUE / 2) % 4);
        list_pager.setCurrentItem(currentItem);

    }

}

效果圖: