当前位置: 首页 > news >正文

Bitmap -> Bitmap安卓设备上的显示和内存

Android 屏幕显示与 Bitmap 内存详解

前言

Android 开发中,理解屏幕显示单位和 Bitmap 内存占用是构建高效应用的基础。本文将详细介绍相关概念、计算公式及单位转换,并通过实例分析 Bitmap 在内存中的表现。

一、屏幕显示单位基础

1.1 基本单位及概念

  • px 手机屏幕分辨率的基本单位,与物理像素一一对应
  • dp 密度无关像素,1dp = (屏幕密度/160)px,用于保证不同屏幕密度下视图尺寸的一致性
  • sp 可缩放像素,主要用于字体大小,会随系统字体大小设置变化
  • dpi 屏幕密度,每英寸包含的像素点数,密度越大,每英寸内容纳的点数就越多
  • ppi 每英寸像素数,由屏幕分辨率和物理尺寸计算得出的近似值

1.2 Android 密度等级

密度等级密度值(dpi)比例对应系数资源目录
ldpi1200.75x0.75drawable-ldpi
mdpi1601x1.0drawable-mdpi
hdpi2401.5x1.5drawable-hdpi
xhdpi3202x2.0drawable-xhdpi
xxhdpi4803x3.0drawable-xhdpi
xxxhdpi6404x4.0drawable-xxhdpi

二、屏幕单位计算公式与转换

2.1 基本计算公式

  • pxdp 的转换:
px = dp × (dpi ÷ 160)
dp = px × (160 ÷ dpi)
  • pxsp 的转换:
px = sp × (dpi ÷ 160) × fontScale
sp = px ÷ ((dpi ÷ 160) × fontScale)
  • ImageView 实际像素计算:
    实际像素宽/高 = XML中设置的dp值 × (inTargetDensity ÷ 160)
  • Bitmap 尺寸计算:
    加载后的Bitmap宽/高 = 原始宽/高 × (inTargetDensity ÷ inDensity)

2.2 单位转换工具

object DisplayUtils {/*** dp转px*/fun dp2px(context: Context, dpValue: Float): Int {val scale = context.resources.displayMetrics.densityreturn (dpValue * scale + 0.5f).toInt()}/*** px转dp*/fun px2dp(context: Context, pxValue: Float): Int {val scale = context.resources.displayMetrics.densityreturn (pxValue / scale + 0.5f).toInt()}/*** sp转px*/fun sp2px(context: Context, spValue: Float): Int {val fontScale = context.resources.displayMetrics.scaledDensityreturn (spValue * fontScale + 0.5f).toInt()}/*** px转sp*/fun px2sp(context: Context, pxValue: Float): Int {val fontScale = context.resources.displayMetrics.scaledDensityreturn (pxValue / fontScale + 0.5f).toInt()}/*** 获取屏幕宽度(px)*/fun getScreenWidth(context: Context): Int {return context.resources.displayMetrics.widthPixels}/*** 获取屏幕高度(px)*/fun getScreenHeight(context: Context): Int {return context.resources.displayMetrics.heightPixels}/*** 获取状态栏高度*/fun getStatusBarHeight(context: Context): Int {val resourceId = context.resources.getIdentifier("status_bar_height", "dimen", "android")return if (resourceId > 0) {context.resources.getDimensionPixelSize(resourceId)} else {0}}
}

2.3 获取设备显示信息

fun getDisplayMetricsInfo(context: Context): String {val dm = context.resources.displayMetricsreturn """屏幕宽度(px): ${dm.widthPixels}屏幕高度(px): ${dm.heightPixels}屏幕密度(density): ${dm.density}屏幕密度DPI: ${dm.densityDpi}X轴DPI: ${dm.xdpi}Y轴DPI: ${dm.ydpi}字体缩放因子: ${dm.scaledDensity}屏幕宽度(dp): ${dm.widthPixels / dm.density}屏幕高度(dp): ${dm.heightPixels / dm.density}""".trimIndent()
}

三、Bitmap 内存计算与管理

3.1 Bitmap 内存计算公式

Bitmap 在内存中的占用大小计算公式:

内存大小(字节) = 宽度(像素) × 高度(像素) × 每像素字节数

每像素字节数由 Bitmap.Config 决定:

配置类型每像素字节数说明
ALPHA_81仅存储透明度
RGB_5652无透明度通道
ARGB_88884默认配置,最高质量
RGBA_F168高精度浮点配置

3.2 Bitmap 内存大小:未压缩的原始像素数据大小

  • 以一张 1920×1080 分辨率的图片为例:
    • 内存占用 (ARGB_8888)1920 × 1080 × 4 = 8,294,400 字节 ≈ 7.91 MB

3.3 不同单位的内存大小表示

fun calculateBitmapMemorySize(bitmap: Bitmap): String {val bytes = bitmap.byteCountval kb = bytes / 1024.0val mb = kb / 1024.0return """内存占用(Bytes): $bytes bytes内存占用(KB): ${String.format("%.2f", kb)} KB内存占用(MB): ${String.format("%.2f", mb)} MB""".trimIndent()
}
http://www.lryc.cn/news/546726.html

相关文章:

  • QT study DAY2
  • QT-自定义参数设计框架软件
  • VUE集成Live2d
  • 【CPP面经】科大讯飞 腾讯后端开发面经分享
  • el-card 结合 el-descriptions 作为信息展示
  • GaussDB自带诊断工具实战指南
  • LeetCode 链表章节
  • SSL证书和HTTPS:全面解析它们的功能与重要性
  • 正交投影与内积空间:机器学习的几何基础
  • Qt中txt文件输出为PDF格式
  • 《HelloGitHub》第 107 期
  • Langchain解锁LLM大语言模型的结构化输出能力(多种实现方案)
  • AI数据分析:deepseek生成SQL
  • 力扣-动态规划-115 不同子序列
  • Qt C++ 开发 动态上下页按钮实现
  • 数据结构第五节:排序
  • 从文件到块: 提高 Hugging Face 存储效率
  • Android14 串口控制是能wifi adb实现简介
  • vue3中 组合式~测试深入组件:事件 与 $emit()
  • SQL-labs13-16闯关记录
  • 基于微信小程序的停车场管理系统的设计与实现
  • DAIR-V2X-R数据集服务器下载
  • table 拖拽移动
  • Linux使用笔记:Find Tree 命令
  • 数据结构入门篇——什么是数据结构。
  • MySQL-简介与基本命令
  • 汽车材料耐候性测试仪器-太阳光模拟器介绍
  • 音频3A测试--AEC(回声消除)测试
  • DeepSeek 助力 Vue3 开发:打造丝滑的弹性布局(Flexbox)
  • 六、Redis 高级功能详解:BitMap、HyperLogLog、Geo、Stream