//原来写在其他博客上的东西,搬迁
预备知识:
  • 要明确的三个概念
    • 设计分辨率:在编辑器上开发UI使用的分辨率。我们所有的UI都是在这个分辨率下设计制作的。
    • 显示区域分辨率:设备上所显示的UI区域在编辑器中的分辨率。
    • 屏幕分辨率:设备实际的分辨率。
  • 已知设计分辨率,屏幕分辨率,区域分辨率的计算方法
    • 设置变量
      • 设计分辨率 ContentWidth * ContentHeight,以下简写为 CW * CH
      • 屏幕分辨率 width * height,以下简写 W * H
      • 区域分辨率 TargetWidth * TargetHeight,以下简写 TW * TH (这两个是未知量)
      • 所求区域分辨率用 Target 表示
    • 求解
      • 模式一:保持各个UI在屏幕中所占的百分比(保持宽高比)

不留黑边

留黑边

CW / CH < W / H

CW / TH = W / H

Target = CW * TH

TW / CH = W / H

Target = TW * CH

CW / CH > W / H

TW / CH = W / H

Target = TW * CH

CW / TH = W / H

Target = CW * TH

黄色的公式:以宽度为基准自适应 (所用公式记为:公式一)

绿色的公式:以高度为基准自适应 (所用公式记为:公式二)

  • 模式二:保持各个UI的像素大小不变(保持宽高比)
Target = W * H
  • 模式三:保证UI元素在单方向上的比例不变,即自由拉伸(保持宽高比)
Target = CW * CH(此时 CW 和 CH 是随着屏幕分辨率变化的)

UIRoot

  • Flexible 即,上文所说的模式二。但有个地方要额外注意下:
    • 这种模式下有两个参数,MinHeight 和 MaxHeight。
    • 当屏幕分辨率在 MinHeight 和 MaxHeight 之间时,此时按照模式二正常显示;
    • 当屏幕分辨率小于 MinHeight 或者大于 MaxHeight 时,会对整体UI进行缩放,缩放比例为(H / MinHeight) 或者(H / MaxHeight)
  • Constrained 即, 上文所说的模式一。
    • 这种模式下有四个参数,ContentWidth 与 ContentHeight 以及对应的 Fit
    • ContentWidth 与 ContentHeight 填我们的设计分辨率
    • Fit 有四种选择模式,不同的模式有不同的自适应方案。为了便于理解,从NGUI网站上找到了一张示意图&自己总结了一下计算所需的公式:

  

Fit Width

No

Yes

No

Yes

Fit Height

No

No

Yes

Yes

显示&对应计算公式

保证设备不显示黑边

保证左右无黑边

(公式一)

保证上下无黑边

(公式二)

保证设计分辨率内所有UI全部显示

    • 额外的计算:计算某个UI(比如图片)在设备上的分辨率
      • 图片分辨率大小 PW * PH
      • 图片在设备上显示的分辨率大小 TPW * TPH(未知量)
      • 计算:需要一个方程组
        • (PW * PH) / (TW * TH) = (TPW * TPH) / (W * H)
        • PW / PH = TPW / TPH

