从零开始水安卓——高级UI组件6(ViewPager)
概述
位于android.support.v4.view.ViewPager(v4,官方提供的兼容低版本安卓设备的软件包,ViewPager需要安卓3.0及以上)
ViewPager是一个页面切换组件,可以利用它实现导航、页面菜单等功能。
实现
PagerAdapter
首先是activity_main.xml,这里需要注意的,如概述提到的,需要引入android.support.v4.view.ViewPager
此外,本案例还设置了一个gravity为top的PagerTabStrip,相当于一个顶部导航的效果。(如果把top改成bottom,就变成底部导航栏了哦)
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<android.support.v4.view.PagerTabStrip
android:id="@+id/pagertab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="top"
app:layout_constraintStart_toStartOf="@+id/viewpager"
app:layout_constraintTop_toTopOf="@+id/viewpager">
</android.support.v4.view.PagerTabStrip>
</android.support.v4.view.ViewPager>
</android.support.constraint.ConstraintLayout>
然后还需要准备若干个自定义布局,即你的每个View界面。
例如下面的代码:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/imageview"
android:scaleType="centerCrop"
android:src="@drawable/a1"/>
</LinearLayout>
然后准备结束,正式开始编写代码
首先还是注册组件
完毕后准备一个字符串数组,准备一个集合装布局(view)
????然后再准备一个方法实例化view,例如下面的语句
views.add(getLayoutInflater().inflate(R.layout.layout1,null));
都准备完毕就可以开始创建适配器,继承PagerAdapter,需要重写的方法如下:
getCount()比较好理解直接return view的数量即可,即我们准备的装view的集合的size
@Override
public int getCount() {
return views.size();
}
instantiateItem的话,将view从集合中获取出来再装在到container中去
@Override
public Object instantiateItem(@NonNull ViewGroup container, int position) {
View v = views.get(position);
container.addView(v);
return v;
}
destroyItem反一下,将view从container中remove
@Override
public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
container.removeView(views.get(position));
}
isViewFromObject 判断view和对象是否相等
@Override
public boolean isViewFromObject(@NonNull View view, @NonNull Object o) {
return view==o;
}
最后CharSequence getPageTitle,终于轮到我们的字符串数组派上用场了。
@Override
public CharSequence getPageTitle(int position) {
return titles[position];
}
效果
补充
设置指示标签的属性(pagerTabStrip)
setTablndicatorColor /指示器的颜色
setBackgroundColor//背景色
setTextColor//字体颜色
代码加再图示位置即可:
效果如下:
切换事件
implements ViewPager.OnPageChangeListener
主要有以下三个方法
@Override
public void onPageScrolled(int i, float v, int i1) {
}
@Override
public void onPageSelected(int i) {
}
@Override
public void onPageScrollStateChanged(int i) {
}
然后切换呢,我们重写onPageSelected就好,代码如下:
@Override
public void onPageSelected(int i) {
Toast.makeText(this,"Page---"+i,Toast.LENGTH_LONG).show();
}
效果如图:(索引0开始,所以标题是2,下面toast是1)