一、一般基本原则以及总结
1、xml布局中不要写死, 既单位不要用px。尽量用dp,或者match、warp
2、应该尽量把资源图片设计成能够拉伸的.9图,假设有渐变,尽量横向或竖向单方向渐变。这样能大大减小安装包大小,同一时候也能提高处理速度。
3、假设不想设计多套图片,那就设计最大的那套。压缩总比拉伸好,放在drawable-xhdpi这个目录。
4、写几套value值,相应不同分辨率。一套layout就可以。例如以下图所看到的。
5、建立多个layout目录,目录名称为layout-800x480等。须要适应那种分辨率就写成什么。(这样的方式太累了,还会导致应用大,不建议)
6、迫不得已要重写部分layout的xml。
layout-1024x768
layout-1024x600
layout-1280x768
layout-land-1024x720 //1024x768横屏
layout-port-976x768 //1024x768竖屏
注意格式,【layout】-【port/land】-【长度x宽度】
注意事项:
在android3.0后,要适配如上的分辨率,需将高度减去48像素,即底部状态栏的高度,android方可识别。
分辨率中大的数字必须写到前面,否则会产生语法错误。
7、
<supports-screens android:largeScreens="true" android:normalScreens="true" android:anyDensity = "true"/>android:anyDensity="true" 。这一句对整个的屏幕都起着十分关键的数据,值为true,我们的应用程序当安装在不同密度的手机上时,程序会分别载入hdpi,mdpi,ldpi文件 夹中的资源。
在</application>标签和</manifest> 标签之间加入上面那段代码。就可以
二、附上Android部分屏幕分辨率。像素知识。
低密度(120),ldpi
中密度(160),mdpi
高密度(240),hdpi
小屏幕
1、QVGA(240×320),2.6~3.0寸
普通屏幕
1、WQVGA(240×400)。3.2~3.5寸
2、FWQVGA(240×432),3.5~3.8寸
3、HVGA(320×480),3.0~3.5寸
4、WVGA(480×800),3.3~4.0寸
5、FWVGA(480×854),3.5~4.0寸
大屏幕
1、WVGA(480×800),4.8~5.5寸
2、FWVGA(480×854),5.0~5.8寸
屏幕尺寸分为:small,normal,large,xlarge分别表示小。中,大,超大屏
屏幕密度分为:ldpi,mdpi,hdpi,xhdpi,它们的标准值各自是:120dpi,160dpi,240dpi,320dpi
px(像素):屏幕上的点。
in(英寸):长度单位。
mm(毫米):长度单位。
pt(磅):1/72英寸。
dp(与密度无关的像素):一种基于屏幕密度的抽象单位。在每英寸160点的显示器上。1dp = 1px。
dip:与dp同样,多用于android/ophone演示样例中。
sp(与刻度无关的像素):与dp类似。可是能够依据用户的字体大小首选项进行缩放。
由此。依据 google 的建议,TextView 的字号最好使用 sp 做单位,并且查看TextView的源代码可知 Android 默认使用 sp 作为字号单位。
关于sp与dp的选择的建议是:
1、假设textview的显示区域能够弹性变化(wrap_content,当然其全部父view也须要能够弹性变化),这时能够优先考虑用sp,这时字体大小更改一般来说不会破坏界面的可用性
2、 与1情况相反时。textview的显示区域已经限定在一个固定值(或者其父view被限定了),这时优先考虑用dp吧,不然遇到一直使用着超大字体的用户。字体可能横向被截了,而用户不知情,会认为是程序问题。