我希望我可以在 viewpager 的页面中显示 3 个项目,但现在我只能设置 viewpager 的填充值和边距值,所以它只能在 viewpager 的页面中显示一个项目。如何设置项目宽度?我想如果我可以设置更小的项目宽度,viewpager 将在页面中显示更多项目。
2 回答
快速回答
您想要的是覆盖您为此所做getPageWidth
的PagerAdapter
实现ViewPager
。
例如,将其设置为0.8f
将使单个页面仅覆盖 viewpagers 宽度的 80%,以便下一页和/或上一页的一部分可见。
@Override
public float getPageWidth(final int position) {
return 0.8f;
}
更多信息,请访问https://developer.android.com/reference/android/support/v4/view/PagerAdapter.html#getPageWidth(int)
其他备注
另请注意,负边距只会导致单独的页面相互重叠。页边距用于定义每页之间的间距。
如果没有配置替代 pageWidth(没有设置器,只有覆盖),默认情况下它将覆盖 100%,除非拖动,否则其他页面的任何部分都不可见。
代码示例
可以在这里找到对可能的非常好的概述https://commonsware.com/blog/2012/08/20/multiple-view-viewpager-options.html
布局中的视图寻呼机
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v4.view.ViewPager>
内联配置适配器实现的示例,这将进入 onCreate 或 onViewCreated 方法:
// get a reference to the viewpager in your layout
ViewPager mViewPager = (ViewPager) findViewById(R.id.viewpager);
// this margin defines the space between the pages in the viewpager mViewPager.setPageMargin(context.getResources().getDimensionPixelSize(R.dimen.margin_normal));
// setting the adapter on the viewpager, this could/should be a proper Adapter implementation in it's own class file instead
mViewPager.setAdapter(new PagerAdapter() {
// just example data to show, 3 pages
String[] titles = {"Eins", "Zwei", "Drei"};
int[] layouts = {R.layout.layout1, R.layout.layout2, R.layout.layout3};
@Override
public Object instantiateItem(ViewGroup container, int position) {
LayoutInflater inflater = LayoutInflater.from(MainActivity.this);
// here you can inflate your own view and dress up
ViewGroup layout = (ViewGroup) inflater.inflate(layouts[position], container, false);
container.addView(layout);
return layout;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View)object);
}
@Override
public float getPageWidth(final int position) {
return 0.8f;
}
@Override
public CharSequence getPageTitle(int position) {
return titles[position];
}
@Override
public int getCount() {
return layouts.length;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
});
基于https://newfivefour.com/android-viewpager-simple-views.html的示例代码
您是否尝试将页边距设置为负值,请参阅setPageMargin(int)
?如果我没记错的话,我读到有人意识到与您所描述的类似。
或者,您可以看看使用 aGallery
代替,尽管我不得不承认我不是它们的忠实粉丝,因为它们似乎不太灵活且更容易出错。