Back to Hmcl

贡献指南

docs/Contributing_zh.md

657.7 KB
Original Source

贡献指南

<!-- #BEGIN LANGUAGE_SWITCHER -->

English | 中文 (简体, 繁體)

<!-- #END LANGUAGE_SWITCHER -->

构建 HMCL

环境需求

构建 HMCL 启动器需要安装 JDK 17 (或更高版本)。你可以从此处下载它: Download Liberica JDK

在安装 JDK 后,请确保 JAVA_HOME 环境变量指向符合需求的 JDK 目录。 你可以这样查看 JAVA_HOME 指向的 JDK 版本:

<details> <summary>Windows</summary>

PowerShell:

PS > & "$env:JAVA_HOME/bin/java.exe" -version
openjdk version "25" 2025-09-16 LTS
OpenJDK Runtime Environment (build 25+37-LTS)
OpenJDK 64-Bit Server VM (build 25+37-LTS, mixed mode, sharing)
</details> <details> <summary>Linux/FreeBSD</summary>
> $JAVA_HOME/bin/java -version
openjdk version "25" 2025-09-16 LTS
OpenJDK Runtime Environment (build 25+37-LTS)
OpenJDK 64-Bit Server VM (build 25+37-LTS, mixed mode, sharing)
</details> <details> <summary>macOS</summary>
> /usr/libexec/java_home --exec java -version
openjdk version "25" 2025-09-16 LTS
OpenJDK Runtime Environment (build 25+37-LTS)
OpenJDK 64-Bit Server VM (build 25+37-LTS, mixed mode, sharing)
</details>

获取 HMCL 源码

  • 通过 Git 可以获取最新源码:
    shell
    git clone https://github.com/HMCL-dev/HMCL.git
    cd HMCL
    
  • GitHub Release 页面可以手动下载特定版本的源码。

构建 HMCL

想要构建 HMCL,请切换到 HMCL 项目的根目录下,并执行以下命令:

shell
./gradlew clean makeExecutables

构建出的 HMCL 程序文件位于根目录下的 HMCL/build/libs 子目录中。

调试选项

[!WARNING] 本文介绍的是 HMCL 的内部功能,我们不保证这些功能的稳定性,并且随时可能修改或删除这些功能。

使用这些功能时请务必小心,错误地使用这些功能可能会导致 HMCL 行为异常甚至崩溃。

HMCL 提供了一系列调试选项,用于控制启动器的行为。

这些选项可以通过环境变量或 JVM 参数指定。如果两者同时存在,那么 JVM 参数会覆盖环境变量的设置。

环境变量JVM 参数功能默认值额外说明
HMCL_JAVA_HOME指定用于启动 HMCL 的 Java仅对 exe/sh 生效
HMCL_JAVA_OPTS指定启动 HMCL 时的默认 JVM 参数仅对 exe/sh 生效
HMCL_FORCE_GPU指定是否强制使用 GPU 加速渲染false
HMCL_ANIMATION_FRAME_RATE指定 HMCL 的动画帧率60
HMCL_LANGUAGE指定 HMCL 的默认语言使用系统默认语言
HMCL_UI_SCALE指定 HMCL 的 UI 缩放比例遵循系统当前的缩放比例支持倍数 (1.5)、百分比 (150%) 或 DPI (144dpi)
-Dhmcl.dir=<path>指定 HMCL 的当前数据文件夹./.hmcl
-Dhmcl.home=<path>指定 HMCL 的用户数据文件夹Windows: %APPDATA%\.hmcl
Linux/BSD: $XDG_DATA_HOME/hmcl
macOS: ~Library/Application Support/hmcl
-Dhmcl.self_integrity_check.disable=true检查更新时不检查本体完整性
-Dhmcl.bmclapi.override=<url>指定 BMCLAPI 的 API Roothttps://bmclapi2.bangbang93.com
-Dhmcl.discoapi.override=<url>指定 foojay Disco API 的 API Roothttps://api.foojay.io/disco/v3.0
HMCL_FONT-Dhmcl.font.override=<font family>指定 HMCL 默认字体使用系统默认字体
-Dhmcl.update_source.override=<url>指定 HMCL 更新源https://hmcl.huangyuhui.net/api/update_link
-Dhmcl.authlibinjector.location=<path>指定 authlib-injector JAR 文件的位置使用 HMCL 内嵌的 authlib-injector
-Dhmcl.openjfx.repo=<maven repository url>添加用于下载 OpenJFX 的自定义 Maven 仓库
-Dhmcl.native.encoding=<encoding>指定原生编码使用系统的本机编码
-Dhmcl.microsoft.auth.id=<App ID>指定 Microsoft OAuth App ID使用 HMCL 内置的 Microsoft OAuth App ID
-Dhmcl.curseforge.apikey=<Api Key>指定 CurseForge API 密钥使用 HMCL 内置的 CurseForge API 密钥
-Dhmcl.native.backend=<auto/jna/none>指定HMCL使用的本机后端auto
-Dhmcl.hardware.fastfetch=<true/false>指定是否使用 fastfetch 检测硬件信息true