Android dp、dpi、px的区别

目录

Android dp、dpi、px的区别_第1张图片


一、基本概念

1.1  dpi

dpi是dot per inch,每英寸多少点,ppi是 Pixel per inch,每英寸像素数,针对显示器的设计时,dpi=ppi。ppi计算方法是长宽各自平方之和开方,除以对角线长度(单位英寸)。

ppi表示显示设备的点密度,dpi表示印刷品点密度。

1.2  dip或dp

安卓开发用的单位,官方规定:1dp表示在屏幕点密度为160ppi时1px长度。因为安卓设备屏幕众多不可能为每个屏幕单独开发,所以用公式 px=dp*(ppi/160)计算在不同屏幕上的像素数。1dp=1dip ,为了与字体的sp统一。

要理解DP是物理尺寸是不会变的(就像是英寸、厘米这些),在不同屏幕密度下,1dp的物理长度也相同。

1.3  px

像素的大小是没有固定长度的,不同设备上一个单位像素色块的大小是不一样的。
例如,尺寸面积大小相同的两块屏幕,分辨率大小可以是不一样的,分辨率高的屏幕上面像素点(色块)就多,所以屏幕内可以展示的画面就更细致,单个色块面积更小。而分辨率低的屏幕上像素点(色块)更少,单个像素面积更大,可以显示的画面就没那么细致。

作为图像构成的基本单元,单个像素的大小并不固定,跟随屏幕大小和像素数量的关系变化(屏幕越大,像素越低,单个像素越大,反之亦然)。所以在使用像素作为设计单位时,在不同的设备上可能会有缩放或拉伸的情况。

1.4  density  

density 在每个设备上都是固定的,DPI / 160 = density屏幕的总 px 宽度 / density = 屏幕的总 dp 宽度(自己理解1dp中包含像素的个数)

二、详细说明

1.1  dpi

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

Android dp、dpi、px的区别_第2张图片

 

举个例子:屏幕分辨率为:1920*1080,屏幕尺寸为5吋的话,那么dpi为440。

Android dp、dpi、px的区别_第3张图片

1.2  dip或dp

引用一张图

Android dp、dpi、px的区别_第4张图片

图中我们清晰看到,如何通过px、inch、dpi来获取dp。再次强调,dp是物理尺寸,是不会变的。Android 官方规定,当设备的dpi为160dpi时,1dp=1px的。比如:将一个控件设置长度为1dp,那么在160dpi上该控件长度为1px,在240dpi的屏幕上该控件的长度为1*240/160=1.5个像素点。(或者我们可以理解,当设备dpi为160dpi时,即每英寸有160个像素,可以理解1dp=1/160inch物理尺寸。)

1.3  px

px和dp之间的关系。android中的dp在渲染前会将dp转为px,计算公式:

  • px = density * dp;

  • density = dpi / 160;

  • px = dp * (dpi / 160);

1.4  density

根据上面density 的概念,屏幕的总 px 宽度 / density = 屏幕的总 dp 宽度我们来看一个例子:

  • 设备 1,屏幕宽度为 1080px480DPI,屏幕总 dp 宽度为 1080 / (480 / 160) = 360dp

  • 设备 2,屏幕宽度为 1440560DPI,屏幕总 dp 宽度为 1440 / (560 / 160) = 411dp

可以看到屏幕的总 dp 宽度在不同的设备上是会变化的,但是我们在布局中填写的 dp 值却是固定不变的。

三、深入理解

1.1  px、dp、density 、dpi之间的关系


 

Android dp、dpi、px的区别_第5张图片

液晶屏显示图像,放大来看是一个个小点组成的,这些小点就是像素点(px)。

有的手机屏幕小像素点少,比如HTC G11的4寸480x800屏幕,还有的屏幕大像素点多,比如三星note2的5.5寸720x1280屏幕。

Android dp、dpi、px的区别_第6张图片

这个图标在不同的手机屏幕上显示出来,就是上图的效果。可以想象一下我们不同的手机打开同一个应用,按钮的尺寸相差很大。

图片显示大小是由什么决定的呢,屏幕尺寸?上图第1和第2个屏都是4.3英寸。像素数?第2和第3个屏都是720x1280的像素。最后我们找到了点密度(density),也就是像素数和屏幕尺寸的比值。density是每单位长度容纳的像素数量,一般用像素/英寸,也就是Pixel per inch(ppi)。

屏幕的尺寸是屏幕对角线的长度,计算对角线像素数量再除以屏幕尺寸就得到了ppi值。上面3个屏的点密度分别是217ppi,342ppi,267ppi。

对比上图可以知道,ppi越低图片显示的越大,ppi越高图片显示的越小。

要让不同屏幕显示图片的大小相同,就需要对图片进行缩放,给高ppi屏提供更大的图片。

Android dp、dpi、px的区别_第7张图片

高ppi屏幕需要更大的图片才能得到同样的显示效果,反之亦然。ppi和图片px的关系如下

px1/px2=ppi1/ppi2

选定一个ppi值作为基础绘制图片,用ppi的比值计算出图片缩放比例就可以适配各种屏幕

px2=px1*(ppi2/ppi1)

安卓选定的这个基础值就是160ppi

px2=px1*(ppi2/160)

我们已经解决了图片放大缩小的问题,还需要一个单位用来描述长度(因为px不固定,inch不方便)。安卓创造了一个新的单位dp,中文名设备独立像素。并且规定在160ppi的屏幕上,1dp=1px。

设计师只需要针对160ppi的显示屏设计并制图,安卓会根据当前手机屏幕的ppi值来放大缩小图片,在不同的屏幕上得到相近的显示效果。

Android dp、dpi、px的区别_第8张图片

引用:

https://www.zhihu.com/question/21220154

https://www.cnblogs.com/JLZT1223/p/6784449.html

https://www.jianshu.com/p/55e0fca23b4f

 

 

 

你可能感兴趣的:(Android屏幕适配)