在这里,我们概述了这个项目使用的工具链与运行时。
对于整个项目,我们有:
- Node.js >=18.17.0. 核心库基础环境。
- Electron 27. 启动器实际的运行时。
- pnpm. 用于 monorepo 包管理。
- TypeScript. 整个项目将尽可能使用 TypeScript 代码。
对于主进程(Electron),我们使用:
- esbuild. 使用 esbuild 来构建主进程的 TypeScript 代码。
对于渲染侧,这是纯前端的技术栈:
- Vue. 用于构建用户界面。
- Vite. 用作我们的构建工具。
- Vuetify. 用作我们的组件库。
- Windi CSS. 用作 CSS 工具
- Vue Composition API. Vue 2 的组合式 API 的桥梁。一旦 Vuetify 升级到 Vue 3,这将被删除。
- xmcl
- 链接指向的 git 仓库 launcher-core 是本项目的一个子模块。
- 实现核心 Minecraft 安装和启动逻辑,并将它们作为库暴露出来。
- xmcl-electron-app
- 用 Electron 实现运行时。
- 它依赖 xmcl-runtime。
- 它的部分内容依赖 xmcl-keystone-ui(临时的,可能将在未来被删除)
- xmcl-keystone-ui
- 启动器的默认 UI。
- 100% 兼容浏览器,此项目中不涉及 Electron 的 API。
- xmcl-runtime
- 启动器架构的核心实现。它只依赖 Node.js,不需要 Electron 运行时。
- xmcl-runtime-api
- 这是 XMCL 运行时的共享代码与 API。它可用于渲染器应用程序(浏览器侧)
启动器由“服务器/客户端”或“主/渲染器”组成。它们通过 Electron 的 ipcMain 与 ipcRenderer 相互通信。
主进程 main 是启动器的“后端”。它管理窗口以及应用程序的所有持久数据与状态。它通过 Vuex 管理状态。一旦 Vuex 修改了状态/数据,它将广播一条 IPC 消息,其中包含所有渲染器的变化信息。同时会触发修改模块的保存动作,将修改写入磁盘。
渲染器只是与主进程通信的浏览器,它包含一份存储数据的副本(可以是完整的副本,也可以是只有部分内容的副本),用户的输入将触发一个 动作 action 或 提交 mutations,它将自动同步到主进程。因此,不需要开发人员采取任何额外的行动。本地提交和操作将自动发送到主进程。完全可以把渲染器当作普通的 Vue 应用。
如果你对特定的页面逻辑感兴趣,你可以看看 xmcl-keyston-ui/src/windows/main/views
。这个文件夹下的 .vue
文件是启动器中使用的主要组件。文件的前缀是用户界面的关键字。
请看一些例子:
AppSideBar.vue
是侧边栏组件,AppSideBarInstanceItem.vue
是AppSideBar.vue
中使用的组件,代表一个实例。Curseforge.vue
是 CurseForge 页面组件,CurseforgeCategories.vue
是Curseforge.vue
页面中使用的类别卡。
如果你对核心逻辑感兴趣,你可以看看 xmcl-runtime/services/
。它下面的每个文件都将一个特定领域/业务的逻辑封装成了“服务”。在阅读服务的过程中,你也需要看看 xmcl-runtime-api/services/
下的对应的服务声明。
一些例子:
xmcl-runtime/services/InstanceService.ts
包含添加/删除/更新实例的 API 实现。xmcl-runtime-api/services/InstanceService.ts
包含了InstanceService
的接口。xmcl-runtime/services/InstanceVersionService.ts
包含检查实例版本健康状况的 API 实现。它将确定实例将使用什么版本,以及我们是否应该安装该版本。xmcl-runtime/services/InstallService.ts
包含安装 Minecraft/Forge/Fabric 等的API实现。xmcl-runtime/services/LaunchService.ts
包含启动实例的 API 实现。
我们强烈建议您使用 VSCode 打开项目。
用 git 克隆项目,需要使用 --recurse-submodules
选项:
git clone --recurse-submodules https://github.com/Voxelum/x-minecraft-launcher
如果您忘记添加 --recurse-submodules
标志,则需要手动初始化和更新 git 子模块:
git submodule init
git submodule update
使用 pnpm 安装项目:
pnpm install
解决中国国内安装依赖(如 Electron)太慢的办法
打开您的 git bash,在 pnpm i
前面加上 registry=https://registry.npm.taobao.org electron_mirror="https://npm.taobao.org/mirrors/electron/"
。使用国内阿里提供的 npm 以及 Electron 的镜像。
最终输入的 command 也就是
registry=https://registry.npm.taobao.org electron_mirror="https://npm.taobao.org/mirrors/electron/" pnpm i
在xmcl-electron-app
下创建.env
文件来设置CURSEFORGE_API_KEY
。.env
文件已被添加到.gitignore
文件中。
请注意保护好你的 CURSEFORGE API KEY
现在你可以运行开发版启动器了
进入 Run and Debug
菜单,使用配置文件 Electron: Main (launch) 来启动 Electron。(热键 F5)
打开任一终端,执行命令:
# 开启一个 UI 的 dev server
npm run dev:renderer
打开另一终端,执行命令:
# 开始监听主进程
npm run dev:main
当你改了代码后,如何把把更新应用到正在跑的启动器中呢?
Vite 提供热重载,它会自动更新。如果出现问题,您可以通过 Ctrl+R
刷新浏览器。
如果您使用 VSCode 启动启动器,则在更改代码后,您可以点击 VSCode 调试器上的 reload
按钮。
如果您不使用 VSCode 启动,则应该关闭 Electron 并重新启动。
启动器核心位于用 TypeScript 编写的单独项目中。
如果您发现任何与之相关的问题,请在此开启一个 Issue。
- 在
src/renderer/composables
文件夹中为 hook 函数创建一个新文件,并通过src/renderer/composables/index.ts
导出 hook 函数。- 将 Vuex 操作包装在 hook 函数中。
- 通过
import { yourHook } from '/@/composables'
在你的 Vue 文件中导入你的 hook 函数, - 在 Vue 文件中使用钩子访问 Vuex ,而不是直接访问 Vuex。
该项目包含了针对 VSCode 调试器的配置。您可以在线添加断点并进行调试。目前,VSCode 调试器方法仅支持在主进程上进行调试。
(无论如何,您都可以使用 Chrome DevTools 进行渲染进程)
我们现在有两个选择:
- Electron: 主进程(启动)
- Electron: 主进程 (附加方式)
如果您使用第一种方式启动,它会自动将调试器附加到实例。
该项目遵循 Conventional Commits。简而言之,提交信息的第一行应该是:
commit type: commit description
有几种可用的提交类型:feat
, fix
, refactor
, style
, docs
, chore
, test
.
参考自 这个gist:
feat: (new feature for the user, not a new feature for build script)
fix: (bug fix for the user, not a fix to a build script)
docs: (changes to the documentation)
style: (formatting, missing semi colons, etc; no production code change)
refactor: (refactoring production code, eg. renaming a variable)
test: (adding missing tests, refactoring tests; no production code change)
chore: (updating grunt tasks etc; no production code change)
如果您不遵守这些规则,您的提交将被拒绝。
现在的启动器使用 2 个命令来构建
首先你需要先编译前端的代码
pnpm build:renderer
除非你在 xmcl-keystone-ui
有新的改动,你已经不需再重新跑这个命令了。
然后你需要构建 Electron,将你刚刚构建的前端代码和 Electron 打包到一起
pnpm build:all
如果你需要构建一个 debug 的版本用于临时 debug,你可以使用 pnpm build:dir
。它只会产生一个包含启动器程序文件夹输出(不用打包很多其他格式了)。