CocosCreator 面试题(十七)Cocos creator 固定宽度与固定高度的底层原理是什么?Cocos creator是如何做适配的?

简介: CocosCreator 面试题(十七)Cocos creator 固定宽度与固定高度的底层原理是什么?Cocos creator是如何做适配的?

一、Cocos creator 固定宽度与固定高度的底层原理


Cocos Creator 中,固定宽度和固定高度是两种常见的适配方式,用于在不同屏幕尺寸上保持游戏画面的一致性。它们的底层原理如下:


1、固定宽度适配

固定宽度适配的目标是在不同屏幕宽度上保持游戏画面的一致性。底层原理如下:

  • 游戏设计时基于一个固定的宽度进行布局和渲染,通常称为「设计宽度」。
  • 在游戏初始化阶段,通过获取设备的屏幕宽度,计算出一个缩放比例,将设计宽度缩放到设备的实际宽度上。
  • 将游戏画面按照缩放比例进行缩放,保持宽度的一致性。高度会根据缩放比例等比例缩放,以保持画面的纵横比不变。
  • 使用相对坐标和布局方式,确保游戏中的元素在不同屏幕尺寸上正确定位和显示。


2、固定高度适配

固定高度适配的目标是在不同屏幕高度上保持游戏画面的一致性。底层原理如下:

  • 游戏设计时基于一个固定的高度进行布局和渲染,通常称为「设计高度」。
  • 在游戏初始化阶段,通过获取设备的屏幕高度,计算出一个缩放比例,将设计高度缩放到设备的实际高度上。
  • 将游戏画面按照缩放比例进行缩放,保持高度的一致性。宽度会根据缩放比例等比例缩放,以保持画面的纵横比不变。
  • 使用相对坐标和布局方式,确保游戏中的元素在不同屏幕尺寸上正确定位和显示。


通过固定宽度或固定高度的适配方式,可以使游戏在不同屏幕尺寸上保持一定的一致性,确保游戏中的元素的大小和位置相对稳定。具体选择哪种适配方式取决于你的游戏需求和设计考虑。在 Cocos Creator 中,你可以通过设置「设计分辨率」和使用相对坐标和布局方式来实现固定宽度或固定高度的适配。


二、Cocos creator如何做适配?


Cocos Creator 提供了多种适配方式,用于在不同屏幕尺寸上保持游戏画面的一致性。下面介绍 Cocos Creator 中常用的适配方式和相应的配置方法:


  1. 固定宽度适配
  • 在 Cocos Creator 编辑器中,选择「项目设置」窗口。
  • 在「分辨率」选项卡中,选择「固定宽度适配」。
  • 设置设计分辨率的宽度,这是游戏设计时使用的固定宽度。
  • 在代码中,可以通过 cc.view.getFrameSize().width 获取屏幕宽度,并使用缩放比例将设计宽度缩放到设备宽度上。


  1. 固定高度适配
  • 在 Cocos Creator 编辑器中,选择「项目设置」窗口。
  • 在「分辨率」选项卡中,选择「固定高度适配」。
  • 设置设计分辨率的高度,这是游戏设计时使用的固定高度。
  • 在代码中,可以通过 cc.view.getFrameSize().height 获取屏幕高度,并使用缩放比例将设计高度缩放到设备高度上。


  1. 自适应适配
  • 在 Cocos Creator 编辑器中,选择「项目设置」窗口。
  • 在「分辨率」选项卡中,选择「自适应适配」。
  • 设置设计分辨率的宽度和高度,这是游戏设计时使用的分辨率。
  • 在代码中,可以使用相对坐标和布局方式,使用百分比或比例来定位和缩放游戏中的元素,以适应不同屏幕尺寸。


  1. 其他适配方式
  • Cocos Creator 还提供了其他适配方式,如填充适配、裁剪适配等,可以根据具体需求进行选择和配置。


除了选择适配方式,你还可以使用 Cocos Creator 提供的 UI 组件和布局系统来实现自适应布局。例如,使用 cc.Widget 组件来设置节点的锚点、边距、对齐方式等,以适应不同屏幕尺寸。


总之,Cocos Creator 提供了多种适配方式和工具,帮助你在不同屏幕尺寸上保持游戏画面的一致性。选择适当的适配方式,并结合 UI 组件和布局系统,可以实现灵活而精确的适配效果。



