Cocos Creator3.8 项目实战(五)背景无限滚屏效果如何实现

在游戏中,我们经常会实现背景无限滚动的效果。那这些效果是怎么实现的呢?

原理很简单,就是使用多张背景图,每张图,每一帧都同时移动,当图移出屏幕外时,将其位置设置到下一张图的初始位置,最后一张图位置设置为第一张图的初始位置,如此循环即可。

下面以 实现背景 1920*1080 的背景图,垂直方向无限滚动为例,进行详细说明。

⚠️ 文末附 BgMoveView.ts 完整源码, 可直接拿去使用。

具体实现方法:

step 1 ,在cocoscrearor 资源管理器中,添加多张背景图资源,并设置为sprite-frame类型。

注意:最好每张图的尺寸一致。

如下:

step 2 ,在cocoscrearor 层级管理器中,首先添加 bgNode 节点,用于背景图的根节点,然后再添加多个sprite节点 ,并设置sprite frame 资源 以及位置。

注意位置:

第一张图 0 ,0

第一张图 0 ,-1080

第三张图 0 ,-1080 *2

第四张图 0 ,-1080 *3

第五张图 0 ,-1080 *4

第六张图,以此类推...

step 3 ,为根节点 设置蒙版(Mask)组件。

step 4 ,为bgNode节点 挂载背景滚动脚本,并配置背景节点数组、滚动速度。

Step 5 、脚本 BgMoveView.ts 完整源码

复制代码
/**
 * 
 * 背景无限滚屏效果实现
 *
 * 
 * */

import { _decorator, Component, Node,UITransform } from 'cc';
const { ccclass, property } = _decorator;

@ccclass('BgMoveView')
export class BgMoveView extends Component {
    
	/**背景数组 */
    @property({type: Node})
	bgList:Node[] = [];

	/**移动速度 */
	@property({type: Number})
	moveSpeed:number = 200;

	/**背景图片滚出屏幕的位置*/
    bottomPosition:number = 0;

	/**背景图片高度*/
	bgHeight:number = 0;

	onLoad () {
	
		/**注意是负值*/
		this.bottomPosition = -this.bgList[0].getComponent(UITransform).height;
		this.bgHeight = this.bgList[0].getComponent(UITransform).height;
	}

    start() {

    }

    update(deltaTime: number) {
        
		for(let i = 0; i < this.bgList.length; i++) {

            /**达到触发条件,改变背景图片位置*/ 
			if(this.bgList[i].position.y <= this.bottomPosition) {
                this.bgList[i].setPosition(this.bgList[i].position.x,
					this.bgList[i+1<this.bgList.length?i+1:0].position.y + this.bgHeight);
			}

       		/**背景的移动*/  
			this.bgList[i].setPosition(this.bgList[i].position.x, this.bgList[i].position.y - this.moveSpeed*deltaTime);
		}
	}
}
相关推荐
°青31 分钟前
JavaScript 核心知识点(四)
开发语言·前端·javascript
踩着两条虫32 分钟前
VTJ:页面管理功能
前端·低代码·ai编程
梦想的颜色33 分钟前
js document 节点增删改查、样式设计全解析
java·前端·javascript
nvvas1 小时前
Could not resolve “@intlify/vue-devtools‘ node modules/. pnpm/vue-118n@9. 14
前端·javascript·vue.js
中屹指纹浏览器1 小时前
跨终端跨平台指纹浏览器的环境一致性技术架构与落地实践
经验分享·笔记
yqcoder1 小时前
[特殊字符] Vue 3 组件通信全指南:从基础到进阶
前端·javascript·vue.js
爱上好庆祝1 小时前
学习js第一天(出发新世界)
开发语言·前端·javascript·css·学习·html·ecmascript
木斯佳1 小时前
前端八股文面经大全:秦丝科技前端(2026-04-24)·笔试深度解析
前端·笔试
喜欢吃鱿鱼1 小时前
VUE项目 弹窗改为页面供其他项目嵌入iframe - 截取地址栏URL中的参数
前端·javascript·vue.js
无心使然云中漫步1 小时前
Openlayers调用ArcGis地图服务之二 —— 动态地图(/export)
前端·arcgis·vue·数据可视化