【Cocos Creator 3.x】篇——第一章 简介

目录

[1 什么是游戏编程](#1 什么是游戏编程)

[1.1 游戏引擎是什么](#1.1 游戏引擎是什么)

[1.2 常见的游戏引擎](#1.2 常见的游戏引擎)

[Unity 3D](#Unity 3D)

[虚幻引擎(Unreal Engine)](#虚幻引擎(Unreal Engine))

[Cocos Creator](#Cocos Creator)

[2 Cocos Creator 3.x 简介](#2 Cocos Creator 3.x 简介)

[2.1 主要改进](#2.1 主要改进)

[2.2 选择Cocos Creator 3.x的理由](#2.2 选择Cocos Creator 3.x的理由)

[3 开发前的准备](#3 开发前的准备)

[3.1 安装Cocos Creator 3.x](#3.1 安装Cocos Creator 3.x)

下载安装包

系统要求

[3.2 TypeScript基础](#3.2 TypeScript基础)

[3.2.1 类型注解](#3.2.1 类型注解)

[3.2.2 接口](#3.2.2 接口)

[3.2.3 类](#3.2.3 类)

[3.2.4 模块化](#3.2.4 模块化)

[3.3 开发工具](#3.3 开发工具)

推荐编辑器

必备插件

[4 项目结构](#4 项目结构)

[4.1 项目目录](#4.1 项目目录)

[4.2 关键文件说明](#4.2 关键文件说明)

tsconfig.json

package.json

project.json

[5 核心概念](#5 核心概念)

[5.1 实体组件系统(ECS)](#5.1 实体组件系统(ECS))

[5.2 场景与节点](#5.2 场景与节点)

[5.3 坐标系](#5.3 坐标系)

[6 第一个程序](#6 第一个程序)

[6.1 创建项目](#6.1 创建项目)

[6.2 创建脚本](#6.2 创建脚本)

[6.3 使用脚本](#6.3 使用脚本)

[7 总结](#7 总结)


《Cocos Creator 3.x游戏编程入门指南》摘要:本文系统介绍了游戏编程基础与Cocos Creator 3.x引擎的核心技术。从游戏引擎概念入手,对比分析了Unity3D、Unreal Engine等主流引擎特性,重点讲解Cocos Creator 3.x的架构升级(ECS系统、TypeScript支持、WebGPU等)和跨平台优势。详细说明开发环境配置、TypeScript语法要点(类型注解、类与模块化)、项目目录结构及核心概念(实体组件系统、坐标系)。

通过Hello World实例演示脚本创建、组件绑定和节点操作流程,为开发者提供从零开始的实践指导,并预告后续进阶学习内容。全文兼顾理论知识与实践操作,是快速掌握Cocos Creator 3.x开发的实用指南。

1 什么是游戏编程

游戏编程(Gaming Programming)是一种通过编程来实现电子游戏中的逻辑的方法,包括渲染,物理,交互等。

随着游戏产业的发展,游戏编程涉及的技术越来越广泛,从传统的渲染引擎到现代的人工智能、网络同步等。

1.1 游戏引擎是什么

游戏引擎是指一些已编写好的可编辑电脑游戏系统或者一些交互式实时图像应用程序的核心组件。这些系统为游戏设计者提供各种编写游戏所需的各种工具,其目的在于让游戏设计者能容易和快速地做出游戏程式而不用由零开始。

简单来说,引擎可以理解为一个开发游戏用的基本框架,对于一些游戏开发上通用的功能,不用再重复造轮子了,拿来就用。

1.2 常见的游戏引擎

Unity 3D

Unity3D是由Unity Technologies开发的一个让玩家轻松创建诸如三维视频游戏、建筑可视化、实时三维动画等类型互动内容的多平台的综合型游戏开发工具。

虚幻引擎(Unreal Engine)

虚幻引擎是一套完整的游戏开发工具,提供了从建模到发布的全套解决方案,以其强大的渲染能力和蓝图系统著称。

Cocos Creator

Cocos Creator是由Cocos官方推出的新一代游戏引擎,支持2D和3D游戏开发,具有轻量、高效、跨平台等特点。


2 Cocos Creator 3.x 简介

Cocos Creator 3.x 是 Cocos 引擎的最新版本,相比 2.x 版本有了全面的升级:

2.1 主要改进

  • 架构升级:采用全新的架构设计,性能大幅提升

  • 3D能力增强:原生支持3D渲染管线,支持PBR材质系统

  • TypeScript优先:全面拥抱TypeScript,提供更好的类型支持

  • ECS架构:引入实体组件系统(Entity-Component System)

  • WebGPU支持:支持最新的WebGPU标准,提升Web端性能

2.2 选择Cocos Creator 3.x的理由

  1. 跨平台能力强:支持Web、iOS、Android、Windows、Mac等多个平台

  2. 学习曲线平缓:对于有2D游戏开发经验的开发者来说,上手相对容易

  3. 社区活跃:拥有庞大的开发者社区和丰富的学习资源

  4. 性能优秀:针对移动平台进行了深度优化


3 开发前的准备

3.1 安装Cocos Creator 3.x

下载安装包

  1. 访问官方网站:Cocos Creator - 高效轻量的跨平台3D/2D图形引擎

  2. 下载最新版本的Cocos Creator 3.x

  3. 按照安装向导完成安装

系统要求

  • Windows 10+ 或 macOS 10.14+

  • 至少8GB内存

  • 支持OpenGL 3.3或更高版本的显卡

3.2 TypeScript基础

Cocos Creator 3.x 使用 TypeScript 作为主要开发语言。如果你之前使用过 JavaScript,学习 TypeScript 会非常容易。

3.2.1 类型注解

复制代码
// 基本类型
let name: string = "Cocos";
let version: number = 3.8;
let isEnabled: boolean = true;
​
// 数组类型
let numbers: number[] = [1, 2, 3];
let names: Array<string> = ["Alice", "Bob"];
​
// 任意类型
let data: any = "hello";
data = 123; // 可以改变类型

3.2.2 接口

复制代码
interface Player {
    id: number;
    name: string;
    level: number;
    hp: number;
}
​
let player: Player = {
    id: 1,
    name: "Hero",
    level: 10,
    hp: 100
};

3.2.3 类

复制代码
class Character {
    // 私有属性
    private _name: string;
    private _hp: number;
​
    // 构造函数
    constructor(name: string, hp: number) {
        this._name = name;
        this._hp = hp;
    }
​
    // 方法
    takeDamage(damage: number): void {
        this._hp -= damage;
        if (this._hp <= 0) {
            this.die();
        }
    }
​
    private die(): void {
        console.log(`${this._name} has died!`);
    }
​
    // Getter
    get hp(): number {
        return this._hp;
    }
}
​
// 使用类
let hero = new Character("Hero", 100);
hero.takeDamage(30);
console.log(hero.hp); // 输出 70

3.2.4 模块化

复制代码
// math.ts
export function add(a: number, b: number): number {
    return a + b;
}
​
export const PI: number = 3.14159;
​
// main.ts
import { add, PI } from './math';
​
console.log(add(2, 3)); // 输出 5
console.log(PI); // 输出 3.14159

3.3 开发工具

推荐编辑器

  • Visual Studio Code:官方推荐,支持TypeScript语法高亮、智能提示等

  • WebStorm:功能强大的IDE,对TypeScript有很好的支持

必备插件

  • Cocos Creator Extension:提供项目管理、调试等功能

  • ESLint:代码风格检查

  • Prettier:代码格式化工具


4 项目结构

4.1 项目目录

创建一个新的Cocos Creator 3.x项目后,你会看到以下目录结构:

复制代码
ProjectName/
├── assets/              # 资源目录
│   ├── scenes/          # 场景文件
│   ├── scripts/         # TypeScript脚本
│   ├── textures/        # 纹理资源
│   ├── audio/           # 音频资源
│   └── prefabs/         # 预制体资源
├── library/             # 编译后的资源库
├── packages/            # 扩展包
├── settings/            # 项目设置
├── temp/                # 临时文件
├── tsconfig.json        # TypeScript配置
├── package.json         # 依赖配置
└── project.json         # 项目配置

4.2 关键文件说明

tsconfig.json

TypeScript编译器配置文件,定义了编译选项和路径别名。

package.json

项目依赖管理文件,包含项目的依赖包信息。

project.json

Cocos Creator项目的核心配置文件,包含项目名称、版本等信息。


5 核心概念

5.1 实体组件系统(ECS)

Cocos Creator 3.x 引入了实体组件系统(Entity-Component System):

  • Entity(实体):游戏对象的抽象,本身不包含任何逻辑

  • Component(组件):附加到实体上的功能模块

  • System(系统):处理特定类型组件的逻辑

5.2 场景与节点

  • Scene(场景):游戏中的一个独立关卡或界面

  • Node(节点):场景中的基本元素,可以包含子节点

5.3 坐标系

Cocos Creator 3.x 使用左手坐标系:

  • X轴:向右为正方向

  • Y轴:向上为正方向

  • Z轴:向外为正方向


6 第一个程序

让我们创建一个简单的Hello World程序来熟悉Cocos Creator 3.x的开发流程。

6.1 创建项目

  1. 打开Cocos Creator

  2. 点击"新建项目"

  3. 选择"Empty 3D"模板

  4. 设置项目名称和路径

  5. 点击"创建"

6.2 创建脚本

assets/scripts目录下创建一个新的TypeScript文件HelloWorld.ts

复制代码
import { _decorator, Component, Node, Label } from 'cc';
const { ccclass, property } = _decorator;
​
@ccclass('HelloWorld')
export class HelloWorld extends Component {
    // 声明一个Label属性,用于显示文字
    @property({ type: Label })
    public label: Label = null!;
​
    // 声明一个字符串属性,用于存储显示的文字
    @property
    public text: string = 'Hello, Cocos Creator 3.x!';
​
    // 生命周期回调:组件激活时执行
    start() {
        // 设置Label的文字内容
        this.label.string = this.text;
        
        // 打印日志
        console.log('Hello World!');
    }
​
    // 生命周期回调:每帧执行
    update(deltaTime: number) {
        // 每帧旋转节点
        this.node.rotate(0, deltaTime * 90, 0);
    }
}

6.3 使用脚本

  1. 在场景中创建一个Canvas节点

  2. 在Canvas下创建一个Label节点

  3. 选中Canvas节点,点击"添加组件"

  4. 选择"自定义脚本" -> "HelloWorld"

  5. 将Label节点拖拽到HelloWorld组件的label属性上

  6. 点击"运行"按钮预览效果


7 总结

通过本章的学习,你应该已经了解了:

  1. 游戏编程的基本概念

  2. Cocos Creator 3.x的主要特点

  3. TypeScript的基础知识

  4. 项目结构和核心概念

  5. 如何创建一个简单的Hello World程序

下一章我们将深入学习Cocos Creator 3.x的入门。

相关推荐
light blue bird1 小时前
MES/ERP 协同场景导入导出图表展示组件
前端·信息可视化·桌面端winform·多节点端·gdi图表绘制开发
周杰伦fans1 小时前
AutoCAD2016经典模式不见了-设置回14版本前的经典工作空间
服务器·c语言·前端
Front思1 小时前
shopify前端开发
前端
风骏时光牛马2 小时前
Julia常见问题汇总与代码示例
前端
ZC跨境爬虫2 小时前
跟着 MDN 学JavaScript day_10:数组——数据的有序集合
android·java·开发语言·前端·javascript
广州华水科技2 小时前
如何利用单北斗变形监测实现大坝安全监测?
前端
hxy06012 小时前
Flutter showModalBottomSheet等弹窗宽度问题
前端·flutter
Wireless_wifi62 小时前
IPQ9574 + WiFi 7: Building the Foundation for Scalable Edge AI Deployments
前端·人工智能·edge