User Tools

Site Tools


zh_cn:tutorial:primer

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
zh_cn:tutorial:primer [2023/01/12 03:39] – translate tao0luzh_cn:tutorial:primer [2025/11/11 13:04] (current) sinoaakira
Line 1: Line 1:
-====== Minecraft 模组编写基础 ======+~~REDIRECT>https://docs.fabricmc.net/zh_cn/develop/getting-started/introduction-to-fabric-and-modding~~
  
-//注意:本页假定你没有任何编写模组的经验。但是,你应该先会一点 Java 语言以使用 Minecraft(参见“前提”段落)。如果你是从其他模组加载器(如 Forge)来的,可以直接阅读 [[introduction]]。//+====== Minecraft Mod 开发入门 ======
  
-本文档是给模组编写的初学者使用的,比如还不知道 ``BlockState`` 和 ``BlockPos`` 的玩家。如果你编写数据包的经验并想要将技巧提升到更高水平或者需要学习面向对象的语言并开启一个有趣的项目,那么本文档适合首先从你需要了解的几个概念开始:+//注意:本文假设您没任何 Minecraft Mod 制作经验。但是需要熟练掌握 Java 编程语言才能修改 Minecraft 源码 (请参阅“准备工作”部分)。如果您是从其他 Mod Loader (例如 Forge) 转到 Fabric,那么本入门指南的内容可能更适合//
  
-===== Minecraft 模组编写的前提 ===== 
  
-  * 你必须道代码编写基础。如果你从没接触过代码,你应该先知道如何使用代码。这里所说的基础,括变量、函数、类和方法等以及一些面向对象的概念,如继承、多态、类型强转。要是不知道,先搜索。 +本文旨在为那些对“方块位置” (''BlockPos'')和“方块状态” (''BlockState'')一无所知的人提供 Mod 制作的入门指导。如果您有数据制作经验并希望提升技能或者您正在学习面向对象编程语言并希望找到一个有趣项目来辅助学习那么本文正适合您。 
-  * 你应该要有一些编程语言的经验例如 Java、C、C++ 和 C#。Java 的语法和 C 系列的比较类似。 +首先让我们从您需要事先了解内容开始:
-  * 熟悉 Java 的语法例如 lambda 方法、泛型(你应该知道这些是什么),以及一些语法糖,这些语法应该会在学习时候一并遇到。 +
-  * 你必须知道如何使用 Internet 查找问题与答案,以及如何在网络论坛或者群里提问求助。+
  
-===== 模组编写是什么? =====+===== Mod 制作是什么?=====
  
-模组编写(Modding)是指的往程序的源代码里面**添**或**修改**内容这个程序指的 Minecraft。你制作的所有模组需要增添或者修改内容+Mod 制作是指程序进行**功能**或**修改**的过程;在本文中程序是 Minecraft。你制作的所有 Mod 至少会进行其中一项操作
  
-===== Fabric 是什么? =====+===== Fabric 是什么?=====
  
-Fabric 是一系列用于编写 Minecraft 模组的工具,包括:+Fabric 是一工具可以方便地制作 Fabric Mod 对 Minecraft 进行修改。这些工具包括:
  