相关文章
|
消息中间件 存储 缓存
大厂面试高频:Kafka 工作原理 ( 详细图解 )
本文详细解析了 Kafka 的核心架构和实现原理,消息中间件是亿级互联网架构的基石,大厂面试高频,非常重要,建议收藏。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:Kafka 工作原理 ( 详细图解 )
|
存储 SQL 关系型数据库
MySQL进阶突击系列(03) MySQL架构原理solo九魂17环连问 | 给大厂面试官的一封信
本文介绍了MySQL架构原理、存储引擎和索引的相关知识点,涵盖查询和更新SQL的执行过程、MySQL各组件的作用、存储引擎的类型及特性、索引的建立和使用原则,以及二叉树、平衡二叉树和B树的区别。通过这些内容,帮助读者深入了解MySQL的工作机制,提高数据库管理和优化能力。
|
存储 NoSQL 前端开发
美团面试:手机扫描PC二维码登录,底层原理和完整流程是什么?
45岁老架构师尼恩详细梳理了手机扫码登录的完整流程,帮助大家在面试中脱颖而出。该过程分为三个阶段:待扫描阶段、已扫描待确认阶段和已确认阶段。更多技术圣经系列PDF及详细内容,请关注【技术自由圈】获取。
|
Java 数据库连接 Maven
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
自动装配是现在面试中常考的一道面试题。本文基于最新的 SpringBoot 3.3.3 版本的源码来分析自动装配的原理,并在文未说明了SpringBoot2和SpringBoot3的自动装配源码中区别,以及面试回答的拿分核心话术。
1130 2
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
|
Java Linux 调度
硬核揭秘:线程与进程的底层原理,面试高分必备!
嘿,大家好!我是小米,29岁的技术爱好者。今天来聊聊线程和进程的区别。进程是操作系统中运行的程序实例,有独立内存空间;线程是进程内的最小执行单元,共享内存。创建进程开销大但更安全,线程轻量高效但易引发数据竞争。面试时可强调:进程是资源分配单位,线程是CPU调度单位。根据不同场景选择合适的并发模型,如高并发用线程池。希望这篇文章能帮你更好地理解并回答面试中的相关问题,祝你早日拿下心仪的offer!
403 6
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
|
存储 安全 Java
面试高频:Synchronized 原理,建议收藏备用 !
本文详解Synchronized原理,包括其作用、使用方式、底层实现及锁升级机制。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
面试高频:Synchronized 原理,建议收藏备用 !
|
负载均衡 算法 Java
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
40岁老架构师尼恩分享了关于SpringCloud核心组件的底层原理,特别是针对蚂蚁集团面试中常见的面试题进行了详细解析。内容涵盖了Nacos注册中心的AP/CP模式、Distro和Raft分布式协议、Sentinel的高可用组件、负载均衡组件的实现原理等。尼恩强调了系统化学习的重要性,推荐了《尼恩Java面试宝典PDF》等资料,帮助读者更好地准备面试,提高技术实力,最终实现“offer自由”。更多技术资料和指导,可关注公众号【技术自由圈】获取。
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
|
SQL 关系型数据库 MySQL
阿里面试:MYSQL 事务ACID,底层原理是什么? 具体是如何实现的?
尼恩,一位40岁的资深架构师,通过其丰富的经验和深厚的技術功底,为众多读者提供了宝贵的面试指导和技术分享。在他的读者交流群中,许多小伙伴获得了来自一线互联网企业的面试机会,并成功应对了诸如事务ACID特性实现、MVCC等相关面试题。尼恩特别整理了这些常见面试题的系统化解答,形成了《MVCC 学习圣经:一次穿透MYSQL MVCC》PDF文档,旨在帮助大家在面试中展示出扎实的技术功底,提高面试成功率。此外,他还编写了《尼恩Java面试宝典》等资料,涵盖了大量面试题和答案,帮助读者全面提升技术面试的表现。这些资料不仅内容详实,而且持续更新,是求职者备战技术面试的宝贵资源。
阿里面试:MYSQL 事务ACID,底层原理是什么? 具体是如何实现的?
|
安全 算法 网络协议
网易面试:说说 HTTPS 原理?HTTPS 如何保证 数据安全?
45岁老架构师尼恩在其读者交流群中分享了关于HTTP与HTTPS的深入解析,特别针对近期面试中常问的HTTPS相关问题进行了详细解答。文章首先回顾了HTTP的工作原理,指出了HTTP明文传输带来的三大风险:窃听、篡改和冒充。随后介绍了HTTPS如何通过结合非对称加密和对称加密来解决这些问题,确保数据传输的安全性。尼恩还详细解释了HTTPS的握手过程,包括如何通过CA数字证书验证服务器身份,防止中间人攻击。最后,尼恩强调了掌握这些核心技术的重要性,并推荐了自己的技术资料,帮助读者更好地准备面试,提高技术水平。