业界动态
Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好小尺寸手机「Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好」
2025-04-24 22:16

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_限定符

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_限定符_02

屏幕分辨率越大,手机越清晰

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_Android 手机屏幕尺寸dp_03

 

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_android_04

 

dpi就是dot per inch dot意思是点,就是每英寸上面的像素点数

 

android原始的api返回的单位都是px,获得屏幕的宽度高度返回的单位都是px,ui设计师在设计图片的时候的单位一般也是px作为单位

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_xml_05

我们在xml布局的时候,android推荐我们使用dp作为单位,最后不要直接使用px作为单位

我们来看下面的一个案例

列如,我们要实现这样的一个需求,画一条直接填充整个屏幕的宽度

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_限定符_06

 

如果使用xml布局使用px作为单位,第一个屏幕需要320px,第二个屏幕需要480px。这也就是说使用px作为单位,并不能保证在不同的屏幕分辨率、不同的屏幕像素密度不同的dpi下面保存相同的显示效果。

使用dp单位就可以,我们来在160dpi下面,1dp=1px,上面320px,对应的dp就是320dp,第二个手机像素密度是240dpi,如果设置320dp,转换成像素就是320*(240/160)=480px

这样就保证了同一条直接在不同的手机屏幕上都具有填充满整个屏幕的效果

 

换算的单位是:

据px = dip * density / 160,则当屏幕密度为160时,px = dip

 

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_xml_07

 

和上面的填充屏幕宽度一样,推荐使用sp作为文字的大小,sp能够依据屏幕的不同的分辨率进行缩放达到屏幕适配的效果。

不同屏幕像素密度的区分,为啥android需要对不同的像素密度进行区分了,这主要也是为了屏幕的适配,因为同一张图片在不同的像素密度下显示的效果是不一样的,为了保证不同的设备具有相同的显示效果,我们需要为不同的设备提供不同尺寸的图片,就能够大体的满足屏幕的适配,我们在新建项目的时候,开发工具会自动创建下面的文件夹,程序员需要把当前手机对应像素密度的图片放在对应的文件夹下面,当程序运行的时候,系统会按照当前手机的dpi到对应的文件夹下面去加载对应的图片,drawable文件夹是为了解决不同的dpi手机上图片具有相同的显示效果。

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_xml_08

工程的value文件夹是为了保证相同的效果,在不同的dpi的手机密度下显示不同的dimen的值

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_Android 手机屏幕尺寸dp_09

 

 

例如为了达到同样的显示效果,在低dpi下面的间隔就会小一点,在高dpi下面的间隔就会大一点,我们就可以在不同的修饰符限定的value文件夹下面

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_Android 手机屏幕尺寸dp_10

设置不同的dimen的值,但是不同的value下面的name值是一样的,例如上面的不同的value下面name都是login_photo_top只是不同的value下面的值是不一样的。

这样程序在运行的时候会依据当前手机的dpi自动去获得对应限定符下面的value下的值。

ldpi: 屏幕密度为120的手机设备

mdpi: 屏幕密度为160的手机设备(此为baseline,其他均以此为基准,在此设备上,1dp = 1px)

hdpi: 屏幕密度为240的手机设备

xhdpi: 屏幕密度为320的手机设备

xxhdpi:屏幕密度为480的手机设备

 

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_限定符_11

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_android_12

例如当前的首先是440dpi就会对应的drawable--xxhdpi下面的文件去找对应的图片,到对应的value下面找对应的值。

依据dip(dp)单位根据公式像素值 = [dip*(dpi/160)](px)(其中px是单位)转化为屏幕像素。根据此公式可以计算出一个dip分别在120dpi、160dpi、240dpi、320dpi屏幕中对应的像素数分别为0.75、1、1.5、2.0,比例为3:4:6:8,如下图。因此,在不同屏幕密度上,以mdpi作为基准,对位图进行3:4:6:8比例的放缩会达到适配的效果。

例如:在mdpi上面设计师给了一个ui的设计图

比如:现在有一个手机是中等密度的屏幕(160dpi),在mdpi下放置了一个48*48px的图片,要满足图片在不同分辨率的适配性,应该遵循3:4:6:8:12:16的原则。

 

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_限定符_13

 

 

那么在ldpi下应该放置36*36px的图片(12*3

在hdpi文件下就应该放置72*72的图片(12*4


在xhdpi下就应该放置96*96的图片(12*6


在xxhdpi下就应该放置144*144的图片(12*8


上面官方文档有问题,180*180应该是144*144 (12*12


通过上面的大概比例的设置,我们就知道大体需要的图片了。

所以一个设计师给了一个在160dpi下面是48*48的图片,适配不同的手机的dpi,程序员需就需要叫设计师给出在xxhdpi下面是144*144px的图片,我们只需要按照这个宽和高就行比较就可以了,就能够大体满足在不同的手机上面图片具有相同的显示效果。

不同的屏幕密度使用不同的图片

由于Android设备的屏幕密度是各种各样的,您应该为不同密度的屏幕提供不同的图片资源,这样在各种像素密度的屏幕上都能获得最好的图形质量和性能。

在原有矢量图的基础上按照如下的缩放比例来分别生成不同屏幕密度的图片资源:

  • xhdpi: 2.0
  • hdpi: 1.5
  • mdpi: 1.0 (baseline)
  • ldpi: 0.75

这意味着对于xhdpi 的设备需要使用200×200的图片;对于hdpi的设备只需要 150×150 的图片;而对于mdpi的设备需要 100×100 的图片; 对于ldpi 的设备只需要75×75 的图片。

把这些图片放到位于res/目录下对于的图片目录中:

然后,当您使用@drawable/awesomeimage的时候, 系统会根据当前设备的屏幕密度为您选择最优的图片。

我们可以通过以下几种方式来支持各种屏幕尺寸:

wrap_content:根据控件的内容设置控件的尺寸
math_parent:根据父控件的尺寸大小设置控件的尺寸
weight:权重,在线性布局中可以使用weight属性设置控件所占的比例

例如,我们要实现下图所显示的效果:当屏幕尺寸改变时,new reader控件两边的控件大小不变,new reader控件会占完剩余的空间。

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_限定符_15

线性布局中使用weight属性

小插曲:关于属性

公式:所占宽度=原来宽度+剩余空间所占百分比的宽度

一般情况,我们都是设置要进行比例分配的方向的宽度为0dp,然后再用权重进行分配。如下:

效果为:

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_限定符_16

 

然后我们修改布局文件后

 

 

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_Android 手机屏幕尺寸dp_17

 

我们来分析下:

屏幕的宽度是L

剩余空间所占百分比的宽度:现在按钮1的宽度是L,按钮2的宽度是L,剩余空间就是屏幕的宽度减去按钮1和按钮2所占的宽度,L-2L

宽度为match_parent时,所占比例

button1宽度=L+(L-2L)×1/3=2/3L
button2宽度=L+(L-2L)×2/3=1/3L

简单的布局一般都使用,而略微复杂点的布局,我们使用,大多数时候,我们都是使用这两种布局的嵌套。

我们使用的原因是,能在各种尺寸的屏幕上保持控件间的相对位置。

案例如下:

Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好_xml_18

完成界面的适配

 

  • 使用尺寸限定符
    当我们要在大屏幕上显示不同的布局,就要使用限定符。例如,在宽的屏幕左边显示列表右边显示列表项的详细信息,在一般宽度的屏幕只显示列表,不显示列表项的详细信息,我们就可以使用限定符。

  单面板:

 双面板:

如果这个程序运行在屏幕尺寸大于7inch的设备上,系统就会加载 而不是,在小于7inch的设备上就会加载。

需要注意的是,这种通过限定符分辨屏幕尺寸的方法,适用于android3.2之前。在android3.2之后,为了更精确地分辨屏幕尺寸大小,Google推出了最小宽度限定符。

最小宽度限定符的使用和基本一致,只是使用了具体的宽度限定。
,单面板(默认)布局:

,双面板布局: Small Width 最小宽度

 Small Width 最小宽度这里不限定是横屏、还是纵屏的宽度,只要宽度的最小值大于600dp,就加载双面板的布局

这种最小宽度限定符适用于android3.2之后,所以如果要适配android全部的版本,就要使用限定符和文件同时存在于项目目录下。

这就要求我们维护两个相同功能的文件。为了避免繁琐操作,我们就要使用布局别名。

使用布局别名
: 单面板布局
: 多面板布局(支持3.2版本之前的平板设备)
: 多面板布局(支持3.2版本之后的平板设备)

l

由于后两个文具文件一样,我们可以用以下两个文件代替上面三个布局文件:

 单面板布局
 双面板布局

然后在下建立


三个文件。

默认布局
:

Android3.2之前的平板布局
:

Android3.2之后的平板布局
:

这样就有了为别名的布局。
在activity中

这样,程序在运行时,就会检测手机的屏幕大小,如果是平板设备就会加载,如果是手机设备,就会加载 。我们就解决了只使用一个布局文件来适配android3.2前后的所有平板设备。

注意几点:values-sw600dp和values-large下面的名字不一定都命名成layout.xml只要xml里面的内容都写成一致的就可以了。

使用屏幕方向限定符

如果我们要求给横屏、竖屏显示的布局不一样。就可以使用来实现。
例如,要在平板上实现横竖屏显示不用的布局,可以用以下方式实现。
:横屏

:竖屏

    以上就是本篇文章【Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好小尺寸手机「Android 手机屏幕尺寸dp 手机屏幕dpi大好还是小好」】的全部内容了,欢迎阅览 ! 文章地址:http://fabua.ksxb.net/news/10267.html 
     文章      相关文章      动态      同类文章      热门文章      栏目首页      网站地图      返回首页 海之东岸资讯移动站 http://fabua.ksxb.net/mobile/ , 查看更多   
最新文章
明确0到2级辅助驾驶系统 “人机共驾”法律属性
公安部交通管理局局长王强7月23日在国新办举行的“高质量完成‘十四五’规划”系列主题新闻发布会上表示,为进一步加强规范管理
iPhone 17系列价格曝光:仅一款不涨价 Pro版更具性价比
【TechWeb】近段时间以来,全新iPhone 17系列尤为吸引外界的目光,而根据供应链最新爆料,iPhone 17系列距离亮相仅剩差不多一个
管庄回收茅台酒!管庄茅台酒回收!
137=1888=0048 回收茅台礼盒15年 30年 50年 80年茅台礼盒回收洋酒系列 回收路易十三,轩尼诗,拉菲,拉图,马爹利,人头马
北京到陶乐物流专线价格,货到付款
长胜物流24 小时服/务热线:||长途搬家|家电托运|电脑托运|液晶电视托运|冰箱托运|洗衣机托运|行李托运|电动车托运|摩托车托运|
解读Solana最新技术路线图:锚定“互联网资本市场”,打造链上华尔街
昨天 Solana 宣布了新的路线图。本质上,由于各链改进都已进入深水区,导致确实有些名词堆砌的情况,我试着用大家可以理解的方式
国泰海通发布新一代全AI智能APP灵犀
央广网北京7月26日消息(记者樊瑞)当前,人工智能技术正加速重构证券行业服务业态,加快发展新一代人工智能是推动证券行业高质
新加坡地道特色平价美食,好吃不踩雷
新加坡太多美食了~亚坤-咖椰吐司$5左右,这是我在新加坡吃的第一顿早餐。不知道好不好吃,但看着一大早就好多人排队,那就没错
上海UPS蓄电池回收
上海UPS回收,UPS电源回收,UPS电池回收:上海APC不间断电源回收,UPS主机回收,机房设备回收,回收UPS设备,UPS蓄电池回收,UPS
云边端协同:虚拟电厂的“神经网”革命
上海某高校586台空调在50秒内无感降负300kW,精度96.57%;重庆虚拟电厂调度17MW可调资源,延迟压缩至100ms级——这组数据的背后
高金食品与远方好物达成战略合作,让高品质“真黑猪”走进千家万户的餐桌
中国黑猪看四川,四川黑猪看高金。高金食品正用“真黑猪”,破局本土黑猪市场占有率困境,开创中国黑猪产业新篇章。7月23日,在