ViewPager+TabLayout实现Android页面滑动切换

本文介绍了如何使用ViewPager和TabLayout在Android中实现页面滑动切换的效果。通过创建FragmentAdapter适配器,结合FragmentLeft和FragmentRight,以及在MainActivity中设置布局和逻辑,成功实现了页面间的滑动切换。最终展示了简单的布局代码和关键的Java实现步骤。
摘要由CSDN通过智能技术生成

ViewPager+TabLayout实现Android页面滑动切换

最近学习了一下Android页面滑动切换效果的实现,写这篇文章加深一下印象

用一个简单的案例来实现该效果

先展示一下效果

GIF 2021-9-6 23-00-16

这里采用时ViewPager和TabLayout实现页面滑动切换效果

首先把布局代码沾上

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity"
    android:orientation="vertical"
    >

    <androidx.viewpager.widget.ViewPager
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="9"
        android:id="@+id/viewPager">
    </androidx.viewpager.widget.ViewPager>

    <com.google.android.material.tabs.TabLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:id="@+id/tabLayout">
    </com.google.android.material.tabs.TabLayout>

</LinearLayout>

用两个fragment页面作为切换页面

fragment_left.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="hello world!"/>
</androidx.constraintlayout.widget.ConstraintLayout>

fragment_right.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="hello SlideSwitch!"/>
</androidx.constraintlayout.widget.ConstraintLayout>

以上就是布局文件内容

下面就是java代码了

先构建FragmentAdapter适配器

MyAdapter.java

public class MyAdapter extends FragmentPagerAdapter {

    private List<Fragment> fragments;

    public MyAdapter(@NonNull FragmentManager fm) {
        super(fm);
    }

    public void setFragments(List<Fragment> fragments) {
        this.fragments = fragments;
    }

    @NonNull
    @Override
    public Fragment getItem(int position) {
        return fragments.get(position);
    }

    @Override
    public int getCount() {
        return fragments.size();
    }
}

然后编写一下两个fragment的java

FragmentLeft.java

public class FragmentLeft extends Fragment {
    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        return inflater.inflate(R.layout.fragment_left, container, false);
    }
}

FragmentRight.java

public class FragmentRight extends Fragment {
    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        return inflater.inflate(R.layout.fragment_right, container, false);
    }
}

最后编写MainActivity活动类

MainActivity.java

public class MainActivity extends AppCompatActivity {

    private ViewPager viewPager;
    private TabLayout tabLayout;
    private List<Fragment> fragments;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        initViewPager();
    }

    private void initViewPager() {
        //创建List集合
        fragments = new ArrayList<>();
        //添加到fragments集合里
        fragments.add(new FragmentLeft());
        fragments.add(new FragmentRight());
        //创建适配器
        MyAdapter adapter = new MyAdapter(getSupportFragmentManager());
        //把fragment添加到adapter
        adapter.setFragments(fragments);
        //吧adapter添加到viewPager
        viewPager.setAdapter(adapter);

        //tabLayout有几个创建几个
        tabLayout.addTab(tabLayout.newTab());
        tabLayout.addTab(tabLayout.newTab());
        //是tabLayout和viewPager关联同步一下
        tabLayout.setupWithViewPager(viewPager);
        //设置创建的名字,一开始时显示索引为0的界面
        tabLayout.getTabAt(0).setText("首页");
        tabLayout.getTabAt(1).setText("消息");
    }

    private void initView() {
        viewPager = findViewById(R.id.viewPager);
        tabLayout = findViewById(R.id.tabLayout);
    }
}

最后跑一下程序,查看效果

本文就到这里,喜欢的朋友能给一个免费的赞嘛,你的鼓励是我前进的动力!

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要禁用TabLayout与ViewPager的左右滑动切换功能,您可以自定义一个ViewPager的子类,并重写它的 `onInterceptTouchEvent` 方法。 首先,创建一个名为 `NonSwipeableViewPager` 的类,并继承自 ViewPager: ```java import android.content.Context; import android.util.AttributeSet; import android.view.MotionEvent; import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.viewpager.widget.ViewPager; public class NonSwipeableViewPager extends ViewPager { public NonSwipeableViewPager(@NonNull Context context) { super(context); } public NonSwipeableViewPager(@NonNull Context context, @Nullable AttributeSet attrs) { super(context, attrs); } @Override public boolean onInterceptTouchEvent(MotionEvent ev) { // 返回false,禁止ViewPager的左右滑动切换 return false; } @Override public boolean onTouchEvent(MotionEvent ev) { // 返回false,禁止ViewPager的左右滑动切换 return false; } } ``` 接下来,在您的布局文件中使用 `NonSwipeableViewPager` 替代原来的 ViewPager: ```xml <com.example.NonSwipeableViewPager android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 最后,通过以下方式将 TabLayout 与 NonSwipeableViewPager 绑定: ```java TabLayout tabLayout = findViewById(R.id.tabLayout); NonSwipeableViewPager viewPager = findViewById(R.id.viewPager); // 设置ViewPager的适配器 viewPager.setAdapter(adapter); // 将TabLayout与ViewPager关联起来 tabLayout.setupWithViewPager(viewPager); ``` 这样就可以禁用TabLayout与ViewPager的左右滑动切换功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小橙子1026

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

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

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

打赏作者

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

抵扣说明:

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

余额充值