苹果的IphoneX新增一个安全区的概念,如下图

图中绿色区域为安全区,所有可交互的组件全部放在安全区内,只有背景可以延伸出去,达到全面屏的效果

我们适配IphoneX采用NGUI通用的锚点去适配。默认的NGUI屏幕适配方案不支持安全区这个概念,我在NGUI每个继承UIRect的组件下新增一个Bool变量InSafeArea,这个变量如果为True则表示这个组件是放置在安全区内的,如果为false则表示这个组件是全屏的,一般为True,只有背景图才需要去掉这个勾

原理:

所有的NGUI锚点的适配最终都会调用NGUITools.GetSides这个方法,这个方法实际上是NGUI为Camera写的扩展方法,如下,新增了一个inSafeArea参数,备注内是我新增的

 static public Vector3[] GetSides (this Camera cam, float depth, Transform relativeTo, bool inSafeArea = true){
#if UNITY_4_3 || UNITY_4_5 || UNITY_4_6 || UNITY_4_7if (cam.isOrthoGraphic)
#elseif (cam.orthographic)
#endif{// for iphonex by xiaobaifloat xOffset = 1f;float yOffset = 1f;
#if UNITY_IOS//iphone x 适配if (SystemInfo.deviceModel.Contains("iPhone10,3") || SystemInfo.deviceModel.Contains("iPhone10,6") && inSafeArea){xOffset = 734f / 812f;yOffset = 340f / 375f;}
#elif UNITY_EDITOR//测试代码if (inSafeArea){Vector2 ssize = screenSize;if (ssize.x == 1624f && ssize.y == 750f)        //自动识别{xOffset = 734f / 812f;yOffset = 340f / 375f;}}
#endif// end for iphonex by xiaobaifloat os = cam.orthographicSize;float x0 = -os * xOffset;float x1 = os * xOffset;float y0 = -os * yOffset;float y1 = os;Rect rect = cam.rect;Vector2 size = screenSize;float aspect = size.x / size.y;aspect *= rect.width / rect.height;x0 *= aspect;x1 *= aspect;// We want to ignore the scale, as scale doesn't affect the camera's view region in UnityTransform t = cam.transform;Quaternion rot = t.rotation;Vector3 pos = t.position;mSides[0] = rot * (new Vector3(x0, 0f, depth)) + pos;mSides[1] = rot * (new Vector3(0f, y1, depth)) + pos;mSides[2] = rot * (new Vector3(x1, 0f, depth)) + pos;mSides[3] = rot * (new Vector3(0f, y0, depth)) + pos;}else{mSides[0] = cam.ViewportToWorldPoint(new Vector3(0f, 0.5f, depth));mSides[1] = cam.ViewportToWorldPoint(new Vector3(0.5f, 1f, depth));mSides[2] = cam.ViewportToWorldPoint(new Vector3(1f, 0.5f, depth));mSides[3] = cam.ViewportToWorldPoint(new Vector3(0.5f, 0f, depth));}if (relativeTo != null){for (int i = 0; i < 4; ++i)mSides[i] = relativeTo.InverseTransformPoint(mSides[i]);}return mSides;}

原理是如果检测到机型为iphonex,并且锚点限制在安全区内,就自动将屏幕大小缩小为安全区大小,否则就全屏。为了方便测试 在编辑器下,设置分辨率为1624x750就可以方便的看到iphonex的效果了

这段代码只展示原理,具体如何去应用,还需要改动UIRect和UIRectEditor的相关方法

UNITY NGUI IPHONEX完美适配相关推荐

  1. Unity NGUI屏幕适配

    前段时间整理的一篇关于unity ui开发的文章,被推荐上了csdn首页,对于刚刚写文字的我来说,是莫大的鼓励,让我干劲十足,写出更多有质量的文字. 写在前面 屏幕适配是每个手机应用和游戏都会解决的问 ...

  2. taro 请务必在小程序页面中完善页面基础信息_小程序自定义导航栏(完美适配所有手机)...

    背景 在做小程序时,关于默认导航栏,我们遇到了以下的问题: Android.IOS手机对于页面title的展示不一致,安卓title的显示不居中 页面的title只支持纯文本级别的样式控制,不能够做更 ...

  3. 微信小程序自定义导航栏组件,完美适配所有手机,可实现各种功能和情况

    背景 在做小程序时,关于默认导航栏,我们遇到了以下的问题: Android.IOS手机对于页面title的展示不一致,安卓title的显示不居中 页面的title只支持纯文本级别的样式控制,不能够做更 ...

  4. 小程序自定义导航栏(完美适配所有手机)解决上下不居中 左右不对齐 高度不协调问题...

    背景 在做小程序时,关于默认导航栏,我们遇到了以下的问题: Android.IOS手机对于页面title的展示不一致,安卓title的显示不居中 页面的title只支持纯文本级别的样式控制,不能够做更 ...

  5. Unity NGUI 插件 简介

    文章目录 Unity NGUI 一. NGUI基础 1.1 导入NGUI插件 1.2 基本UI资源 1.3 制作UI图集 1.4 制作UI字体 1.5 UIRoot.UIPanel 和 UICamer ...

  6. 微信小程序自定义导航栏组件(完美适配所有手机),可自定义实现任何你想要的功能

    背景 在做小程序时,关于默认导航栏,我们遇到了以下的问题: Android.IOS 手机对于页面 title 的展示不一致,安卓 title 的显示不居中 页面的 title 只支持纯文本级别的样式控 ...

  7. Unity NGUI 3.0.4版本 制作网络版斗地主

    Unity NGUI 3.0.4版本 @by 灰太龙  开发环境 Win7旗舰版 Unity 4.2.1f4 本文就写个开门篇,告诉大家怎么用NGUI,第一步导入NGUI 3.0.4版本! 1.启动U ...

  8. sougou ubuntu 优麒麟_搜狗输入法 Linux – V2.3 版发布,完美适配优麒麟 19.10

    搜狗输入法 Linux – V2.3 版发布,完美适配优麒麟 19.10 fenshezhuiyi2 2019年10月19日 暂无评论 阅读 4,346 次 昨天已发布优麒麟操作系统 19.10 版本 ...

  9. android图片适配到裁剪框,Android图片剪裁-调用系统实现,完美适配魅族等机型

    System-Photo-Cropper Android System Photo Cropper 使用系统原生的图片剪裁库,完美适配魅族等机型 Step 1 First you need a sys ...

最新文章

  1. centos查看模块信息和模块路径
  2. 工程化专题之Maven(下)
  3. Spring整合定时任务组件Quartz的简单使用
  4. 2017最新顺口溜出炉(超级经典)!
  5. LeetCode 138. 复制带随机指针的链表(哈希 / 深拷贝)
  6. Python之路【第三篇】:Python基础(二)
  7. [Python] Ubuntu 安装/卸载 python
  8. oracle管理表空间和数据文件(笔记)
  9. 万年历c语言 输出单月,求帮忙差错,打印万年历,输入某年某月,打印该月日历...
  10. 1.1信息安全基础概念
  11. 基于因子分析和聚类分析 的SPSS河南省各地区综合发展分析+操作步骤+全文详细
  12. 魔方cfop公式软件_如何学习魔方?这份提速心得,亲测有效
  13. maya api 初接触
  14. 中科大计算机考研录取分数线_计算机专业学校考研难度排行榜 计算机考研难度排名...
  15. geoserver之gs-kml、gs-wcs、gs-rest、gs-gwc、gs-sec-jdbc
  16. 时间序列ARMA中p,q选择
  17. python的mysql数据查询及报错AttributeError: 'Connection' object has no attribute 'curson'
  18. 大学生研究生毕业找工作,该选择哪个方向?
  19. 23 《武士道》 -豆瓣评分7.8
  20. Python爬取图片并保存本地

热门文章

  1. 63.android 简单的下拉刷新动画水滴效果
  2. 共享充电宝再涨价达每小时6元 客服:市场需求决定的
  3. 地图作业平台低代码实战(搭建能力提升)
  4. 巴卡斯杯 中国大学生程序设计竞赛 - 女生专场(重现)解题思路
  5. SDH原理--1.SDH概述
  6. php脚本爬取头像图片
  7. OS学习笔记-21(清华大学慕课)文件系统
  8. 用UNION的注意事项
  9. 一个通过添加本地分区索引提高SQL性能的案例
  10. Node.js+express+MySQL仿美团注册登录绑定第三方登录