8.0 KiB
8.0 KiB
贡献指南
构建 HMCL
环境需求
构建 HMCL 启动器需要安装 JDK 17 (或更高版本)。你可以从此处下载它: Download Liberica JDK。
在安装 JDK 后,请确保 JAVA_HOME 环境变量指向符合需求的 JDK 目录。
你可以这样查看 JAVA_HOME 指向的 JDK 版本:
Windows
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)
Linux/FreeBSD
> $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)
macOS
> /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)
获取 HMCL 源码
- 通过 Git 可以获取最新源码:
git clone https://github.com/HMCL-dev/HMCL.git cd HMCL - 从 GitHub Release 页面可以手动下载特定版本的源码。
构建 HMCL
想要构建 HMCL,请切换到 HMCL 项目的根目录下,并执行以下命令:
./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%\.hmclLinux/BSD: $XDG_DATA_HOME/hmclmacOS: ~Library/Application Support/hmcl |
||
-Dhmcl.self_integrity_check.disable=true |
检查更新时不检查本体完整性 | |||
-Dhmcl.bmclapi.override=<url> |
指定 BMCLAPI 的 API Root | https://bmclapi2.bangbang93.com |
||
-Dhmcl.discoapi.override=<url> |
指定 foojay Disco API 的 API Root | https://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.microsoft.auth.secret=<App Secret> |
指定 Microsoft OAuth App 密钥 | 使用 HMCL 内置的 Microsoft OAuth App 密钥 | ||
-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 |