Android 屏幕适配的最优方案(一)

    • (1)屏幕尺寸
  • (2)屏幕分辨率

  • (3)屏幕的像素密度

  • (4)屏幕尺寸、分辨率、像素密度三者关系

  • 3.密度无关像素

    • (1)dp与px的转换
  • (2)独立比例像素

  • 4.解决方案

    • (1)使用备用布局 -使用限定符
  • (2)使用最小宽度限定符

  • (3)使用可用宽度限定符

  • (4)添加屏幕方向限定符

  • (5)使用 Fragment 将界面组件模块化

  • (6)使用旧尺寸限定符支持 Android 3.1

  • (7)使用布局别名


1.为什么要屏幕适配

=======================================================================

由于Android系统的开放性,任何用户、开发者、OEM厂商、运营商都可以对Android进行定制,于是导致运行 Android 的设备多种多样,它们有着不同的屏幕尺寸和像素密度。 尽管系统可通过基本的缩放和调整大小功能使界面适应不同屏幕,但您应做出进一步优化,以确保界面能够在各类屏幕上美观地呈现。

碎片化

2.首先我们要搞清楚,几个比较重要的概念。

==================================================================================

(1)屏幕尺寸


屏幕尺寸指屏幕的对角线的长度,单位是英寸,1英寸=2.54厘米

比如常见的屏幕尺寸有2.4、2.8、3.5、3.7、4.2、5.0、5.5、6.0等

(2)屏幕分辨率


屏幕分辨率是指在横纵向上的像素点数,单位是px,1px=1个像素点。一般以纵向像素*横向像素,如1960*1080。表示宽度方向上有1080个像素点,在高度方向上有1920个像素点

1.单位:px(pixel),1px=1像素点

2.Android手机常见的分辨率:320x480、480x800、720x1280、1080x1920

3.UI设计师的设计图会以px作为统一的计量单位

(3)屏幕的像素密度


屏幕像素密度是指每英寸上的像素点数,单位是dpi,即“dot per inch”的缩写。屏幕像素密度与屏幕尺寸和屏幕分辨率有关,在单一变化条件下,屏幕尺寸越小、分辨率越高,像素密度越大,反之越小。

假设设备内每英寸有160个像素,那么该设备的屏幕像素密度=160dpi。安卓手机对于每类手机屏幕大小都有一个相应的屏幕像素密度。

| 密度类型 | 代表的分辨率(px) | 屏幕像素密度(dpi) |

| — | :-: | --: |

| 低密度(ldpi) | 240x320 | 120 |

| 中密度(mdpi) | 320x480 | 160 |

| 高密度(hdpi) | 480x800 | 240 |

| 超高密度(xhdpi) | 720x1280 | 320 |

| 超超高密度(xxhdpi) | 1080x1920 | 480 |

(4)屏幕尺寸、分辨率、像素密度三者关系


一部手机的分辨率是宽x高,屏幕大小是以寸为单位,那么三者的关系是:

关系

3.密度无关像素

=====================================================================

density-independent pixel,叫dp或dip,与终端上的实际物理像素点无关。可以保证在不同屏幕像素密度的设备上显示相同的效果。

1.Android开发时用dp而不是px单位设置图片大小,是Android特有的单位

2.场景:假如同样都是画一条长度是屏幕一半的线,如果使用px作为计量单位,那么在480x800分辨率手机上设置应为240px;在320x480的手机上应设置为160px,二者设置就不同了;如果使用dp为单位,在这两种分辨率下,160dp都显示为屏幕一半的长度。

(1)dp与px的转换


px = dp * (dpi / 160)

| 密度类型 | 代表的分辨率(px) | 屏幕密度(dpi) | 换算(px/dp) | 比例 |

| — | :-: | --: | --: | --: |

| 低密度(ldpi) | 240x320 | 120 | 1dp=0.75px | 3 |

| 中密度(mdpi) | 320x480 | 160 | 1dp=1px | 4 |

| 高密度(hdpi) | 480x800 | 240 | 1dp=1.5px | 6 |

| 超高密度(xhdpi) | 720x1280 | 320 | 1dp=2px | 8 |

| 超超高密度(xxhdpi) | 1080x1920 | 480 | 1dp=3px | 12 |

在Android中,规定以160dpi(即屏幕分辨率为320x480)为基准:1dp=1px

(2)独立比例像素


sp,即scale-independent pixels,与dp类似,但是可以根据文字大小首选项进行放缩,是设置字体大小的御用单位。

4.解决方案

===================================================================

(1)使用备用布局 -使用限定符


  • 尺寸(size)限定符

  • 使用最小宽(Smallest-width)度限定符

  • 布局别名

  • 屏幕方向(Orientation)限定符

(2)使用最小宽度限定符


使用“最小宽度”屏幕尺寸限定符,您可以为具有最小宽度(以dp 或 dip 为度量单位)的屏幕提供备用布局。

