Kotlin高效实现 Android ViewPager2 顶部导航:动态配置与性能优化指南

  1. 高效实现:强调代码的性能优化。
  2. Android ViewPager2:明确技术栈。
  3. 顶部导航:核心功能点。
  4. 动态配置与性能优化指南:突出动态配置的灵活性和性能优化的重点。

在 Android 开发中,使用 ViewPager2 实现高效的顶部导航(通常结合 TabLayout)是一种常见的需求。以下是优化后的实现方案,确保代码高效、简洁且易于维护。


优化目标

  1. 高效加载:利用 FragmentStateAdapter 的特性,避免不必要的 Fragment 实例化。
  2. 动态配置:通过数据驱动的方式动态配置 TabLayoutViewPager2
  3. 代码简洁:使用 Kotlin 的特性和扩展函数减少冗余代码。
  4. 可扩展性:方便添加或删除页面,无需修改核心逻辑。

实现步骤

1. 添加依赖

确保在 build.gradle 中添加 ViewPager2Material Design 依赖:

dependencies {implementation 'androidx.viewpager2:viewpager2:1.0.0'implementation 'com.google.android.material:material:1.4.0'
}

2. 定义页面数据

使用 sealed classdata class 定义页面信息,包括标题、图标和对应的 Fragment

// Page.kt
sealed class Page(val title: String, val icon: Int) {object Home : Page("Home", R.drawable.ic_home)object Dashboard : Page("Dashboard", R.drawable.ic_dashboard)object Notifications : Page("Notifications", R.drawable.ic_notifications)companion object {val pages = listOf(Home, Dashboard, Notifications)}
}

3. 创建 Fragment

为每个页面创建对应的 Fragment

// Fragment1.kt
class Fragment1 : Fragment() {override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,savedInstanceState: Bundle?): View? {return inflater.inflate(R.layout.fragment_1, container, false)}
}// Fragment2.kt
class Fragment2 : Fragment() {override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,savedInstanceState: Bundle?): View? {return inflater.inflate(R.layout.fragment_2, container, false)}
}// Fragment3.kt
class Fragment3 : Fragment() {override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,savedInstanceState: Bundle?): View? {return inflater.inflate(R.layout.fragment_3, container, false)}
}

4. 创建适配器

使用 FragmentStateAdapter 动态加载 Fragment

class ViewPagerAdapter(fragmentActivity: FragmentActivity) : FragmentStateAdapter(fragmentActivity) {override fun getItemCount(): Int = Page.pages.sizeoverride fun createFragment(position: Int): Fragment {return when (Page.pages[position]) {is Page.Home -> Fragment1()is Page.Dashboard -> Fragment2()is Page.Notifications -> Fragment3()}}
}

5. 设置 ViewPager2 和 TabLayout

MainActivity 中设置 ViewPager2TabLayout 的联动。

class MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)val viewPager = findViewById<ViewPager2>(R.id.viewPager)val tabLayout = findViewById<TabLayout>(R.id.tabLayout)// 设置 ViewPager2 适配器viewPager.adapter = ViewPagerAdapter(this)// 将 TabLayout 与 ViewPager2 联动TabLayoutMediator(tabLayout, viewPager) { tab, position ->tab.text = Page.pages[position].titletab.icon = ContextCompat.getDrawable(this, Page.pages[position].icon)}.attach()}
}

6. 布局文件

activity_main.xml 中定义布局,包含 TabLayoutViewPager2

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><!-- 顶部导航 --><com.google.android.material.tabs.TabLayoutandroid:id="@+id/tabLayout"android:layout_width="match_parent"android:layout_height="wrap_content"app:tabMode="fixed"app:tabGravity="fill"/><!-- ViewPager2 --><androidx.viewpager2.widget.ViewPager2android:id="@+id/viewPager"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"/></LinearLayout>

7. 扩展函数:简化 TabLayout 配置

如果需要频繁配置 TabLayout,可以将其封装为扩展函数。

// TabLayoutExtensions.kt
fun TabLayout.setupWithViewPager(viewPager: ViewPager2, pages: List<Page>) {TabLayoutMediator(this, viewPager) { tab, position ->tab.text = pages[position].titletab.icon = ContextCompat.getDrawable(context, pages[position].icon)}.attach()
}

MainActivity 中使用:

tabLayout.setupWithViewPager(viewPager, Page.pages)

优化后的优势

  1. 高效加载FragmentStateAdapter 确保 Fragment 实例的高效管理。
  2. 动态配置:通过 Page.pages 动态配置页面,避免硬编码。
  3. 代码简洁:扩展函数和 Kotlin 特性使代码更加简洁。
  4. 可扩展性:添加新页面只需在 Page 中添加一个新对象,无需修改核心逻辑。

