支持各种屏幕密度
来源:互联网 发布:男士胸包品牌 知乎 编辑:程序博客网 时间:2024/06/11 18:23
熊猫猫韩国代购
支持各种屏幕密度
本教程将向您介绍如何通过提供不同资源和使用独立于分辨率的测量单位来支持不同屏幕密度。
使用非密度制约像素
在设计布局时,大家经常会误使用绝对像素来定义距离或尺寸,您一定要避免犯这种错误。由于各种屏幕的像素密度都有所不同,因此相同数量的像素在不同设备上的实际大小也有所差异,这样使用像素定义布局尺寸就会产生问题。因此,请务必使用 dp 或 sp 单位指定尺寸。dp 是一种非密度制约像素,其尺寸与 160 dpi 像素的实际尺寸相同。sp 也是一种基本单位,但它可根据用户的偏好文字大小进行调整(即尺度独立性像素),因此您应将该测量单位用于定义文字大小(请勿用其定义布局尺寸)。
例如,请使用 dp(而非 px)指定两个视图间的间距:
1234
<Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/clickme" android:layout_marginTop="20dp" />
请务必使用 sp 指定文字大小:
123
<TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:textSize="20sp" />
提供备用位
由于 Android 可在具有各种屏幕密度的设备上运行,因此您提供的位图资源应始终可以满足各类普遍密度范围的要求:低密度、中等密度、高密度以及超高密度。这将有助于您的图形在所有屏幕密度上都能得到出色的质量和效果。
要生成这些图片,您应先提取矢量格式的原始资源,然后根据以下尺寸范围针对各密度生成相应的图片。
- xhdpi:2.0
- hdpi:1.5
- mdpi:1.0(最低要求)
- ldpi:0.75 也就是说,如果您为 xhdpi 设备生成了 200x200 尺寸的图片,就应该使用同一资源为 hdpi、mdpi 和 ldpi 设备分别生成 150x150、100x100 和 75x75 尺寸的图片。
然后,将生成的图片文件放在 res/ 下的相应子目录中(如下所示),系统就会根据运行您应用的设备的屏幕密度自动选择合适的图片:
1 2 3 4 5 6 7 8 910
MyProject/ res/ drawable-xhdpi/ awesomeimage.png drawable-hdpi/ awesomeimage.png drawable-mdpi/ awesomeimage.png drawable-ldpi/ awesomeimage.png
这样一来,无论您何时引用 @drawable/awesomeimage,系统都能根据相应屏幕的 dpi 选取合适的位图。
- 支持各种屏幕密度
- 支持各种屏幕密度
- 解决方案-支持各种屏幕密度
- Supporting Different Densities 支持各种屏幕密度
- Android屏幕适配之支持各种屏幕密度(三)
- Android应用开发之(支持各种密度的屏幕)
- Android 针对多种屏幕进行设计 (二)支持各种屏幕密度
- android各种分辨率和屏幕密度
- Android Developers:支持不同的屏幕密度
- Android Developers:支持不同的屏幕密度
- android-支持多种屏幕[密度独立性] 三
- 支持各种屏幕尺寸
- 支持各种屏幕尺寸
- Android支持多屏幕尺寸和多屏幕密度
- 屏幕密度
- 屏幕密度
- 支持各种尺寸的屏幕
- 支持各种尺寸的屏幕
- Js获取当前日期时间及其它操作
- 我的博客今天0岁1天了,我领取了新…
- java反射详解
- ASP.NET数据库连接字符串总结
- 用JS弹出“有输入框并带有是、否、…
- 支持各种屏幕密度
- javascript编辑器
- 按钮只能点击一次,点击过后立即失…
- 关于CPU的Cache
- 7种JS脚本分页代码
- Heap And Stack -- Part1
- js动态显示时间 时分秒设置为红色
- 单击文字后可经进行编辑的JS特效
- 双击文字出现编辑文本框的JS代码