ViewPager详解 <一> : 基础知识

在使用ViewPager时,发现其实现核心其实是PagerAdapter。先研究之。


0. PagerAdapter:

PagerAdapter是ViewPager提供填充页面内容的适配器(Adapter). 它有两个子类:FragmentPagerAdapter or FragmentStatePagerAdapter用来实现Fragment的滑动效果。

ViewPager是android.support.v4扩展包提供的一个控件。可以实现控件的侧滑效果。PagerAdapter就是ViewPager实现侧滑的适配器。


ViewPager不是直接与Views关联而是与一个key对象关联起来。这个key对象用来记录并且在这个适配器中唯一地标示某个页面。而这个唯一性与页面所处的位置无关。如果ViewPager的页面内容改变,那么系统就会调用这个ViewPager所对应的PagerAdapterstartUpdate(ViewGroup)方法。之后,系统会根据页面中的内容,调用若干次instantiateItem(ViewGroup, int) 或者destroyItem(ViewGroup, int, Object)方法,最后,在这次更新结束之前,系统会调用 finishUpdate(ViewGroup)方法。在finishUpdate结束之前 , instantiateItem destroyItem方法会分别完成将key objects所对应的view对象加载到其父ViewGroup中和删除之。而isViewFromObject(View, Object)方法可以用于判断某个view是否对应某个key对象。其中,我们可以简单地将Page Views本身作为key objects,我们可以在instantiateItem(ViewGroup, int)中创建view对象和将这个对象添加到父ViewGroup中,并且最后将这个view对象作为这个方法的返回值。同样地,destroyItem(ViewGroup, int, Object)也可以类似操作。相对于地,isViewFromObject(View, Object) 可以这样子实现:

return view == object;.



PagerAdapter将需要滑动的View存储和管理起来。供ViewPager随时使用。它同时缓存3个页面(未查到出处),当需要进入新的页面时,它将自动将新的页面加入(instantiateItem(ViewGroup, int)), 而将旧页面销毁(destroyItem(ViewGroup, int, Object))。


需要实现一个PagerAdapter时,至少要重写以下4个方法:


分别讲解如下:

getCount():  得到可以滑动的控件的数量。


instantiateItem(ViewGroup, int)

当需要添加以int为索引的页面到Adapter时调用。

创建一个以给定的position(参数2)为索引的Page。Adapter负责把View加入指定的容器。

ViewGroup:容器,页面将要显示它。

int position: 实例化的页面索引。

返回值:Key Object。代表新实例化的页。


isViewFromObject(View, Object): 

检测给定的View(参数一)是否关联于Key Object(从instatiateItem()返回的)。通常情况下,因为instantiateItem()返回的Key Object就是添加如的View。 所以这里仅仅返回:

View == Object就好。




1. ViewPager 与PageAdapter关联:

viewpager = (ViewPager) this.findViewById(R.id.viewpager1); 

viewpager.setAdapter(new myPageAdapter());


其中:viewpager1 是在xml中添加的。




2. 实例:

2.1: 在Layout xml中添加ViewPager.

<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" >

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

        <android.support.v4.view.PagerTitleStrip
            android:id="@+id/pagertitle"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="top" >
        </android.support.v4.view.PagerTitleStrip>
    </android.support.v4.view.ViewPager>

</RelativeLayout>



2.2: 创建多个Layout xml作动态加载的布局,创建View供PageAdapter使用,共创建4个,分别为:tab1.xml  tab2.xml  tab3.xml tab4.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:orientation="vertical" >

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />
   
</LinearLayout>


2.3: 在Activity中实现ViewPager:



package com.example.android.snake;

import java.security.PublicKey;
import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.app.ListActivity;
import android.os.Bundle;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.PagerTitleStrip;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.widget.ArrayAdapter;
import android.widget.TextView;


public class Snake extends Activity {

    private SnakeView mSnakeView;
    private ViewPager viewpager1;
    private PagerTitleStrip title;
    private List<View> list;
    private List<String> titleList;
    
    
    
    private static String ICICLE_KEY = "snake-view";

    /**
     * Called when Activity is first created. Turns off the title bar, sets up
     * the content views, and fires up the SnakeView.
     *
     */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.snake_layout);

        // 得到ViewPager和Title。
        viewpager1 = (ViewPager) this.findViewById(R.id.viewpager1);
        title = (PagerTitleStrip) this.findViewById(R.id.pagertitle);

        View view1 = LayoutInflater.from(this).inflate(R.layout.tab1,null);
        View view2 = LayoutInflater.from(this).inflate(R.layout.tab2, null);
        View view3 = LayoutInflater.from(this).inflate(R.layout.tab3, null);
        View view4 = LayoutInflater.from(this).inflate(R.layout.tab4, null);
        
        list = new ArrayList<View>();
        list.add(view1);
        list.add(view2);
        list.add(view3);
        list.add(view4);
        
        titleList = new ArrayList<String>();
        titleList.add("title1");
        titleList.add("title2");
        titleList.add("title3");
        titleList.add("title4");
        
        //将ViewPager与PageAdapter联系起来
        viewpager1.setAdapter(new myPageAdapter() );
        


    }
    
    
    class myPageAdapter extends PagerAdapter {

//得到Page的数量
        @Override
        public int getCount() {
            // TODO Auto-generated method stub
            return list.size();
        }
        
        // 得到对应Page Title
        @Override
        public CharSequence getPageTitle(int position) {
            // TODO Auto-generated method stub
            return titleList.get(position);
        }
        

//增加Page,注意返回值
        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            // TODO Auto-generated method stub
            ((ViewPager)container).addView(list.get(position));
            return list.get(position);
        }

// 判断给定的View是否是Key Object
        @Override
        public boolean isViewFromObject(View arg0, Object arg1) {
            // TODO Auto-generated method stub
            return arg0 == arg1;
        }

//删除指定的Page
        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            // TODO Auto-generated method stub
        //    super.destroyItem(container, position, object);
            ((ViewPager)container).removeView(list.get(position));
            
        }

        
        
        
        
    }

    @Override
    protected void onPause() {
        super.onPause();

    }



}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值