Android 在 Scrollview 中使用 Listview 布局 ViewPager
Android Layout ViewPager with Listview in Scrollview
目前我正在尝试在 xml 中创建类似这样的东西。
用户能够滚动整个页面而不是仅列表视图。
任何人都知道如何创建此 XML 或任何建议使用什么来替换列表视图。
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
tools:context="plaza_semanggi.lippomalls.lippoapp.Screens.HomeFragment"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:layout_width ="wrap_content"
android:layout_height ="wrap_content"
card_view:cardCornerRadius= "5dp"
android:layout_weight="5"
>
<android.support.v4.view.ViewPager
android:id="@+id/home_viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
</android.support.v7.widget.CardView>
<ListView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="5"></ListView>
</LinearLayout>
一种可能是将所有内容都放在列表视图中。您的列表适配器的第一个位置将 return 带有 Viewpager 的 CardView 和以下位置 return 您的其他列表条目。
不要使用 Scrollview ....只使用 ListView 并首先为 viewpager 创建两个视图,然后为列表项视图创建第二个视图。
在列表视图的第一行添加 Viewpager 视图,其余为列表项。
在适配器中使用以下更改
@Override
public int getItemViewType(int position) {
// TODO Auto-generated method stub
boolean strViewPagerFlage=arraylist.get(position).getviewpageflage();
//get
if(strViewPagerFlage){
//For ViewPager
return 0;
}else{
//For ListItem
return 1;
}
}
@Override
public int getViewTypeCount() {
// TODO Auto-generated method stub
return 2;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
View view = convertView;
if(position == 0){
view = inflater.inflate(R.layout.view_pager_layout, null);
}else{
view = inflater.inflate(R.layout.list_item, null);
}
}
目前我正在尝试在 xml 中创建类似这样的东西。 用户能够滚动整个页面而不是仅列表视图。 任何人都知道如何创建此 XML 或任何建议使用什么来替换列表视图。
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
tools:context="plaza_semanggi.lippomalls.lippoapp.Screens.HomeFragment"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:layout_width ="wrap_content"
android:layout_height ="wrap_content"
card_view:cardCornerRadius= "5dp"
android:layout_weight="5"
>
<android.support.v4.view.ViewPager
android:id="@+id/home_viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
</android.support.v7.widget.CardView>
<ListView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="5"></ListView>
</LinearLayout>
一种可能是将所有内容都放在列表视图中。您的列表适配器的第一个位置将 return 带有 Viewpager 的 CardView 和以下位置 return 您的其他列表条目。
不要使用 Scrollview ....只使用 ListView 并首先为 viewpager 创建两个视图,然后为列表项视图创建第二个视图。 在列表视图的第一行添加 Viewpager 视图,其余为列表项。
在适配器中使用以下更改
@Override
public int getItemViewType(int position) {
// TODO Auto-generated method stub
boolean strViewPagerFlage=arraylist.get(position).getviewpageflage();
//get
if(strViewPagerFlage){
//For ViewPager
return 0;
}else{
//For ListItem
return 1;
}
}
@Override
public int getViewTypeCount() {
// TODO Auto-generated method stub
return 2;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
View view = convertView;
if(position == 0){
view = inflater.inflate(R.layout.view_pager_layout, null);
}else{
view = inflater.inflate(R.layout.list_item, null);
}
}