1 ViewPager 简介
ViewPager是Android的一个视图滑动切换组件,该组件可通过手势滑动完成View的切换,一般是用来做APP的引导页或者实现图片轮播,和ListView、GridView等组件一样需要一个Adapter来将我们的视图进行绑定。
ViewPager使用的是PagerAdapter,还有FragmentPageAdapter和FragmentStatePagerAdapter,本篇着重介绍PagerAdaper的使用。
2 PagerAdapter的使用
要使用PagerAdapter,我们需要重写其方法
getCount:得到ViewPager中View的个数
destroyItem:移除一个给定位置的View
instantiateItem:实例化给定位置的View,并返回一个对象
isViewFromObject:判断instantiateItem(ViewGroup, int)函数所返回来的对象与一个页面视图是否是代表的同一个视图(即它俩是否是对应的,对应的表示同一个View),通常我们直接写 return view == object!
3 关键代码
view_pager_content.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto">
<TextView
android:id="@+id/vc_text"
android:text="text"
android:textSize="40sp"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</android.support.constraint.ConstraintLayout>
自定义的PagerAdapter
class MyPagerAdapter extends PagerAdapter{
private ArrayList<View> views;
public MyPagerAdapter(ArrayList<View> views){
this.views = views;
}
@Override
public int getCount() {
return views.size();
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
View view = views.get(position);
final int[] colors = {
Color.YELLOW,
Color.GREEN,
Color.RED,
Color.WHITE
};
view.setBackgroundColor(colors[position]);
((TextView)view.findViewById(R.id.vc_text)).setText(""+position);
container.addView(view);
return view;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView(views.get(position));
}
}
Activity
public class ViewPagerActivity extends AppCompatActivity {
@BindView(R.id.view_pager)
ViewPager viewPager;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.view_pager_main);
ButterKnife.bind(this);
LayoutInflater inflater = getLayoutInflater();
final ArrayList<View> views = new ArrayList<>();
views.add(inflater.inflate(R.layout.view_pager_content,null));
views.add(inflater.inflate(R.layout.view_pager_content,null));
views.add(inflater.inflate(R.layout.view_pager_content,null));
views.add(inflater.inflate(R.layout.view_pager_content,null));
MyPagerAdapter adapter = new MyPagerAdapter(views);
viewPager.setAdapter(adapter);
}
}
今天的文章ViewPager入门使用之PagerAdapter分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/19674.html