主题

Cocos Creator不同手机分辨率的背景图像和场景内容适配

特别说明

CocosCreator微信小游戏开发系列文章,是我在逐步开发过程中,基于官方文档之上,记录一些重点内容,以及对官方文档中有些知识点的补充和分析。

正文

我在《微信小游戏开发之Cocos Creator系列文章》中,写Cocos Creator项目配置时,提到了Canvas默认分辨率设置,微信推荐使用的设计稿分辨率是750x1334(iphone6的屏幕尺寸),然后把模拟器的分辨率尺寸也设成了750x1334。

当我发布构建,在微信开发者工具运行时,哦豁,怎么会有黑边呢,突然想起来现在市面上的手机分辨率五花八门的,肯定要做屏幕多分辨率适配的啊,大意了啊,我没有闪。

按照惯例,先看下当设计分辨率和屏幕分辨率出现差异时,Cocos Creator 官方建议如何进行适配呢?

有兴趣的可以去看下cocos官方文档《多分辨率适配方案》的详细介绍,我直接总结一下官方文档中的适配方案:

文档中的适配主要是靠Canvas组件节点上的两个选项:

  • 适配高度(Fit Height)
  • 适配宽度(Fit Width)

下面是这两个选项适合使用的情形:

  1. 设计分辨率宽高比大于屏幕分辨率宽高比,勾选Fit Height,可以避免屏幕可见区域内出现黑边,之后配合Widget(对齐挂件)调整 UI 元素的位置,来保证 UI 元素出现在屏幕可见区域内。

  2. 设计分辨率宽高比小于屏幕分辨率宽高比,勾选Fit Width,可以避免出现黑边,同样需要配合Widget(对齐挂件)来调整 UI 元素的位置,使UI 元素出现在屏幕可见区域内。

  3. 比例相同的情况,随便勾选哪一个都可以。

为什么是设计分辨率宽高比大于屏幕分辨率宽高比时,适配高度而不是适配高度呢?

来看看它的适配过程:

假设设计分辨率宽高是800 x 480,屏幕分辨率宽高是1024 x 768

1. 先算以下两个值:* A1: 屏幕分辨率宽 / 设计分辨率宽 = 1024 / 800 = 1.28* A2: 屏幕分辨率高 / 设计分辨率高 = 768 / 480 = 1.62. 适配实际是将场景图像放大 "A1或A2" 倍3. 假设放到A1倍:分辨率变成 800*1.28 / 480*1.28 = 1024 / 614.4
可以看到高度其实还没有达到当前屏幕的高度,所以还是会出现黑边4. 放到A2倍:分辨率变成 800*1.6 / 480*1.6 = 1280 / 768
可以看到宽高都达到当前屏幕宽高度,
只是宽度有部分超出屏幕被裁剪掉了,
但不会出现黑边5. 所以,设计分辨率宽高比大于屏幕分辨率时,适配高度。

同理,如果是设计分辨率宽高比小于屏幕分辨率宽高比,就应当适配宽度。

文档中还提到了其他的几种适配策略,但是他们都有可能出现黑边:

  • SHOW_ALL模式:同时勾选Fit HeightFit Width,图像内容不会失真,场景图像等比进行缩放,缩放比例是取屏幕宽/设计分辨率宽屏幕高/设计分辨率高中较小的一个值。

  • NO_BORDER模式:Fit HeightFit Width两个都不勾选,图像内容不会失真,但会有裁剪,场景图像等比进行缩放,缩放比例是取屏幕宽/设计分辨率宽屏幕高/设计分辨率高 中较大的一个值。

  • EXACT_FIT模式:不详细介绍了,官方也是一笔带过。

看到这里,你会发现因为手机屏幕的分辨率实在太多,屏幕分辨率宽高比大于小于设计分辨率宽高比的手机屏幕都会有,所以在编辑器上勾选Fit HeightFit Width中的某一个或者多个,都没有办法适配所有屏幕,那应该怎么办呢?

方案一:动态选择启用 Fit Height 模式和 Fit Width 模式

既然编辑器上怎么勾选都会有问题,那我们可以动态地判断屏幕分辨率宽高比来选择启用Fit Height模式和Fit Width模式啊。

直接上代码:

//FullScreenAdapter.js
cc.Class({extends: cc.Component,onLoad () {//监听窗口大小变化时的回调,每次窗口变化都要自动适配cc.view.setResizeCallback(() => this.screenAdapter());this.screenAdapter();},/*** Fit Height 模式:适用于宽大于高的屏幕* Fit Width 模式:适用于高大于宽的屏幕*/screenAdapter() {//当前屏幕分辨率比例let screenRatio = cc.winSize.width / cc.winSize.height;//设计稿分辨率比例let designRatio = cc.Canvas.instance.designResolution.width / cc.Canvas.instance.designResolution.height;if (screenRatio <= 1) {//屏幕高度大于或等于宽度,即竖屏if (screenRatio <= designRatio) {this.setFitWidth();} else {//此时屏幕比例大于设计比例//为了保证纵向的游戏内容不受影响,应该使用 fitHeight 模式this.setFitHeight();}} else {//屏幕宽度大于高度,即横屏this.setFitHeight();}},setFitWidth() {cc.Canvas.instance.fitHeight = false;cc.Canvas.instance.fitWidth = true;},setFitHeight() {cc.Canvas.instance.fitHeight = true;cc.Canvas.instance.fitWidth = false;}
});

把上面的js脚本挂载到Canvas节点上,就可以简单的实现所有屏幕适配了。

注意: 如果项目运行在可动态调整窗口大小的平台(比如浏览器),最好每次调整窗口都刷新一下页面。

方案二:基于SHOW_ALL模式,动态设置最大父节点的scale属性

这个方案比较麻烦,但是确实可以实现所有屏幕的适配,大家有兴趣可以去看看“Cocos Creator 多分辨率完美适配”系列文章。

刘海屏和水滴屏等手机状态栏的适配

现在市面上的手机额头上千奇百怪的状态,什么刘海啊、水滴啊、挖孔啊、伸缩啊,为了用户体验,没办法我们也要去适配它。

方法很简单,我们只要获取微信菜单按钮(右上角胶囊按钮)距离屏幕顶部的距离,然后设置一下顶部节点的paddingTop就可以了,直接上代码吧:

let menuInfo = wx.getMenuButtonBoundingClientRect();
let systemInfo = wx.getSystemInfoSync();
let paddingTop = this.node.parent.height * (menuInfo.top / systemInfo.screenHeight);let widget = this.node.getComponent(cc.Widget);
widget.top = paddingTop;
widget.isAbsoluteTop = true;
widget.isAlignTop = true;
widget.updateAlignment();

介绍cocos提供的几个获取View的方法

cc.view.getDesignResolutionSize()获取的是你在编辑器中设计的分辨率,也就是canvas 组件下设置的设计分辨率。cc.view.getFrameSize()获取各种手机、pad上的屏幕分辨率,也就是硬件分辨率。cc.view.getVisibleSizeInPixel()获取的是 visibleSize 的基础上乘以各种适配策略下的缩放比例后的分辨率。cc.view.getVisibleSize()返回视图窗口可见区域尺寸

总结

多分辨率适配的核心原理是动态改变Canvas节点或者其他节点的scale属性,熟悉Cocos Api文档的各个方法,能为我们解决各种疑难问题提供丰富的思路。

结尾

既然您看到这了,说明文章对你还有吸引力,帮忙点个赞再走吧,谢谢!

关注我的公众号「掉队程序员」,持续输出更多内容!

自己动手写,分解项目中的各个模块需求,通过查文档和搜索Cocos社区,解决碰到的问题,最终在微信上线了下面这款微信小游戏《成语锦衣卫》,欢迎大家扫码体验,并作为参考项目模版,开发出属于自己的小游戏

预告

下一节和朋友们说一说:Toast插件的使用,一直提示“readFile:fail permission denied”的原因

微信小游戏开发之CocosCreator多分辨率场景适配方案相关推荐

  1. 微信小游戏开发之Cocos Creator使用微信云开发和微信开放能力

    主题 Cocos Creator集成微信云开发和调用微信开放能力 特别说明 CocosCreator微信小游戏开发系列文章,是我在逐步开发过程中,基于官方文档之上,记录一些重点内容,以及对官方文档中有 ...

  2. 微信小游戏开发之二:hello world

    将main.js中的代码修改为如下: import './js/libs/weapp-adapter' import './js/libs/symbol'let ctx = canvas.getCon ...

  3. 微信小程序开发之scroll-view上拉加载数据实现

    微信小程序开发之scroll-view上拉加载数据实现 一.开发思路 1.使用小程序的scroll-view组件中提供了一个bindscrolltolower属性监听组件的滑动到了底部 https:/ ...

  4. 微信小程序开发之SVG的使用

    因为工作的原因,最近开始接触并且了解微信小程序.太久没有写或者看过前端相关的代码,加上小程序本身的bug也比较多,中间发现坑还是不少,后面逐渐整理总结一下.这一篇先总结一下svg在小程序中的使用. S ...

  5. 微信小程序开发之wxss中的那些事(一)

    微信小程序开发之wxss中的那些事 微信小程序开发中,页面的布局怎么整? 啥是WXSS? 基本语法 什么是rpx 什么是 flex 微信小程序开发中,页面的布局怎么整? 各位道友请留步,如果你是新手, ...

  6. 微信营销小游戏开发之6月份总结

    从6月1开始,各种筹备应用资料以及了解应用逻辑,思路,功能,效果,状态,以及配置 6月12开始,正式开始动工开始我的第一个游戏应用,取名 [翻翻乐]  turncard 翻翻乐:是一款翻卡片的H5小游 ...

  7. 微信小游戏开新手攻略

    Creator星球「脱贫实验室」有不少伙伴开始实践微信小游戏,遇到一些问题,在这里简单总结并回复大家. 1. 开发微信小游戏需要版号吗? 开发微信小游戏不需要版号,但需要<计算机软件著作权登记证 ...

  8. 【转】微信小游戏开发源码_教程_工具_资源最新集合

    [小游戏资源] 微信小游戏开发资源目录 一.微信官方游戏教程 小游戏简易教程 小游戏API大全 小游戏开发工具 二.微信小游戏图标资源 Game-icons.net 三.微信小游戏图片资源 Super ...

  9. [小游戏] 微信小游戏开发源码_教程_工具_资源最新集合

    [小游戏资源] 微信小游戏开发资源目录 一.微信官方游戏教程 小游戏简易教程 小游戏API大全 小游戏开发工具 二.微信小游戏图标资源 Game-icons.net 三.微信小游戏图片资源 Super ...

最新文章

  1. 02_Mybatis动态代理
  2. 负责域名解析的DNS服务
  3. 什么人不在生死簿_地府在孙悟空划掉生死簿以后,因为什么原因不组织重写?...
  4. 优秀linux系统设计,Linux系统下设计优秀实用程序的艺术
  5. java设计模式-Observe
  6. springboot logback 调整 mybatis 日志级别无效
  7. 【算法笔记】逆元的求解
  8. vue js代码混淆加密、压缩
  9. UML 类图生成工具simpleUML
  10. 5个高质量资源网站,耗时一周整理,让你告别资源付费
  11. 爬虫实战 ——百度翻译
  12. neo4j构建算法_使用neo4j构建餐厅推荐引擎
  13. SeleniumWebdriver参数化详解
  14. 2019 Google Developder Days(GDD)
  15. [二级域名映射端口][Ngins端口映射]腾讯云二级域名映射端口
  16. 视频编码第一节:H.265/HEVC原理——入门
  17. linux 定时任务(crontab)
  18. excel表格xlsx密码强制解除手机,忘记excel表格xlsx密码如何找回?
  19. 第八章、使用matplotlib绘制高级图表
  20. mysql 分位数 知乎_分位数的意义是什么?

热门文章

  1. 曼达洛人对机器人的评价_如何评价《曼达洛人 》?
  2. 去除字符串两边 或 所有空格
  3. 小程序不能加载服务器上缩略图,微信小程序 图片加载失败处理方法
  4. 利用libqrencode生成二维码并保持成bmp图片
  5. leetcode 58最后一个单词的长度 (js)
  6. 哔哩哔哩2021年1024程序员节算发与安全答题——解析答案
  7. linux怎么查看tomcat错误日志,Linux下查看Tomcat运行日志
  8. Java实现拼图小游戏(6)—— 移动图片(键盘监听实操练习)
  9. fpga实现VGA显示
  10. 使用Vue指令实现数据展示,小米商城商品展示