首页 > 编程语言 >手机直播源码,使用ViewPager2实现页面滑动切换

手机直播源码,使用ViewPager2实现页面滑动切换

时间:2023-02-03 14:22:44浏览次数:49  
标签:content 源码 ViewPager2 滑动 android datas 页面

手机直播源码,使用ViewPager2实现页面滑动切换

1.引言

在很多应用中,我们经常会看到多个页面之间滑动切换的场景,ViewPager2是ViewPager的升级版,本文将简要介绍如何使用ViewPager2、FragmentStateAdapter和Fragment来实现页面之间的滑动切换。

 

2.实现页面滑动切换

2.1 引入ViewPager2库

要使用ViewPager2,需要引入ViewPager2库,引入方法如下:

 


implementation "androidx.viewpager2:viewpager2:1.0.0" 
 

2.2 使用ViewPager2

在布局中使用ViewPager2,示例如下:

 


<androidx.viewpager2.widget.ViewPager2
    android:id="@+id/viewPager2"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/> 
 

 

2.3 构建Fragment

本Fragment只为简单演示使用,其布局如下:

 


<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"
    android:gravity="center"
    android:orientation="vertical">
    <TextView
        android:id="@+id/tv_content"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="18sp"
        android:textColor="@color/black"/>
</LinearLayout> 
 

 

ContentFragment类的实现如下:

 


public class ContentFragment extends Fragment {
    private String content;
    public ContentFragment(String content) {
        this.content = content;
    }
    private TextView tv_content;
    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_content, container, false);
        tv_content = view.findViewById(R.id.tv_content);
        tv_content.setText(content);
        return view;
    }
    public void setContent(String content) {
        this.content = content;
        tv_content.setText(content);
    }

 

2.4 继承FragmentStateAdapter

创建自定义的类ContentPagerAdapter,让它继承FragmentStateAdapter,并实现createFragment(int position)和getItemCount()方法,示例如下:

 


public class ContentPagerAdapter extends FragmentStateAdapter {
    private List<ContentFragment> datas;
    public ContentPagerAdapter(@NonNull FragmentActivity fragmentActivity,List<ContentFragment> datas) {
        super(fragmentActivity);
        this.datas = datas;
    }
    @NonNull
    @Override
    public Fragment createFragment(int position) {
        return datas.get(position);
    }
    @Override
    public int getItemCount() {
        return datas.size();
    }

 

2.5 将ViewPager2与适配器绑定

将ViewPager2与适配器绑定后,便可实现页面滑动切换,示例如下:

 


datas = new ArrayList<>();
datas.add(new ContentFragment("页面1"));
datas.add(new ContentFragment("页面2"));
datas.add(new ContentFragment("页面3"));
datas.add(new ContentFragment("页面4"));
datas.add(new ContentFragment("页面5"));
contentPagerAdapter = new ContentPagerAdapter(this, datas);
viewPager2.setAdapter(contentPagerAdapter); 

 

2.6 垂直方向滑动切换

ViewPager2不仅支持水平方向的滑动,还支持垂直方向的滑动,实现垂直滑动也是相当简单,在布局文件中添加android:orientation="vertical"属性即可,如下所示:

 


<androidx.viewpager2.widget.ViewPager2
    android:id="@+id/viewPager2"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"/> 
 

 

或者在代码中调用ViewPager2的setOrientation(ViewPager2.ORIENTATION_VERTICAL)方法也可以让ViewPager2实现垂直方向的滑动。

 以上就是 手机直播源码,使用ViewPager2实现页面滑动切换,更多内容欢迎关注之后的文章

 

标签:content,源码,ViewPager2,滑动,android,datas,页面
From: https://www.cnblogs.com/yunbaomengnan/p/17089081.html

相关文章

  • Centos 7.9 源码编译安装nginx
    一、nginx简介  是一个高性能的HTTP和反向代理服务器,特点是占有内存少,并发能Nginx力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好Nginx专为性能......
  • 手撕fft系列之频移fftshift源码解析
    壹:fft在数字信号处理领域是一个神一样的存在。要好好熟悉一下。这里给出频移的算法源码解析。所谓的频移,就是把数字信号的频频顺序打乱,移动一些。这个在防止啸叫和......
  • 记一次在读Babel源码时遇到的闭包应用
    function_commander(){constdata=require("commander");_commander=function(){returndata;};returndata;}在函数里面对函数进行了重新赋......
  • layer.open type: 2, 关闭弹窗后无法刷新页面
     ajaxPostToast(_param,globe.baseApi.user_login,function(res){if(res.code===1){setStorage("userInfo",res.data.userinfo......
  • vue-cli以及element-ui国际化实战(待完善-切换时不刷新页面)
    步骤创建language文件夹在src同级的目录下新建language文件夹,新增三个文件,代码如下index.jsimportVuefrom'vue'importVueI18nfrom'vue-i18n'Vue.use(VueI1......
  • 基于nuxt ssr页面的监控数据
    页面方式1、ssr.enter:空白窗口打开页面(如浏览器打开:https://www.ctyun.cn/qzdh/b,在https://www.ctyun.cn/qzdh/点击链接选择在新窗口打开)2、ssr.forward:在已经打开的页面......
  • libxml2-master源码下载及编译
    libxml2源码下载地址https://gitlab.gnome.org/GNOME/libxml2/-/releasesCMake(mainlyforWindows)AnotheroptionforcompilinglibxmlisusingCMake:cmake-Et......
  • openjdk@15源码-01调试源码
    openjdk@15源码-调试源码在调试jdk源码过程中可能需要追踪c/cpp甚至汇编指令,方便起见新建项目不需要package路径0Git可以直接clone我自己的代码https://github.com/Ba......
  • 10、获取一个网页的源码
    #获取一个网页的源码https://www.baidu.com/s?wd=%E5%91%A8%E6%9D%B0%E4%BC%A6importurllib.requesturl='https://www.baidu.com/s?wd='#要将周杰伦变为Unicode......
  • 一文讲尽Thread类的源码精髓
    摘要:今天,我们就一起来简单看看Thread类的源码。本文分享自华为云社区《【高并发】Thread类的源码精髓》,作者:冰河。前言最近和一个朋友聊天,他跟我说起了他去XXX公司面试......