屏幕适配需要知道的一些知识

屏幕尺寸相关的知识

  1. 相关名词释义

    • 屏幕尺寸 :
      • 手机对角线的物理尺寸,单位:英寸(inch), 1 inch = 2.54 cm,常见手机尺寸有5寸,6寸等
    • 屏幕分辨率
      • 手机在横向和纵向上的像素点总数,常见手机分辨率 1080X1920,720X1280
    • 屏幕像素密度
      • 每英寸区域包含的像素点数 dpi (dots per inch) , dpi = √(宽度²+ 高度²)/屏幕尺寸
    • density:
      • density = dpi/160,px = density*dp
  2. 屏幕适配

    1. dp的局限,dp的适配,是基于dpi换算出来的最终px的占比不同分辨率基本一致

      720 X 1280 - dpi 320, 1dp = 320/160 = 2px

      1080 X 1920 - dpi 480, 1dp = 480/160 = 3px

      这样,dp在不同分辨率上占据的px百分比是一致的,

      如果dpi不是按照等比例的设置,或者相同分辨率有不同的dpi,那么就会出现差异,适配失败 !!!

    2. 宽高限定符,暴力全匹配,局限很明显

      设定一个基本分辨率,其他分辨率都按照这个基准进行换算,例如基准是360*480,宽度分成360份,高度分成480分,截图只设定了宽度的适配,高度也是一样的!,代码里面直接使用x16来使用

      这个方案有一个致命的缺陷,分辨率必须要百分百匹配上可以,否侧只能匹配到默认的values/dimens.xml,这样就有可能造成很大的误差!!!

      宽高限定符.png

    3. 最小宽度限定符values-sw<N>dp,宽高限定符的升级版本

      最小宽度,是因为屏幕可以旋转,宽高会互换,这个方案是不区分屏幕方向的,所以取宽高之中的最小值作为匹配值,如果想随着屏幕变化,可以使用values-w<N>dp,想区分屏幕还可以带上-land或者-port

      最小宽度的计算: 1080X1920, 480dpi,

      最小宽度 1080px ---- 1080/(480/160) = 360dp 匹配360dp的资源

      类似宽高限定符,也是将屏幕划分成360份,1份 = 1dp

      匹配规则

      如果某个设备没有为它提供对应的 values-sw<N>dp,那它就会去寻找相近的 *values-sw<N>dp,但如果这个相近的与期望的差距太大,就会达不到适配效果

      sw限定.png

    4. 今日头条方案,另辟蹊径,既然一切的源头都是density,那就动态调整这个值

      我们假设,手机的屏幕宽度=设计图的宽度,反推出density,已知屏幕宽度dp = density * 屏幕宽度dp,可以计算出density = px/dp,然后通过api设置到系统,替换到系统原本计算的denstiy的方法

      例如设计图720dp,屏幕720px, density = 1 ,屏幕1280pxdensity = 1.77

      view宽度设置为120dp ,720px的屏幕实际占据 ---> 120px,1280px的屏幕实际占据----> 213,占据的百分比是一样的!120/720 == 213/1280)

      可能会影响第三方框架的view的显示

参考链接

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,029评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,395评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,570评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,535评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,650评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,850评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,006评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,747评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,207评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,536评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,683评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,342评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,964评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,772评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,004评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,401评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,566评论 2 349

推荐阅读更多精彩内容