-  * **Fabric Loader**-- 基于 Java 的游戏如 Minecraft)加载修改后的代码的框架。 +  * **Fabric Loader**-- 一个用于将修改后的代码加载到基于 Java 的游戏 (例如 Minecraft) 中的框架。 
-  * **Fabric Loom**,用于使用 Fabric 编写模组的构建系统 +  * **Fabric Loom**-- 一个专为使用 Fabric 进行 Mod 制作而设计的构建系统 
-  * Fabric 的 **语言模块** 允许你使用其他的 JVM 语言例如 Kotlin 或 Scala来编写你的模组。注意:建议初学者还是先从 Java 开始,因为 Minecraft 就是用这种语言编写的,Java 也是最容易寻求帮助的。 +  * Fabric 的 **编程语言模块** 允许你使用其他 JVM 语言 (例如 Kotlin 或 Scala来编写你的 Mod。注意:建议初学者从 Java 入手,因为 Minecraft 就是用 Java 编写的,而且 Java 也是最容易找到相关帮助的 JVM 语言。 
-  * **Fabric API**-- 一系列能让添加或修改 Minecraft 共同特性更简单的工具。 +  * **Fabric API**-- 一套可以更轻松地添加或修改某些常见 Minecraft 功能的工具。 
-  * **Fabric Installer**-- 将 Fabric Loader 安装到最终用户的 Minecraft 安装的工具。+  * **Fabric 安装程序**-- 一款可以将 Fabric Loader 安装到用户的 Minecraft 系统中的工具。
  
-为了更好的理解 Minecraft 的代码干了什么,当使用 Fabric 进行模组编写时,你有机会接触到 Minecraft 的源代码。由于 Java 是编译型语言,我们需要反编译来获得我们懂的代码。这一过程会将它从 Java 字节码转为人类可读的 Java 源代码。然而,为了盗版,Mojang  **混淆** 了 Minecraft 的代码。这意味着代码中所有类、方法和字段的名称是随机的。可以通过 zip 解压工具打开 Minecraft 的 .jar 文件亲眼看到这一点 —— 所有文件都会以类似 ''abc.class'' 的形式出现此外我们无法保证两个版本同一对象拥有相同的名称 —— 可能个版本还是 ''abc''个版本就是 ''adb'' 所以这使得在不知道对象名称的情况下修改游戏十分困难,因为我们无法知道不同变量的作用。为了解决这个问题,Fabric 使用了一套映射工具来给所有东西起一个人类可读的名称。+为了更轻松地理解 Minecraft 的代码,当使用 Fabric 进行 Mod 制作时,您将能够访问 Minecraft 的源代码。由于 Java 是一种编译型语言,我们需要反编译代码才读。这会将 Java 字节码转为人类可读的 Java 源代码。然而,为了逆向工程,Mojang **混淆**格式分发 Minecraft。这意味着代码中所有类、方法和变量的名称是随机生成的。可以解压工具打开一个 Minecraft 的 .jar 文件来验证这一点——所有文件的名称都类似于 ''abc.class''更糟糕的是,无法保证同一对象在不版本中的名称相同——可能在一个版本中名为 ''abc''而在另一个版本中则可能名为 ''abd''。这使 Mod 制作变非常困难,因为没有名称,就很难区分不同变量的作用。为了解决这个问题,Fabric 使用了一套**映射**工具,为所有物品赋予一个易于理解的名称。((注:虽然 Mojang 为所有 Minecraft 版本发布了官方映射表,但未来在 Mod 中使用这些映射的合法性可能会发生变化。Yarn 映射表是自由的,任何人都可以使用,并且足以满足大多数 Mod 制作的需求,因此不建议使用官方映射。))
  
-  * **中介**映射器是一个程序,它会给予 Minecraft 码中所有被混淆的对象一个名称,类似 “field_10832” 和 “method_12991()”。关键的是,这个程序将总是给予一个对象相同的名称,所以一个在不同版本之间没有的方法将会拥有相同的中名称。+  * **Intermediary** 映射器是一个程序,它会给 Minecraft 码中的每个对象赋予一个类似“field_10832”“method_12991()”的名称。关键在于,这个程序始终为每个对象赋予相同的名称。因此,在不同版本之间保持不变的方法,其 Intermediary 名称也始终保持不变。 
 +  * **Yarn** 反混淆过程最后一步,它从 Intermediary 映射器的产物为 Minecraft 的所有方法和类命名。当您查看 Minecraft 的“源代码”时,您发现的任何带有描述其功能名称的类、变量或方法都是 Yarn 生成的。Yarn 社区成员分析并决定了它们的命名。每次发布新的更新或快照版本时,社区都会着手梳理代码,看看哪些新对象需要命名
  
-  * **Yarn** 是反混淆过程中的最后一步。Yarn 是一个自由的、开源的社区驱动的 Minecraft 中所有方法和类的名称库。当你看 Minecraft 的源代码时,对于任何类、变量或方法,描述其作用的名称都是由 Yarn 编写的。社区中会有人分析并决定为其命名。每次有新的更新或快照出现时,社区就会开始工作,梳理代码,看看有哪些新的对象需要命名。((注意:虽然 Mojang 发布了所有 Minecraft 版本的官方映射,但在模组编写中使用这些映射的合法性在未来可能会改变。而 Yarn 映射是自由的,每个人都可以使用,并且足以满足大多数模组编写的目的,所以不鼓励你使用官方的映射。)) +然而,并非 Minecraft 中所有内容被 Yarn 映射——有时会看到一些变量仍然使用 Intermediary 名称。如果弄清楚了它们的作用,可以为 Yarn 贡献一个名称((关于官方映射的另一说明:请勿参考官方映射来获取 Yarn 映射方面的帮助。这很可能违反知识产权法——**所有 Yarn 映射必须是原创的,并且独立于官方映射。**)有关使用和贡献映射的更多信息,请查看 [[mappings]] 页面))
- +
-但是,在反编译的 Minecraft 代码库,并不是所有的对象都被 Yarn 映射了 —— 有时会看到一些变量仍然有中介名称。如果弄清楚了它们的作用,可以为 Yarn 贡献一个名称((关于官方映射的另一说明:不要向官方映射咨询 Yarn 映射的帮助。这很可能违反知识产权法 —— **所有的 Yarn 映射必须是原创的,并且独立于 Mojang 的。**))。查看 [[mappings]] 页面,了解更多使用和贡献映射的信息。+
  
 ===== 代码结构 ===== ===== 代码结构 =====
  
