这次讲的是关于ViewPager的使用方法,而什么是ViewPager呢,我们来看看官网的介绍,Layout manager that allows the user to flip left and right through pages of data. You supply an implementation of a PagerAdapter
to generate the pages that the view shows.
简单来说,就是界面管理对页面变化的支持,但是需要PagerAdapter这个接口进行实现,官网还有更加详细的介绍,想更加深入了解的朋友可以去查看官网。
首先,我们当然是在界面的xml中添加一个ViewPager控件。
<span style="font-size:18px;"><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.exam.viewpagerdemo.MainActivity" >
<android.support.v4.view.ViewPager
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/viewPager"
>
</android.support.v4.view.ViewPager>
</RelativeLayout></span>
然后就是类的实现了,我们首先找几张图片,笔者就简单的从网上搜了几张美女的图片,首先对ViewPager进行声明,并且呢,将图片放在一个数组里面。
import java.util.ArrayList;
import java.util.List;
import android.renderscript.RenderScript.ContextType;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.ImageView.ScaleType;
public class MainActivity extends ActionBarActivity {
private int[] res = new int[]{R.drawable.girl,R.drawable.girl2,R.drawable.girl3,R.drawable.girl4,R.drawable.girl5};
private ViewPager viewPager;
private List<ImageView> imageViews = new ArrayList<ImageView>();
好了,很简单,然后我们对ViewPager进行加载适配器, 在这里我们使用匿名内部类的方式,使用了PagerAdapter的接口实现。
<span style="font-size:18px;"> @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
viewPager = (ViewPager) findViewById(R.id.viewPager);
viewPager.setAdapter(new PagerAdapter() {
@Override
public Object instantiateItem(ViewGroup container, int position) {
ImageView imageView = new ImageView(MainActivity.this);
imageView.setImageResource(res[position]);
imageView.setScaleType(ScaleType.CENTER_CROP);
container.addView(imageView);
imageViews.add(imageView);
return imageView;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// TODO Auto-generated method stub
container.removeView(imageViews.get(position));
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
// TODO Auto-generated method stub
return arg0 == arg1;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return res.length;
}
});
}</span>
在这个PagerAdapter类里面,我们要添加两个方法,
instantiateItem()和destroyItem(),这两个方法分别是对每个页面进行初始化和销毁页面,当我们将页面拖出来时则是初始化的过程而页面隐藏时候,却是页面的销毁,这就是ViewPager的基本使用了,效果图如下: