基于屏幕的图片尺寸的逻辑关系及移动界面的尺寸知识点【毅耘科技】
我知道这个题目念起来会让你觉得特别很是拗口,假如你是中文系卒业的,或许还能从中挑出语病来,但我想你晓畅我要表达什么意思,对舛错O(∩_∩)O哈哈~
要讲的东西其实都是很简单的逻辑关系,但可能许多人都跟我一样稀里糊涂的做了多年设计却一向没搞晓畅其中的关系。当然你不晓畅其中的关系并不影响你做出好的作品,但作为有理想有担当有着历史责任感…(此处省略一万字的排比)…的设计师,晓畅这些基本的知识点,能让你更好的…(想了下并没有什么现实益处(┬_┬)…)
====================华丽丽的分割线=========================
我们先来说说DPI和PPI之间的关系
DPI(每英寸/点)普遍运用于图像及印刷上,主要反应图像的邃密度。通过反向推算也可以计算图像的尺寸。
PPI(每英寸/像素点)是一种多用于屏幕分辨率的单位。本质上其实两者的概念应该是一样的,毕竟像素点也是点嘛。之前我一向很傻很无邪的认为基于屏幕的图像应该用PPI为精度单位,并且坚信电脑上显示的DPI是一种错误的透露表现体例。那其实是我的错误想法,不知道你是否有同样的想法?
讲完DPI和PPI,我们再来讲讲电脑分辨率、屏幕分辨率及印刷分辨率之间的关系
我们知道电脑分辨率是72DPI,而在上面我们讲了屏幕分辨率用PPI。显然这二者是有区别的,那么问题来了,他们区别在哪?
最初的PS是运行在苹果电脑上的,而那时候的苹果电脑的分辨率正好是72PPI(注重:这里用的是PPI)。为了能使图像的点与电脑屏幕上的像素点一一对应从而使图像在显示器上的尺寸和现实的物理尺寸相同,当初的PS把DPI设置成为了72。而这个设置就这样一向沿用了下来。
上面说到的苹果电脑的分辨率是72PPI就是屏幕分辨率。现在我们手上的屏幕种类繁多,各种尺寸各种分辨率。稍微计算一下
21.5寸的台式机的分辨率是√1920^2+1080^2/21.5≈102PPI
17寸笔记本的分辨率是√1366^2+768^2/17≈92PPI
屏幕分辨率的不同导致一个什么问题?——相统一张图片在不同显示器上呈现的大小及精度是不同的。屏幕的分辨率越高,图片显示越小精度越高。这点应该是比较好理解的…
既然现在的屏幕分辨率已经不适用于72PPI这一种分辨率了,电脑分辨率采用72DPI和屏幕分辨率之间还有什么联系吗?
答案是基本上没什么逻辑上的联系了。现在屏幕分辨率这么多,你基本上是无法要求有一个同一的DPI可以让印刷稿和你的屏幕保持一致的。当然,你可以把DPI设置成与你显示器PPI一样的数值,以此来保证你屏幕上的图像与印刷的图像保持相同的尺寸。但是即使是MacBook 的Retina屏幕的分辨率也达不到印刷要求的300DPI,所以这样设置的后果就是你的印刷品无法保持清晰度。
当然,以上这些都是基于印刷的理论。从基于屏幕为出发点的界面设计从印刷的角度来考虑物理尺寸显然是没有什么需要的。
我们回过头来再来说说电脑分辨率72DPI与印刷分辨率之间的关系,他们又有什么具体的现实关系呢?其实也没什么太多的关系。我们到现在唯一运用到的就是当图像的DPI为72时,图像的点即为图像的像素点。
这句话怎么理解?当我们用PS的外形工具绘制一个矩形并对其进行描边的时候会发现默认的3点(不是图层样式里的描边)。对,这里的点就是基于DPI而非像素点的,也就是说,当且仅当DPI为72时,这里的点等同于像素点。(记住这点很主要)
我们通常说的基于网络的图片分辨率设为72DPI就足够清晰了,这句话其实是不准确的。最简单的逻辑关系就是,当你把一张从网上下下来的图片调整它的分辨率但又保持它的像素分辨率的时候,你会发现图像自己是没有任何转变的。这是为什么?图像在屏幕上显示是基于像素分辨率一一对应原则的。也就是图像的一个像素对应显示器的一个像素,而这时候的图像分辨率是完全不起作用的,取而代之的是屏幕分辨率。
好了,我觉得关于这对虐心的三角恋关系我已近讲的够清楚了……接下来我们讲讲移动设备的一些尺寸关系。
====================华丽丽的分割线============================
DP到底是不是一个物理单位?
dp的本质是于像素密度无关的物理单位。好吧,我没能找到官方的诠释。但已我自己的经验感觉应该差不离是这么诠释的吧……
这种看似很明确的诠释其实让我们产生了不少歧义。
既然是一个物理单位,为什么不同尺寸的安卓手机使用的界面都是360DP这个单位呢?这显然不吻合逻辑嘛。4.3英寸的720P和5.7英寸的1080P你都用360DP来透露表现,这整整差了1.4英寸的物理单位,怎么就换了个单位就给同一起来了呢?!
Google把不同的安卓设备设想成了ldpi(120PPI)/mdpi(160PPI)/hdpi(240PPI)/xhdpi(320PPI)/xxhdpi(480PPI)/xxxhdpi(640PPI)等几种屏幕分辨率,而这几种分辨率以mdpi为基准构成0.75/1/1.5/2/3/4的比例关系。DP的长度公式为PD=PX/(PPI/160)。也就是我们所说的当设备的屏幕是mdpi时,DP=PX(注重:其实并不是所谓的当设备屏幕的分辨率为720*1280时)
但事实是作为开源软件,大家并不会按照你的要求来制造自己的设备。于是各种奇葩分辨率的设备应运而生……
魅族MX4-4.4英寸√800^2+1280^2/4.4≈343PPI
三星NOTE2-5.5英寸√720^2+1280^2/5.5≈267PPI
三星NOTE3-5.7英寸√1080^2+1920^2/5.7≈386PPI
几乎没有一款设备是在Google设置的那个档上的。那么唯一能做的就是归类了,用小于等于的体例来归类,既把小于或等于以上某类DPI的屏幕归档于其中。
比如上面的魅族MX4的323大于xhdpi小于xxhdpi(虽然它尺寸只有4.4,分辨率也没达到1080P,但它却是一款xxhdpi设备),它就被归档为xxhdpi了。以此类推,NOTE2为xhdpi,NOTE3为xxhdpi。
所以,其实我们在设计上在使用的DP不过是被归档后的一种近似取值罢了。这已经和定义上的物理尺寸产生了一定的差异。
================又是一条华丽丽的分割线======================
讲完这些看似高端烧脑子,然而却没什么现实用处的理论知识后,我们再来讲一些相对实用的东西。
许多人在讲设置画布的时候是设置360*640比较合适照旧720*1280会比较合适。我的建议是,现在的Android设备基本都是基于xxhdpi甚至xxxhdpi,部分老旧及低端设备还在用xhdpi,至于hdpi或更低的设备,基本已经可以摒弃考虑了。而介于360*640画布在电脑显示器上显示过小无法查看细节(在Retina上就更无法看了)这点,我建议大家把画布设置成720*11280,同时吧DPI设置成144。在PS首选项里把单位和标尺设置成以点为单位。假如我没记错,在PS CC版本里的预设值里就有这些选项,但到CC2014之后就没了。
为什么要设置144DPI呢?
当我们考虑手机界面设计时,我们的假定是所有的手机界面尺寸都是相同的,即使现实当中他们有着从4.4到5.7之间的差距,这些都是通过自适应来调整的。而唯一转变的就是屏幕的PPI,并且它们之间成倍率关系。在最上面我们将DPI和PPI时说道了电脑的分辨率是72DPI,当这个分辨率下的时候,此时你用外形工具的描边的时候1PT=1PX,而当像素分辨率达到720*1280时,为了让逻辑尺寸不变,需要将分辨率调整为72*2=144DPI。此时你用外形工具的描边的时候1PT=2PX(当然,同时也包含文字),保证了你的设计照旧以DP为单位调整,这也就是我们所说的在xxhdpi界面下,所有的像素都是偶数的。同时,当你需要调整切图大小时候只要讲DPI以72为基准进行缩放调整即可,xxxhdpi即为72*3=216DPI以此类推。
切图时候应该切哪些尺寸的图呢?
这个问题其实是比较多余的问题,上面都说了现在主流的就是xxdpi和xxxdpi,那就切这两套呗。
其实我想说的不是这点啦(┬_┬),Android将对应尺寸的图片放在对应的文件夹呢,xxxhdpi有对应的文件夹,当对应文件夹下没有资源时系统会主动调用下一级文件夹的资源来用,并且同时它会对资源进行缩放调整,但系统的缩放仅限于整数倍缩放。当你的切图只有xxhdpi时,xxxhdpi会把xxhdpi文件放大一倍来用,而这个时候这套图的基数倍率则变成了2*2=4倍,会使你的界面不但模糊,图片元素还会显得特殊大。除非你在mdpi中还有一套1倍率的图。
好吧,这条其实说了也没什么太多需要,你只要记住记得切一套xxxdpi图拉。
记得给你的720的版本的设计稿切一套1.5x版本的切图哦
================又是一条华丽丽的分割线===========================
好啦,今天要讲的就是这些了,不知道你看懂了没有。
需要强调的是以上的所有内容都是我在实战中累计和总结的经验。并没有过多的去考据过权威资料,假如其中有显明的错误,还望指正。
虽然都是些没什么现实作用的理论概念,但现实运用的知识都是构建在基础理论知识之上的,当你懂得了最基础的逻辑关系之后。以后界面之间的再复杂的关系,都能用这些基础知识来解开啦。(说的有点玄乎啦<( ̄▽ ̄)> 哇哈哈…)
原文来自:ui2702
本文标题:基于屏幕的图片尺寸的逻辑关系及移动界面的尺寸知识点
本文网址:http://www.yiyuncloud.com/index/index/news_detail/id/875.html
原创网址:合肥APP开发公司<毅耘科技> 版权所有,转载标明出去,并以链接形式链接网址:www.yiyuncloud.com
文章标签:合肥APP开发 合肥软件开发 合肥o2o社区 合肥商城开发 合肥B2B2C商城开发
毅耘科技(www.yiyuncloud.com)是一家拥有新型网站建设与程序开发经验的公司,致力于解决企业网络服务问题,紧跟着网络变化的步伐,为企业提供网络科技服务。平台服务:品牌网站建设 、网站开发、微信开发、APP开发、软件开发、网校系统开发、多用户商城开发、分销商城开发、微商城、一元云购系统开发、O2O系统开发、商标注册、网络营销等项目。是专业为企业提升价值的公司。