ndroid平板多屏幕适配
这几天做关于平板的项目,发现用之前的多屏幕适配方案,会直接运行闪退,报的错误是找不到指定的资源,克服了懒惰的心,翻墙查了api文档。找到了问题。记录下来。
Android多屏幕适配-手机
http://blog.csdn.net/qq_27570955/article/details/53207600
如何划分手机和平板
人为判断方法:大于6英寸的就是平板。小于6英寸的都是手机。
平板尺寸:6英寸、7英寸、10英寸、14英寸...
note:6英寸是手机和平板的阀值。但是还没有找到系统是根据什么来判断是手机还是平板。待验证。欢迎提供证据。
ps1:有人说根据
来判断是否是平板。查看源码,Configuration.SCREENLAYOUT_SIZE_LARGE 的值至少是 480x640dp,即 sw480dp。而 sw480dp 是中间平板电脑。例如 Streak 480x800mdpi。这个点来看,这个公式是成立的。但是使用该方法的准确性有待验证。因为 5英寸 的手机和 7英寸 的平板都在 Configuration.SCREENLAYOUT_SIZE_LARGE 范围内。
平板-tablet
Android 手机系统是 2.x,4.x,5.x 等,但是 Android 系统的 Tablet 设备是从3.0开始的,且3.x系统只有平板才有。Android3.0是专门为平板服务的系统。但是从4.0以后,看起来能运行于手机的也同样能运行于平板。但是,如果使用手机适配的方法用于平板是不可行的。通过查询Google文档可知,Android 平板的适配要使用限定符 swxxxdp。
原因:手机屏幕的适配是根据资源限定符 value-mdpi-xxx 或者 value-ldpi-xxx。在 values 文件夹下的 dimens 文件里没有默认值也没有关系,系统会最匹配原则。但是Tablet设备资源查找的限定符不是 mdpi、ldmpi 这样的限定符。而是 swxxxdp 限定符查找。所以如果使用手机屏幕适配的方法来适配,系统不认识 mdpi 文件夹下的尺寸,会去找 values 文件夹下的 dimens 文件里的尺寸。没有找到 swxxxdp 也没有找到默认尺寸,就会报资源找不到异常。
平板-Tablet适配原则-最小宽度限定符
对于 Android3.0 的平板,声明平板 Tablet 的正确方式是将资源放在有 xlarge 配置限定符的目录,本质上是使用屏幕尺寸限定符,例如 res/layout-xlarge/。为适应多屏幕尺寸,Android3.2 引入了更具体的屏幕尺寸指定资源的方式。
设备 Tablet 在3.0系统时可以使用屏幕限定符 small、normal、large、xlarge 等命名备用资源,从3.2以后,Tablet使用新的限定符 smallestWidth,限定符值为 sw<n>dp。
选择一个宽度并将其设计为最小尺寸(基本上这个最小宽度要跟ui沟通好,可用ui的设计基准作为最小宽度),或者在布局设计玩完成后测试其支持的最小宽度。
sw<n>dp:最小宽度限定符。例如:(取两个尺寸的最短者)
- 设备1024x480mdpi=sw480dp
- 设备1024x600mdpi=sw600dp
- 设备480x600mdpi =sw480dp
- 设备480x640mdpi=sw480dp
- 设备2560x1440mdpi=sw1440dp
Tablet设备常见的屏幕宽度值:
sw320dp:常见手机屏幕。(240x320ldpi、320x480mdpi、480x800hdpi等)
计算过程:480x800hdpi 的最小宽度是 480hdpi,换算成 dp 就是 480hdpi*0.75=320dp。同理,240x320ldpi 最小宽度是 240ldpi,换算成 dp 单位 240ldpi/0.75=320dp。
mdpi 是基准,1mdpi=1dp;1ldpi=0.75dp;1hdpi=1.5dp;1xhdpi=2dp;1xxhdpi=3dp;1xxxhdpi=4dp。对这个公式不熟的看前一篇Android多屏幕适配-手机
sw480dp:中间平板电脑,例如Streak(480x800mdpi)
sw600dp:7英寸平板电脑(600x1024mdpi)
sw720dp:10英寸平板电脑(720x1280mdpi、800x1280mdpi等)
总结:平板的适配基准 sw480dp、sw600dp、sw720d p等,手机屏幕的适配基准是 mdpi、hdpi、xhdpi 等。
注意:这里的单位必须是 dp 单位。资源使用“最小宽度限定符” sw<N>dp 用于指定屏幕两边的最小值,而不管设备当前的方向如何。因此使用 sw<N>dp 是指定 布局可用于整体屏幕尺寸的简便方法,它会忽略屏幕的方向。ps:当横竖屏切换时,width 和 height 值也会交换。
声明尺寸支持
在清单文件 AndroidManifest 中可以通过声明来说明当前应用支持哪些屏幕。如果应用支持Android支持的所有屏幕尺寸(最小屏幕尺寸是 426dpx320dp),则不需要此步骤。
Android 3.2 为 <supports-screens> 清单元素引入了新的属性:
android:requiresSmallestWidthDp:指定应用只用于最小宽度值。设定此值之后,只有设备的 smallestWidth 必须大于等于此值,才能使用该应用。
例如:如果应用只用于最小可用宽度为 600dp 的平板电脑样式设备,则在清单文件中声明如下:
设置了该属性之后,如果设备是 1024x720mdpi 的可以下载此应用,因为 1024x720mdpi 的最小屏幕宽度是 720mdpi,但是应用在清单文件中设置的是 600dp。720mdpi>600dp
如果设备是 1024x720hdpi 的就不能能下载此应用,因为 1024x720hdpi 的最小屏幕宽度是 720hdpi*1.5=480dp。sw480dp<600dp。以此类推。
用户设备的两个尺寸(widthxheight)的最小值必须大于等于 android:requiresSmallestWidthDp 值才能下载,但不影响设备运行。
注意:此值目前设置无效。因为此值的设置并不影响系统运行,而是在应用商店上过滤应用。所以,如果想要使应用不支持小屏幕,就要使用其他的尺寸属性,而不应该使用该属性。因为不起效果。
android:compatibleWidthLimitDp:指定应用支持的最大“最小宽度”,将屏幕兼容性模式用作用户可选的功能。如果设备可用屏幕的最小边大于您在这里的值, 用户仍可安装您的应用,但提议在屏幕兼容性模式下运行。默认情况下,屏幕兼容性模式会停用,并且您的布局照例会调整大小以 适应屏幕,但按钮会显示在系统栏中,可让用户打开和关闭屏幕兼容性模式。
例如:如果在清单文件中设置该属性的值为 600,则如果用户的设备是 1024x720mdpi=sw720dp,则用户可以仍可以安装.
注意:如果应用可针对大屏幕正确调整大小,则无需使用此属性。建议不要使用此属性,而是按照建议,确保应用的布局针对较大屏幕调整大小。
android:largestWidthLimitDp:此属性可指定应用支持的最大“最小宽度”来 强制启用屏幕兼容性模式。如果设备可用屏幕的最小边大于该值,应用将在屏幕兼容模式下运行,且用户无法停用该模式。
注意:建议不要使用此属性来针对多屏幕适配。
使用示例
该方法基于Android多屏幕适配-手机思想
ui 基准是 1024x552mdpi。则屏幕宽度值的基准设置为 sw552dp 或 sw600dp.
对于不同的屏幕密度的设置如下:
1024x552mdpi=sw552dp 或者 sw600dp 或者 sw600dp-1024x552
1024x552hdpi=sw828dp 或者 sw828dp-1024x552
以此类推,保证 sw限定符 的单位是 dp 即可。
以 1024x552mdpi 基准举例,适配 1200x400hdpi,资源应该是 sw600dp-1200x400
注意:屏幕 1024x552mdpi 和 1200x400hdpi,都可以使用同一个 sw600dp 资源。
注意:最好要在 values 下的 dimens 设置默认值。
参考资料:
Google官方文档
https://developer.android.com/guide/practices/screens_support.html