-Minecraft Java 版 是一个巨大的项目,多年来的代码都是建立在彼此之上的。它可能看起来很混乱因为它就是的),但有几个关键概念是部分)一致的,贯穿始终。+MinecraftJava Edition 是一个巨大的项目,它凝聚了多年来层层叠加的代码。它看起来可能很混乱 (因为它确实很混乱),但有一些关键概念是 (概) 贯穿始终的。 
 + 
 +==== 注册表 ==== 
 + 
 +Minecraft 中的大多数“功能” (你可能想要添加的东西,例如方块、物品、界面、实体、区块生成器等等) 会在游戏加载时加载到对应的注册表中。例如,每个物品 (''Item'') 都有一个静态实例,该实例在游戏启动时初始化并放入物品注册表中。游戏使用该实例来确定该物品的物品栈 (''ItemStack'',您背包中物品的内存表示) 的属性。**如果您向游戏中添加了内容,您很可能需要注册它。** 然而,也有例外:Minecraft 中的某些功能是**数据驱动的**,这意味着它们可以完全用数据(而不是代码)来定义。如果您曾经好奇为什么数据包可以添加某些内容而不能添加其他内容,原因就在这里:数据包只能添加数据驱动的内容。Minecraft 中数据驱动的内容包括生物群系、材质、*某些*区块生成器和合成配方。当加载包含数据包的世界时,游戏会自动将这些特性添加到仅在该世界加载期间使用的特殊临时注册表中。如果您之前开发过数据包,则可以轻松地将数据包集成到您的 Mod 中,从而简化某些内容的创建。您甚至可以添加自己的数据驱动内容,供其他人使用编解码器为其创建数据包
  
-=== 注册表 ===+==== 端 ====
  
-很多游戏中(方块、物品、UI、实体、区块生成器等的)特性(你想添加的)在游戏被加载时候将会被加载进注册表比如,每一个''物品''类型都有一个静态的实例,这些实例将在游戏开的时候被初始化,接着就会被加载进物品类型的注册表。游戏使用这些实例去获取物品类型的 ''ItemStack''(所持有物品物品栏中内存表示)属性。**如果你要添加一些对象到游戏内你可能需要注册它**然而,这条规定也有例外:Minecraft 中的一些功能是**数据驱动的**,这意味着它们可以纯粹地数据(而不代码)来定义。如果你想知道为什么数据包可以添加一些对而有些对象不行,这就是原因:数据包只能添加数据驱动内容。例如在 Minecraft 中,数据驱动的内容包括生物群落、纹理、*一些*区块生成和制作配方。当一个带有数据包的世界被加载时,游戏会自动将这些功能添加到个特殊的暂存器中,只会该世界被加载完毕后使用。如果你以前开发过数据包,你可以非常容易地将数据包整合到你模组中这使得一些内容更容易创建你甚至可以添加你自己数据驱动规则,从而其他人可以使用 Codecs 为其制作数据包+Minecraft 处理分为两个线程,通常称为:服务端和客户端客户端终运行玩家计算机上负责渲染和输入服务端可以独立运行,作为专服务器 (可能您印Minecraft 服务”)或者在单人游戏中与客户端起运行玩家计算机上作为集成服务器服务端处理客户端不负责所有事情——物品栏、世界本身等等
  
-=== 端 ===+客户与服务端必须就某些事项达成一致:世界中有哪些方块、箱子里有什么、玩家位置等等。由于这些由服务端处理,因此服务端会将这些值告知客户端,客户端再将这些值显示给玩家。任何由客户端处理的内容都不需要告知服务端——这包括方块和实体的外观 (资源包) 以及如何绘制世界 (着色器)。这就是客户端 Mod (例如着色器)、服务端 Mod (例如运行小游戏的 Mod) 和双端 Mod (例如添加机器、新方块和新物品的 Mod) 之间的区别。
  
-Minecraft 运行在两个线程上,通常称为 "端":服务器端和客户端。客户端总是运行在玩家的电脑上,处理渲染和输入。服务器端可以在专用服务器上独立运行(你可能认为是“Minecraft 服务器”),或者在单人游戏中,与客户端一起在玩家的计算机上运行,作为一个集成服务器。服务器端处理客户端没有处理的一切 —— 物品栏、世界本身,等等。客户端和服务器端必须就某些事情达成一致:世界上有哪些区块,箱子里有什么,玩家的位置等等。由于这些都是由服务器端处理的,所以它向客户端规定这些值应该是什么,而客户端则向玩游戏的人展现这些值。任何由客户端处理的东西都不需要告诉服务器 —— 这包括区块和实体的样子(资源包),以及如何绘制世界(着色器)。这就是客户端模组(如着色器)、服务器端模组(如那些运行小游戏的模组)和双方模组(那些添加机器或新方块和物品的模组)之间的区别。重要的是,不要在服务调用只针对客户端的代码即与渲染而在客户端调用只针对服务端的代码。这就是你在 Minecraft 模组制作中经常看到的无处不在的 ''world.isClient()'' 检查的原因+重要的是,不要在服务端调用仅供客户端使用的代码 (即与渲染的代码)也不要将仅供服务端使用的代码放在客户端。这就是你在 Minecraft Mod 中经常看到的无处不在的 ''world.isClient()'' 检查的目的
  
-===== 下一步 =====+===== 后续骤 =====
  
-一旦你达到了先决条件并阅读本文档,就可以开始了!查看 [[introduction]] 介绍以更深入了解 Fabric 这个平台,阅读 [[setup]] 文档设置 IDE 来修改 Minecraft,然后前往 [[items]] 教程添加第一个物品!+完成所有准备工作并阅读本文档,就可以开始了!查看 [[introduction]] 了解 Fabric 平台的方方面面,阅读 [[setup]] 文档设置 IDE 以进行 Minecraft Mod 制作,然后前往 [[items]] 教程添加您的第一个物品!
  
zh_cn/tutorial/primer.1673494794.txt.gz · Last modified: 2023/01/12 03:39 by tao0lu