在viewpager中動態新增view,並實現偽無限迴圈
阿新 • • 發佈:2019-01-31
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);
}
}
效果圖: