如何在ListView标头中包含ViewPager

时间:2012-11-09 20:10:12

标签: android android-listview android-viewpager

我希望能够在列表视图的标题中添加“图像滑块”。因此,用户可以滑动图像,然后当他们开始滚动页面时,滑块会滚出视图。

我已经使用ViewPager获得了我想要的滑块。现在,我需要做的就是将它插入List View的标题中,但这似乎是我遇到的主要问题。

我添加了寻呼机:

ViewPager pager = (ViewPager) inflater.inflate(R.layout.featured_event, listView, false);

FeaturedEventAdapter featuredAdapter = new FeaturedEventAdapter( getFragmentManager() );

pager.setAdapter( featuredAdapter );

listView.addHeaderView( pager );

我收到以下错误:

java.lang.ClassCastException: android.widget.LinearLayout cannot be cast to android.support.v4.view.ViewPager

现在,需要注意的一点是,如果我在列表视图之外显示它,那么它的工作原理非常好。

编辑:featured_event xml

<?xml version="1.0" encoding="utf-8"?>    
<android.support.v4.view.ViewPager xmlns:android="http://schemas.android.com/apk/res/android"
   android:id="@+id/pager"
   android:layout_width="match_parent"
   android:layout_height="200dip">

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

        <ImageView xmlns:android="http://schemas.android.com/apk/res/android"
             android:id="@+id/imageView1"
             android:layout_width="wrap_content"
             android:layout_height="wrap_content"
             android:src="@drawable/car" />

    </LinearLayout>

</android.support.v4.view.ViewPager>

1 个答案:

答案 0 :(得分:0)

无法看到你的featured_event.xml布局,我试试这个:

View root = inflater.inflate(R.layout.featured_event);
ViewPager pager = null;
if (root instanceof ViewPager){
    Log.d("TAG", "the root element IS the viewpager");
    pager = root;    
} else {
    Log.d("TAG", "pager is not the root element in featured_event.xml, lets find it");
    pager= (ViewPager) root.findViewById(R.id.myViewPagerIdThatIGaveIt);
}
FeaturedEventAdapter featuredAdapter = new FeaturedEventAdapter( getFragmentManager() );
// add header before adapter
listView.addHeaderView( pager );
pager.setAdapter( featuredAdapter );