在视图页面中使用更多视图

时间:2011-10-26 12:25:55

标签: java android

如何在视图中使用不同的视图?我弄清楚了。

例如,包含列表框的视图和带按钮的视图。

这是我的代码:

如何在视图中使用不同的视图?我弄清楚了。

例如,包含列表框的视图和带按钮的视图。

这是我的代码:

package com.stylingandroid.viewpager;

import com.viewpagerindicator.TitlePageIndicator;

import android.app.Activity;
import android.os.Bundle;
import android.support.v4.view.ViewPager;

public class ViewPagerActivity extends Activity
{
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        ViewPagerAdapter adapter = new ViewPagerAdapter(this);
        ViewPager pager = (ViewPager) findViewById(R.id.viewpager);
        TitlePageIndicator indicator = (TitlePageIndicator) findViewById(R.id.indicator);
        pager.setAdapter(adapter);
        indicator.setViewPager(pager);
    }
}

这里是适配器:

package com.stylingandroid.viewpager;

import android.content.Context;
import android.os.Parcelable;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.widget.TextView;

import com.viewpagerindicator.TitleProvider;

public class ViewPagerAdapter extends PagerAdapter
    implements TitleProvider
{
    private static String[] titles = new String[]
    {
        "Page 1",
        "Page 2",
        "Page 3"
    };
    private final Context context;

    public ViewPagerAdapter( Context context )
    {
        this.context = context;
    }

    @Override
    public String getTitle( int position )
    {
        return titles[ position ];
    }

    @Override
    public int getCount()
    {
        return titles.length;
    }

    @Override
    public Object instantiateItem( View pager, int position )
    {
        TextView v = new TextView( context );
        v.setText(titles[position]);

        ((ViewPager)pager).addView(v,0);

        return v;
    }

    @Override
    public void destroyItem( View pager, int position, Object view )
    {
        ((ViewPager)pager).removeView( (TextView)view );
    }

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

    @Override
    public void finishUpdate( View view ) {}

    @Override
    public void restoreState( Parcelable p, ClassLoader c ) {}

    @Override
    public Parcelable saveState() {
        return null;
    }

    @Override
    public void startUpdate( View view ) {}
}

2 个答案:

答案 0 :(得分:0)

您需要修改instantiateItem()中的PagerAdapter方法并动态构建每个视图,而不是每次只添加TextView。例如,您可以为每个职位夸大不同的布局:

@Override
public Object instantiateItem( View pager, int position )
{
    LayoutInflator inflator = LayoutInflator.from( context );
    View v = null;
    switch( position )
    {
        case 0:
            v = inflator.inflate( R.layout.layout1, (ViewPager)pager, false );
            break;
        case 1:
            v = inflator.inflate( R.layout.layout2, (ViewPager)pager, false );
            break;
        .
        .
        .
    }
    v.setText(titles[position]);

    ((ViewPager)pager).addView(v,0);

    return v;
}

答案 1 :(得分:0)

你已经拥有了这些代码,但我想指出,如果要进行膨胀,这需要存在。

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