从零开始水安卓——高级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)

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ViewPager是一个Android中的View容器,可以让用户在多个页面之间进行滑动切换。要实现多页面滑动切换以及动画效果,可以按照以下步骤: 1. 在XML布局文件中添加ViewPager控件,并添加对应的布局文件,例如: ``` <android.support.v4.view.ViewPager android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 2. 在Java代码中为ViewPager设置Adapter,用于显示多个页面。例如: ``` ViewPager viewPager = findViewById(R.id.viewPager); MyPagerAdapter adapter = new MyPagerAdapter(getSupportFragmentManager()); viewPager.setAdapter(adapter); ``` 其中,MyPagerAdapter是自定义的PagerAdapter类,需要继承自FragmentPagerAdapter或FragmentStatePagerAdapter。 3. 在自定义的PagerAdapter类中实现getItem()方法,用于返回每个页面的Fragment实例。例如: ``` @Override public Fragment getItem(int position) { switch (position) { case 0: return new Fragment1(); case 1: return new Fragment2(); case 2: return new Fragment3(); default: return null; } } ``` 其中,Fragment1、Fragment2、Fragment3是自定义的Fragment类,用于显示对应页面的内容。 4. 如果需要添加页面切换的动画效果,可以在Java代码中为ViewPager设置PageTransformer。例如: ``` viewPager.setPageTransformer(true, new DepthPageTransformer()); ``` 其中,DepthPageTransformer是自定义的PageTransformer类,用于实现页面切换时的动画效果。可以参考以下代码示例: ``` public class DepthPageTransformer implements ViewPager.PageTransformer { private static final float MIN_SCALE = 0.75f; public void transformPage(View view, float position) { int pageWidth = view.getWidth(); if (position < -1) { // [-Infinity,-1) // This page is way off-screen to the left. view.setAlpha(0f); } else if (position <= 0) { // [-1,0] // Use the default slide transition when moving to the left page view.setAlpha(1f); view.setTranslationX(0f); view.setScaleX(1f); view.setScaleY(1f); } else if (position <= 1) { // (0,1] // Fade the page out. view.setAlpha(1 - position); // Counteract the default slide transition view.setTranslationX(pageWidth * -position); // Scale the page down (between MIN_SCALE and 1) float scaleFactor = MIN_SCALE + (1 - MIN_SCALE) * (1 - Math.abs(position)); view.setScaleX(scaleFactor); view.setScaleY(scaleFactor); } else { // (1,+Infinity] // This page is way off-screen to the right. view.setAlpha(0f); } } } ``` 以上就是实现Android中ViewPager多页面滑动切换以及动画效果的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云无心鸟知还

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值