Android实战经验分享之如何获取状态栏和导航栏的高度

本文首发于公众号"AntDream",欢迎微信搜索"AntDream"或扫描文章底部二维码关注,和我一起每天进步一点点

在 Android 应用开发中,有时我们需要知道状态栏和导航栏的高度,以便在布局中进行调整。获取这些高度的方法有几种,每种方法在准确性和兼容性方面有所不同。下面我们将详细介绍这几种方法,并提供 Kotlin 代码示例。

获取状态栏高度的方法

方法一:通过资源名称获取

这种方法最常见,也最推荐,具有较高的准确性和兼容性。

kotlin 复制代码
fun getStatusBarHeight(context: Context): Int {
    var result = 0
    val resourceId = context.resources.getIdentifier("status_bar_height", "dimen", "android")
    if (resourceId > 0) {
        result = context.resources.getDimensionPixelSize(resourceId)
    }
    return result
}

方法二:通过 WindowInsets 获取

这种方法需要 API 20 (Android 4.4W) 以上,但在较新版本的 Android(API 21及以上)中更为准确。

kotlin 复制代码
fun getStatusBarHeight(activity: Activity): Int {
    val windowInsets = activity.window.decorView.rootWindowInsets
    return windowInsets?.systemWindowInsetTop ?: 0
}

注意:在 Android 11(API 30)及以上版本可以使用 WindowInsetsCompat 进行更兼容性友好的操作。

kotlin 复制代码
import androidx.core.view.WindowInsetsCompat
import androidx.core.view.ViewCompat

fun getStatusBarHeight(activity: Activity): Int {
    val insets = ViewCompat.getRootWindowInsets(activity.window.decorView)
    return insets?.systemWindowInsetTop ?: 0
}

获取导航栏高度的方法

方法一:通过资源名称获取

这种方法和获取状态栏高度的方式类似。

kotlin 复制代码
fun getNavigationBarHeight(context: Context): Int {
    var result = 0
    val resourceId = context.resources.getIdentifier("navigation_bar_height", "dimen", "android")
    if (resourceId > 0) {
        result = context.resources.getDimensionPixelSize(resourceId)
    }
    return result
}

方法二:通过 WindowInsets 获取

这种方法也是较为现代的方式,但需要更高的 API 级别。

kotlin 复制代码
fun getNavigationBarHeight(activity: Activity): Int {
    val windowInsets = activity.window.decorView.rootWindowInsets
    return windowInsets?.systemWindowInsetBottom ?: 0
}

同样地,可以使用 WindowInsetsCompat 进行兼容性处理:

kotlin 复制代码
import androidx.core.view.WindowInsetsCompat
import androidx.core.view.ViewCompat

fun getNavigationBarHeight(activity: Activity): Int {
    val insets = ViewCompat.getRootWindowInsets(activity.window.decorView)
    return insets?.systemWindowInsetBottom ?: 0
}

对比和总结

1、 通过资源名称获取:

  • 优点:简单、代码兼容性好。
  • 缺点:可能受某些定制 ROM 的影响,准确性在极少数情况下可能有问题。

2、 通过 WindowInsets 获取:

  • 优点:在较新版本的 Android 上非常准确。
  • 缺点:需要较新的 API 级别,可能需要做额外的兼容性处理。

兼容性建议

  • 对于支持的最低 API 级别较低的应用,建议优先使用通过资源名称获取的方法,因为这种方法在大多数情况下效果良好。
  • 对于支持较高 API 级别的应用,可以考虑优先使用 WindowInsetsWindowInsetsCompat,以确保准确性。

欢迎关注我的公众号AntDream查看更多精彩文章!

相关推荐
RickeyBoy2 小时前
SwiftUI 如何实现 Infinite Scroll?
ios·面试
xiaoye37082 小时前
Java 自动装箱 / 拆箱 原理详解
java·开发语言
YDS8293 小时前
黑马点评 —— 分布式锁详解加源码剖析
java·spring boot·redis·分布式
迷藏4944 小时前
**发散创新:基于 Rust的开源权限管理系统设计与实战**在现代软件架构中,**权限控制**早已不
java·开发语言·rust·开源
升鲜宝供应链及收银系统源代码服务4 小时前
《IntelliJ + Claude Code + Gemini + ChatGPT 实战配置手册升鲜宝》
java·前端·数据库·chatgpt·供应链系统·生鲜配送
daidaidaiyu4 小时前
Nacos实例一则及其源码环境搭建
java·spring
冬奇Lab4 小时前
AudioRecord音频录制流程深度解析
android·音视频开发·源码阅读
小江的记录本4 小时前
【Redis】Redis全方位知识体系(附《Redis常用命令速查表(完整版)》)
java·数据库·redis·后端·python·spring·缓存
摇滚侠4 小时前
Java 项目《谷粒商城-1》架构师级Java 项目实战,对标阿里 P6-P7,全网最强,实操版本
java·开发语言
前端摸鱼匠5 小时前
【AI大模型春招面试题12】Scaling Laws揭示了模型性能、数据量、计算量之间的什么关系?
人工智能·ai·语言模型·面试·大模型