NGUI之UIRoot——屏幕的自适应分辨率的计算的更多相关文章

  1. NGUI之UIRoot屏幕分辨率自适应

    NGUI在Unity3D游戏开发中非常常用,而NGUI对于每一个UI场景,都是以一个UIRoot为UI游戏对象树的根的,那么这个UIRoot是起什么作用的呢? 先简单看一下UIRoot中的基本属性 U ...

  2. Unity3D开发(一):NGUI之UIRoot屏幕分辨率自适应

    原地址:http://blog.csdn.net/onerain88/article/details/11713299 NGUI在Unity3D游戏开发中非常常用,而NGUI对于每一个UI场景,都是以 ...

  3. iosiPhone屏幕尺寸、分辨率及适配

    iosiPhone屏幕尺寸.分辨率及适配     1.iPhone尺寸规格 设备 iPhone 宽 Width 高 Height 对角线 Diagonal 逻辑分辨率(point) Scale Fac ...

  4. iPhone屏幕尺寸、分辨率及适配

    转:http://blog.csdn.net/phunxm/article/details/42174937 目录(?)[+]   1.iPhone尺寸规格 设备 iPhone 宽 Width 高 H ...

  5. 【转】iPhone屏幕尺寸、分辨率及适配

    原文网址:http://blog.csdn.net/phunxm/article/details/42174937 1.iPhone尺寸规格 设备 iPhone 宽 Width 高 Height 对角 ...

  6. iPhone手机的屏幕尺寸、分辨率及适配

    1.iPhone尺寸规格 设备 iPhone 宽 Width 高 Height 对角线 Diagonal 逻辑分辨率(point) Scale Factor 设备分辨率(pixel) PPI 3GS ...

  7. CSS 屏幕大小自适应

    要想实现css屏幕大小自适应,首先得引入 CSS3 @media 媒体查询器: media的使用和规则: ①被链接文档将显示在什么设备上. ②用于为不同的媒介类型规定不同的样式. 语法:  @medi ...

  8. android webview使用心得 屏幕宽度自适应

    webview中右下角的缩放按钮能不能去掉 settings.setDisplayZoomControls(false); //隐藏webview缩放按钮 让Webview加载的页面居中显示有我知道的 ...

  9. WinForm窗体自适应分辨率

    我们自己编写程序的界面,会遇到各种屏幕分辨率,只有自适应才能显的美观.实际上,做到这点也很简单,就是首先记录窗体和它上面控件的初始位置和大小,当窗体改变比例时,其控件的位置和大小也按此比例变化即可.因 ...

随机推荐

  1. Redis 3.0.5 集群的命令、使用、维护

    cluster命令 CLUSTER INFO 打印集群的信息 CLUSTER NODES 列出集群当前已知的所有节点(node),以及这些节点的相关信息. //节点 CLUSTER MEET < ...

  2. bat基础

    首先所有命令在cmd命令行中都能找到说明: 例如 想知道type用法 输入type /? 其他命令都一样 type [drive:][path] filename 显示文本文件内容 虽然有点鸡肋 1 ...

  3. Redis之个人简单理解

    1.什么是redis? 在过去的几年中,NoSQL数据库一度成为高并发.海量数据存储解决方案的代名词,与之相应的产品也呈现出雨后春笋般的生机.然而在众多产品中能够脱颖而出的却屈指可数,如Redis.M ...

  4. redis 操作 hash 的测试

    1>hset setname field value hset stuSet name zhangsan:1        2>hget setname field hget stuset ...

  5. C#通过WebClient/HttpWebRequest实现http的post/get方法

    C#通过WebClient/HttpWebRequest实现http的post/get方法 http://www.cnblogs.com/shadowtale/p/3372735.html

  6. 什么是License

    许多混乱就始于你不知道License到底是什么,到底有什么含义.当你对你的产品使用License时,并不意味着你放弃了任何权利,你依然对其拥有原著作权.License只是授予他们于特定权利来使用你的产 ...

  7. [Algorithm] 局部敏感哈希算法(Locality Sensitive Hashing)

    局部敏感哈希(Locality Sensitive Hashing,LSH)算法是我在前一段时间找工作时接触到的一种衡量文本相似度的算法.局部敏感哈希是近似最近邻搜索算法中最流行的一种,它有坚实的理论 ...

  8. nginx tomcat session丢失的问题

    nginx反向代理tomcat,出现seesion获取不到的问题. 网上搜索到的解决方案大多是集群tomcat共享session共享的问题,但我这个只有一台tomcat服务器,不涉及到服务器集群问题. ...

  9. 关于BCGControlbar16.1版本的安装与使用

    csdn上有BCGControlbar16.1版本的下载,地址:http://download.csdn.net/detail/wangxiangdong_sl/4821726带key,个人亲测VS2 ...

  10. MVC路由配置例

    public static void RegisterRoutes(RouteCollection routes) { string suffix = string.Empty; routes.Ign ...