Cocos Creator 多分辨率完美适配系列-3(背景适配实现)

本系列教程指引:

  1. Cocos Creator 多分辨率完美适配系列-1(现状与最终效果)
  2. Cocos Creator 多分辨率完美适配系列-2(部署验证设置)
  3. Cocos Creator 多分辨率完美适配系列-3(背景适配实现)
  4. Cocos Creator 多分辨率完美适配系列-4(内容适配实现)
  5. Cocos Creator 多分辨率完美适配系列-5(贴边栏动画实现)
  6. Cocos Creator 多分辨率完美适配系列-6(刘海屏适配)
  7. Cocos Creator 多分辨率完美适配系列-7(封装库使用)

1. 详细了解 SHOW ALL 模式

在之前第一节中,我们提及到 Cocos Creator 的一种的屏幕适配方式(SHOW ALL),也就是 Canvas 两个都 Fit 都勾选

SHOW_ALL_SETTINGS.png

也提及到这种适配模式可能会出现 上下黑边 或者 左右黑边 。注意,是只会有这两种黑边类型,不会出现其他组合的黑边,如:上下左右黑边、上左黑边。

那么实际上, SHOW ALL 模式是怎么进行适配的呢?参考下方官方提供的一张图

SHOW_ALL_ADAPTER

按照上图,我们 不难 得出 SHOW ALL 模式下适配过程为

1. 先算以下两个值:
    * A1: 画布分辨率宽 / 设计分辨率宽
    * A2: 画布分辨率高 / 设计分辨率高
2. 取 A1、A2 最小值
3. 设计分辨率宽、高分别乘以最小值,即为实际画布上的我们设计稿的宽高了

按照上图:

A1: 画布分辨率宽 / 设计分辨率宽 = 640 / 800 = 0.8
A2: 画布分辨率高 / 设计分辨率高 = 960 / 480 = 2

设计稿在画布上的宽度 = 800 x 0.8 = 640
设计稿在画布上的高度 = 480 x 0.8 = 384

大家可以对对看,是不是刚好等于红框中,白色内容的尺寸! 那么问题来了?为什么是乘以最小值呢?

因为这个模式叫 SHOW ALL,意思为在画布上完整展示我们的设计分辨率下的设计稿内容。为了保证这一点,我们需要按照最小缩放比例,也就是最小值去进行适配。而如果乘以最大值,以上图为例,那么就会变成下方这个适配结果

SHOW_ALL_MAX_DESIGN.png

很明显,在实际显示时,我们会缺失设计搞左右两边部分内容。

至此,我们已经完成了对 SHOW ALL 模式的理解。理解 SHOW ALL 模式对于我们后续的适配方案是十分有必要的

PS:理解整个适配过程之后,大家是否可以理解到为什么只可能出现 上下黑边 或者 左右黑边 呢?又是什么时候才会出现呢?(作者比较懒,读者可以自行脑补,或者赞赏到一定程度可以召唤作者)

2. 背景适配实现

通过上一节的理解,相信大家对 SHOW ALL 模式已经有一定理解了。回归到我们主题,如何做背景适配呢?

可能不少朋友会直接用 Widget 组件,直接将背景拉伸至和设计分辨率宽高一致。如果实际画布分辨率和设计分辨率一致,那么这种做法问题不大,但是如果不一致,那么会出现很明显的拉伸感,会让用户觉得“这个游戏开发得不用心”。

需要肯定的是拉伸是一种适配手段,但我们肯定不止于拉伸。了解SHOW ALL 模式之后,我们可以用 缩放 去做背景适配。

那么 SHOW ALL 模式下应该怎么缩放呢?先上图示

BACKGROUND_ADAPTER_PROCESS.png

过程如下:

  1. 求出设计分辨率在画布(SHOW ALL 模式下)的实际宽高
  2. 将实际宽高的设计分辨率 缩放 至宽高刚好包含画布大小
    • 计算过程如下:
      • B1: 画布宽度 / 设计稿实际宽度
      • B2: 画布高度 / 设计稿实际高度
      • 取B1,B2最大值,修改节点缩放值为最大值即可

伪代码如下:

A1: 画布分辨率宽 / 设计分辨率宽 = 640 / 800 = 0.8
A2: 画布分辨率高 / 设计分辨率高 = 960 / 480 = 2

设计稿在画布上的宽度 = 800 x 0.8 = 640
设计稿在画布上的高度 = 480 x 0.8 = 384

B1: 画布宽度 / 设计稿实际宽度 = 640 / 640 = 1 
B2: 画布高度 / 设计稿实际高度 = 960 / 384 = 2.5

this.node.sacle = 2.5

对应实际代码如下:

// 1. 先找到 SHOW_ALL 模式适配之后,本节点的实际宽高以及初始缩放值
let scaleForShowAll = Math.min(
  cc.view.getCanvasSize().width / this.node.width, 
  cc.view.getCanvasSize().height / this.node.height
);
let realWidth = this.node.width * scaleForShowAll;
let realHeight = this.node.height * scaleForShowAll;

// 2. 基于第一步的数据,再做缩放适配
this.node.scale = Math.max(
  cc.view.getCanvasSize().width / realWidth, 
  cc.view.getCanvasSize().height / realHeight
 );

3. 验证适配结果

为了方便验证结果,我们只需要创建一个 Background 节点并加入一个 Sprite 组件,节点采用上面适配代码就可以了。

实际运行后,我们取两组结果演示:

BACKGROUND_ADAPTER_RESULT.png

上面是同一张图片在不同分辨率下的 缩放 适配,无须美术弄多张图,一张图足以,只是可能会有点模糊,但是整体适配效果还是不错的。

为了方便大家使用,上面代码(其实也就4行)已经弄成了一个 组件 ,下载下来直接拖入到背景节点即可。

更多源码和示例,欢迎打开下方 Github 项目,如果觉得还不错,还可以 Star 一下呢~

https://github.com/zhitaocai/CocosCreator-Multi-resolution-Adapter

4. 总结

至此,我们的「背景适配」基本告一段落了,现在大家理解 SHOW ALL 模式下的缩放适配了吗?我们来做一下总结:

  1. 本章我们其实是在 SHOW ALL 模式基础上,再将我们的内容缩放至刚好包含画布,本质上上一种 缩放适配 方案。
  2. 对于图片背景之类的,采用这种 缩放 方案问题不大,但是我们游戏的实际内容肯定是不能 缩放 适配的。
  3. 那么对于游戏内容适配,我们应该采用的是 重置宽高 的适配方案。 重置宽高 是我自己的一个叫法,其实本质是将我们的 游戏内容节点宽高适配为画布大小 ,下一章我们将详细说明 内容适配实现

本系列教程指引:

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

推荐阅读更多精彩内容