示例:添加新页面

如果需要添加一个新页面,只需在 Page 中添加一个新对象:

object Profile : Page("Profile", R.drawable.ic_profile)

然后在 ViewPagerAdapter 中处理新页面:

override fun createFragment(position: Int): Fragment {return when (Page.pages[position]) {is Page.Home -> Fragment1()is Page.Dashboard -> Fragment2()is Page.Notifications -> Fragment3()is Page.Profile -> Fragment4() // 新增页面}
}

其他代码无需修改,系统会自动同步 TabLayout


总结

通过以上优化,ViewPager2 实现顶部导航的代码变得更加高效、简洁和易于维护。sealed class 和扩展函数的使用使代码更具可读性和可扩展性,同时避免了硬编码和重复逻辑。运行优化后的代码,你将获得一个高效的顶部导航实现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/33044.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深度学习优化-Gradient Checkpointing

数学原理参考&#xff1a; 梯度检查点技术&#xff08;Gradient Checkpointing&#xff09;详细介绍&#xff1a;中英双语-CSDN博客 视频讲解参考&#xff1a; 用梯度检查点来节省显存 gradient checkpointing_哔哩哔哩_bilibili Gradient Checkpointing&#xff08;梯度检查…

sql靶场-时间盲注(第九、十关)保姆级教程

目录 时间盲注&#xff08;第九、十关&#xff09; 1.判断 2.确认时间盲注 2.手工尝试时间盲注 数据库名长度 数据库名字符 表数 表名长度 表名字符 字段数 字段名长度 字段名字符 4.脚本时间盲注注入 5.第十关 时间盲注&#xff08;第九、十关&#xff09; 1.判…

小米路由器SSH下安装DDNS-GO

文章目录 前言一、下载&#xff06;安装DDNS-GO二、配置ddns-go设置开机启动 前言 什么是DDNS&#xff1f; DDNS&#xff08;Dynamic Domain Name Server&#xff09;是动态域名服务的缩写。 目前路由器拨号上网获得的多半都是动态IP&#xff0c;DDNS可以将路由器变化的外网I…

Flutter_学习记录_device_info_plus 插件获取设备信息

引入三方库device_info_plus导入头文件 import package:device_info_plus/device_info_plus.dart;获取设备信息的主要代码 DeviceInfoPlugin deviceInfoPlugin DeviceInfoPlugin(); BaseDeviceInfo deviceInfo await deviceInfoPlugin.deviceInfo;完整案例 import package…

【现代深度学习技术】卷积神经网络05:汇聚层

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈PyTorch深度学习 ⌋ ⌋ ⌋ 深度学习 (DL, Deep Learning) 特指基于深层神经网络模型和方法的机器学习。它是在统计机器学习、人工神经网络等算法模型基础上&#xff0c;结合当代大数据和大算力的发展而发展出来的。深度学习最重…

Amazon RDS ProxySQL 探索(一)

:::info &#x1f4a1; 在日常开发中&#xff0c;开发者们会涉及到数据库的连接&#xff0c;在使用Amazon RDS数据库时&#xff0c;若使用集群模式或者多数据库时&#xff0c;会出现一写多读多个Endpoint&#xff0c;在实际开发中&#xff0c; 开发者们配置数据库连接通常希望走…

Appium高级操作--ActionChains类、Toast元素识别、Hybrid App操作、手机系统API的操作

书接上回Appium高级操作--从源码角度解析--模拟复杂手势操作-CSDN博客文章浏览阅读712次&#xff0c;点赞24次&#xff0c;收藏6次。下面总结Appium模拟复杂手势整体流程创建类实例action时&#xff0c;一定要传入WebDriver实例参数&#xff0c;创建实例成功后&#xff0c;调用…

媲美Deepseek R1 671B的千问QwQ32B本地部署与远程访问实测流程

文章目录 前言1. 环境准备2.QwQ 32B模型安装与运行测试3. 安装Open WebUI图形化界面3.1 安装Open WebUI3.2 添加QWQ32B模型 4. 安装内网穿透工具5. 配置固定公网地址总结 前言 近日&#xff0c;阿里千问发布了最新推理模型QwQ32B &#xff01;并表示“它只有 320亿参数&#x…

SpringBoot整合RabbitMq

1.引入依赖 <!--RabbitMq相关--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId> </dependency>2.application.yml文件配置 spring:rabbitmq:host: 192.168.101.129…

2024年第十五届蓝桥杯软件C/C++大学A组——五子棋对弈

蓝桥杯原题&#xff1a; 题目描述&#xff1a; “在五子棋的对弈中&#xff0c;友谊的小船说翻就翻&#xff1f; ” 不&#xff01;对小蓝和小桥来说&#xff0c;五子棋不仅是棋盘上的较量&#xff0c;更是心与心之间的沟通。这两位挚友秉承着 “ 友谊第一&#xff0c;比赛第二…

PyQt基础——简单的图形化界面(窗口)

一、代码展示 import sysfrom PyQt6.QtGui import QPixmap from PyQt6.QtWidgets import QWidget, QApplication, QLabel, QLineEdit, QPushButton from PyQt6 import uic from PyQt6.QtCore import Qt# 封装一个我的窗口类 class MyWidget(QWidget):def __init__(self):supe…

大语言模型-1.2-大模型技术基础

简介 本博客内容是《大语言模型》一书的读书笔记&#xff0c;该书是中国人民大学高瓴人工智能学院赵鑫教授团队出品&#xff0c;覆盖大语言模型训练与使用的全流程&#xff0c;从预训练到微调与对齐&#xff0c;从使用技术到评测应用&#xff0c;帮助学员全面掌握大语言模型的…

【MATLAB例程】AOA(到达角度)法,多个目标定位算法,三维空间、锚点数量自适应(附完整代码)

给出AOA方法下的多目标定位,适用三维空间,锚点数量>3即可,可自定义目标和锚点的数量、坐标等。 文章目录 运行结果源代码代码讲解概述功能代码结构运行结果 10个锚点、4个目标的情况: 100个锚点、10个目标的情况: 修改方便,只需调节下面的两个数字即可: 源代码 …

[CVE-2017-10271]Weblogic--WLS Security反序列化漏洞复现

文章目录 靶机地址靶机说明开启并访问靶机POCexp反弹shell后续查找flag过程略 靶机地址 网站地址 cyberstrikelab.com 靶机地址CVE-2017-10271 靶机说明 Weblogic的WLS Security组件对外提供webservice服务&#xff0c;其中使用了XMLDecoder来解析用户传入的XML数据&#xf…

如何在vscode中编译linux中的c++文件

方式一 在终端打开进行连接编译 指令含义&#xff1a;将 muduo_server.cpp 源文件编译成一个可执行文件 server&#xff0c;并且在链接过程中使用 muduo_net、muduo_base 库以及 pthread 库 方式二 在vscode中修改配置文件 按F1打开配置文件搜索栏&#xff0c;输入C/C 打开…

Unity中刚体撞墙抖动的原因和本质

当我们制作角色移动的时候我们都知道使用设置位置的方法来移动一个带有刚体和碰撞体的物体&#xff0c;遇到碰撞体的时候就会抖动。 上网查找原因&#xff0c;都说是和物理系统冲突导致的&#xff0c;然后再也找不到其他线索。 这个说法&#xff0c;对&#xff0c;但它并不是最…

文件解析漏洞靶场通关合集

一、IIS解析漏洞 &#xff08;一&#xff09;iis6的目录解析漏洞(.asp目录中的所有文件都会被当做asp文件执行) 第一步&#xff1a;在网站根目录下创建了一个x.asp文件夹&#xff0c;并在文件夹中创建一个名为1.txt的文本文档 第二步&#xff1a;文本文档中输入<% now()%&…

【Linux】浅谈冯诺依曼和进程

一、冯诺依曼体系结构 冯诺依曼由 输入设备、输出设备、运算器、控制器、存储器 五部分组成。 冯诺依曼的设计特点 二进制表示 所有数据&#xff08;包括程序指令&#xff09;均以二进制形式存储和运算&#xff0c;简化了硬件逻辑设计&#xff0c;提高了可靠性。 存储程序原理…

技术聚焦:Debezium 如何将数据库数据精准注入 Kafka

#作者&#xff1a;任少近 文章目录 第一章 Debezium抽取mysql数据给kafka原理第二章 Debezium 与kafka抽取方法及验证2.1 debezium2.0kafka3.3.1mysql82.2 debezium2.0kafka2.6.1mysql82.3 debezium2.0kafka2.6.1mysql5.7 第一章 Debezium抽取mysql数据给kafka原理 debezium的…

SpringBoot学生宿舍管理系统的设计与开发

项目概述 幽络源分享的《SpringBoot学生宿舍管理系统的设计与开发》是一款专为校园宿舍管理设计的智能化系统&#xff0c;基于SpringBoot框架开发&#xff0c;功能全面&#xff0c;操作便捷。该系统涵盖管理员、宿管员和学生三大角色&#xff0c;分别提供宿舍管理、学生信息管…