通过将屏幕尺寸描述为密度无关像素的度量值,Android 允许您创建专为非常具体的屏幕尺寸而设计的布局,同时让您不必对不同的像素密度有任何担心。

例如,您可以创建一个名为 main_activity 且针对手机和平板电脑进行了优化的布局,方法是在目录中创建该文件的不同版本,如下所示:

res/layout/main_activity.xml # For handsets (smaller than 600dp available width)

res/layout-sw600dp/main_activity.xml # For 7” tablets (600dp wide and bigger)

最小宽度限定符指定屏幕两侧的最小尺寸,而不考虑设备当前的屏幕方向,因此这是一种指定布局可用的整体屏幕尺寸的简单方法。

下面是其他最小宽度值与典型屏幕尺寸的对应关系:

  • 320dp:典型手机屏幕(240x320 ldpi、320x480 mdpi、480x800 hdpi 等)。

  • 480dp:约为 5 英寸的大手机屏幕 (480x800 mdpi)。

  • 600dp:7 英寸平板电脑 (600x1024 mdpi)。

  • 720dp:10 英寸平板电脑(720x1280 mdpi、800x1280 mdpi 等)。

下图提供了一个更详细的视图,说明了不同屏幕 dp 宽度与不同屏幕尺寸和方向的一般对应关系。

对应关系上图建议的宽度断点以支持不同的屏幕尺寸。

请记住,最小宽度限定符的所有数值都是密度无关像素,因为重要的是系统考虑像素密度(而不是原始像素分辨率)之后可用的屏幕空间量。

**注意:**您使用这些限定符指定的尺寸不是实际屏幕尺寸,而是 Activity 窗口可用的宽度或高度(以 dp为单位)。Android 系统可能会将部分屏幕用于系统界面(如屏幕底部的系统栏或顶部的状态栏),因此部分屏幕可能不可供您的布局使用。如果您的应用在多窗口模式下使用,则它只能使用该窗口的尺寸。对该窗口进行大小调整时,它会使用新窗口尺寸触发配置更改,以便系统可以选择适当的布局文件。因此,在声明尺寸时,您应具体说明 Activity 需要的尺寸。在声明为布局提供的空间时,系统会考虑系统界面使用的所有空间。

(3)使用可用宽度限定符


您可能希望根据当前可用的宽度或高度来更改布局,而不是根据屏幕的最小宽度来更改布局。例如,如

果您有一个双窗格布局,您可能希望在屏幕宽度至少为 600dp 时使用该布局,但屏幕宽度可能会根据设备的屏幕方向是横向还是纵向而发生变化。在这种情况下,您应使用“可用宽度”限定符,如下所示:

res/layout/main_activity.xml # For handsets (smaller than 600dp available width)

res/layout-w600dp/main_activity.xml # For 7” tablets or any screen with 600dp # available width (possibly landscape handsets)

如果您关心可用高度,则可以使用“可用高度”限定符来执行相同的操作。例如,对于屏幕高度至少为600dp 的屏幕,请使用限定符 layout-h600dp 。

(4)添加屏幕方向限定符


虽然您可能只需将“最小宽度”和“可用宽度”限定符结合使用即可支持所有尺寸变化,但是您可能还希望当用户在纵向与横向之间切换屏幕方向时改变用户体验。

为此,您可以将 port 或 land 限定符添加到资源目录名称中。只需确保这些限定符在其他尺寸限定符后面即可。例如:

最后:学习总结——Android框架体系架构知识脑图(纯手绘xmind文档)

学完之后,若是想验收效果如何,其实最好的方法就是可自己去总结一下。比如我就会在学习完一个东西之后自己去手绘一份xmind文件的知识梳理大纲脑图,这样也可方便后续的复习,且都是自己的理解,相信随便瞟几眼就能迅速过完整个知识,脑补回来。

下方即为我手绘的Android框架体系架构知识脑图,由于是xmind文件,不好上传,所以小编将其以图片形式导出来传在此处,细节方面不是特别清晰。但可给感兴趣的朋友提供完整的Android框架体系架构知识脑图原件(包括上方的面试解析xmind文档)

除此之外,前文所提及的Alibaba珍藏版 Android框架体系架构 手写文档以及一本 《大话数据结构》 书籍等等相关的学习笔记文档,也皆可分享给认可的朋友!

——感谢大家伙的认可支持,请注意:点赞+点赞+点赞!!!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
给感兴趣的朋友提供完整的Android框架体系架构知识脑图原件(包括上方的面试解析xmind文档)
[外链图片转存中…(img-Usl7BVXA-1714682914375)]

除此之外,前文所提及的Alibaba珍藏版 Android框架体系架构 手写文档以及一本 《大话数据结构》 书籍等等相关的学习笔记文档,也皆可分享给认可的朋友!

——感谢大家伙的认可支持,请注意:点赞+点赞+点赞!!!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 22
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值