Настройка рантайма
Описание рантайма
Рантайм в Лаунчере — это модуль для Лаунчера и набор ресурсов (fxml/css/png), отвечающие за взаимодействие с пользователем. Рантайм основан на JavaFX.
Полезные ссылки:
- Scene Builder — Редактор FXML файлов
- OpenJFX API Docs — Документация JavaFX API
- JavaFX CSS Reference Guide — Документация JavaFX CSS
Настройка рантайма
В этом разделе вы найдете полезные функции, входящие в рантайм "из коробки", но не включенные по умолчанию
Шифрование рантайма
- Скачайте библиотеку EnFS и положите её в папку launcher-libraries
- Включите опцию
encryptRuntime
в конфигурации ЛаунчСервера и сделайтеbuild
- Проверьте правильность работы
Скачивание своей Java
- Скачайте архивы с JRE/JDK с Adoptium или другого поставщика сборок OpenJDK
- Распакуйте архивы в папку updates и дайте им понятные названия:
java17-windows-x86-64
,java17-windows-x86
и т.д. - По желанию удалите из сборок JRE/JDK необязательные компоненты для уменьшения объема скачиваемых данных
- Откройте файл
config/JavaRuntime/Config.json
в текстовом редакторе, найдите строку "javaList": {} и приведите её к такому виду:
Пример для JRE Standart 8, 11, 17 версии от BellSoft
"javaList": {
"java8-windows-x86": "Java 8 b392 mustdie X86 javafx false",
"java8-windows-x86-64": "Java 8 b392 mustdie X86_64 javafx false",
"java8-linux-64": "Java 8 b392 linux X86_64 javafx false",
"java8-linux-arm-64": "Java 8 b392 linux ARM64 javafx false",
"java8-macosx-64": "Java 8 b392 macosx X86_64 javafx false",
"java8-macosx-arm-64": "Java 8 b392 macosx ARM64 javafx false",
"java11-windows-x86": "Java 11 b18 mustdie X86 javafx false",
"java11-windows-x86-64": "Java 11 b18 mustdie X86_64 javafx false",
"java11-windows-arm-64": "Java 11 b18 mustdie ARM64 javafx false",
"java11-linux-x86": "Java 11 b18 linux X86 javafx false",
"java11-linux-x86-64": "Java 11 b18 linux X86_64 javafx false",
"java11-linux-arm-64": "Java 11 b18 linux ARM64 javafx false",
"java11-macosx-64": "Java 11 b18 macosx X86_64 javafx false",
"java11-macosx-arm-64": "Java 11 b18 macosx ARM64 javafx false",
"java17-windows-x86": "Java 17 b6 mustdie X86 javafx false",
"java17-windows-x86-64": "Java 17 b6 mustdie X86_64 javafx false",
"java17-windows-arm-64": "Java 17 b6 mustdie ARM64 javafx false",
"java17-linux-x86": "Java 17 b6 linux X86 javafx false",
"java17-linux-x86-64": "Java 17 b6 linux X86_64 javafx false",
"java17-linux-arm-64": "Java 17 b6 linux ARM64 javafx false",
"java17-macosx-64": "Java 17 b6 macosx X86_64 javafx false",
"java17-macosx-arm-64": "Java 17 b6 macosx ARM64 javafx false",
"java21-windows-x86": "Java 21 b6 mustdie X86 javafx false",
"java21-windows-x86-64": "Java 21 b6 mustdie X86_64 javafx false",
"java21-windows-arm-64": "Java 21 b6 mustdie ARM64 javafx false",
"java21-linux-x86": "Java 21 b6 linux X86 javafx false",
"java21-linux-x86-64": "Java 21 b6 linux X86_64 javafx false",
"java21-linux-arm-64": "Java 21 b6 linux ARM64 javafx false",
"java21-macosx-64": "Java 21 b6 macosx X86_64 javafx false",
"java21-macosx-arm-64": "Java 21 b6 macosx ARM64 javafx false"
},
"forceDownloadJava": true,
для скачивания принудительно только с вашего ЛаунчСервера
Формат записи:
Java {номер версии} b{номер сборки} {mustdie (это windows)/linux/macosx} {архитектура} javafx {наличие javafx}
Архитектуры:
- X86_64 (Intel/AMD 64 бит)
- X86 (Intel/AMD 32 бит)
- ARM32 (32 разрядные ARM)
- ARM64 (64 разрядные ARM)
- Добавьте названия ваших папок с JRE/JDK в "protectHandler": {} конфигурации ЛаунчСервера LaunchServer.json
"allowUpdates": [
"java8-windows-x86", "java8-windows-x86-64",
"java8-linux-64", "java8-linux-arm-64",
"java8-macosx-64", "java8-macosx-arm-64",
"java11-windows-x86", "java11-windows-x86-64", "java11-windows-arm-64",
"java11-linux-x86", "java11-linux-x86-64", "java11-linux-arm-64",
"java11-macosx-64", "java11-macosx-arm-64",
"java17-windows-x86", "java17-windows-x86-64", "java17-windows-arm-64",
"java17-linux-x86", "java17-linux-x86-64", "java17-linux-arm-64",
"java17-macosx-64", "java17-macosx-arm-64",
"java21-windows-x86", "java21-windows-x86-64", "java21-windows-arm-64",
"java21-linux-x86", "java21-linux-x86-64", "java21-linux-arm-64",
"java21-macosx-64", "java21-macosx-arm-64"
],
Инструкция с предподготовленными сборками джав
- Джавы не содержат JavaFX, являются минимальными для клиентов
- Если у вас уже есть с другой версией джавы, удалите их в
updates
- Разделы выше сделаны как пример и подходят для данных сборок
cd updates
wget https://mirror.gravit-support.ru/unofficial/jvm/jre-standart-8u392%2B9.zip ;
wget https://mirror.gravit-support.ru/unofficial/jvm/jre-standart-11.0.21%2B10.zip ;
wget https://mirror.gravit-support.ru/unofficial/jvm/jre-standart-17.0.9%2B11.zip ;
wget https://mirror.gravit-support.ru/unofficial/jvm/jre-standart-21.0.1%2B12.zip ;
unzip jre-standart-8u392+9.zip ;
rm -f jre-standart-8u392+9.zip ;
unzip jre-standart-11.0.21+10.zip ;
rm -f jre-standart-11.0.21+10.zip ;
unzip jre-standart-17.0.9+11.zip ;
rm -f jre-standart-17.0.9+11.zip ;
unzip jre-standart-21.0.1+12.zip ;
rm -f jre-standart-21.0.1+12.zip
- Выполните
syncup
иbuild
- Проверьте правильность работы
Структура рантайма
Файловая структура:
images
— папка, которая содержит все картинкиoverlay
— папка, в которой находятся оверлеи. Каждому оверлею выдается отдельная папка, в которой должны лежать fxml и css файлы. Допускается рядом с fxml и css размещать картинки, специфичные для конкретного оверлея.scenes
— папка, аналогичная по своей структуре папке overlay, но предназначена для сцен.components
— папка, в которой находится дизайн отдельных частей (как serverButton и уведомления).dialogs
— папка, в которой находится дизайн диалогов.styles
— папка с css стилями.runtime_*.properties
— собранные файлы локализации.
Основные сущности:
Stage
— окно. Эта сущность отвечает за иконку, параметры окна и его названиеScene
— содержимое окна. Является корнем всех объектов и не может быть встроена куда либоOverlay
— кастомное содержимое, наложенное на сцену. При отображении оверлея сцена размывается и блокируется, пока открыт оверлейComponent
— содержимое, не привязанное к чему—либо. Компонент может существовать в нескольких экземплярах одновременно, чем и отличается от сцен и оверлеев
Для редактирования файлов fxml вам понадобится программа JavaFX SceneBuilder, которую вы можете скачать с любого удобного для вас сайта
После чего открываете интересующий вас fxml файл, заходите в Preview -> Internationalization -> Set Resourse и выбираете файл runtime_*.properties
Для редактирования текста вам понадобится папка compat, в которой находятся оригинальные .properties файлы. Изменять напрямую файлы runtime_*.properties из папки runtime нельзя (не будет работать русский язык)
После того, как вы изменили текст в compat файлах, воспользуйтесь утилитой native2ascii для приведения в понятный рантайму вид, которая идет в любом JDK.
Объекты рантайма
JavaFXApplication
— основной класс рантайма, точка доступа к всем компонентам и управлению приложением.
FXMLLoader
— асинхронный многопоточный загрузчик fxml, обеспечивает ускорение запуска и поддержку мультиязычности
StateService
— точка обмена данными и состоянием Лаунчера
RuntimeSecurityService
— выполняет обмен ключами с ЛаунчСервером, сбор HardwareInfo (HWID) и обновление Лаунчера
MessageManager
— отображает уведомления и диалоги
Работа с .properties и перевод на другие языки
Вы можете перевести Лаунчер на любой другой язык, добавив его в список языков в файле RuntimeSettings.java. Для этого добавьте в enum LAUNCHER_LOCALE свой язык.
Первый параметр — 2–3 буквы страны, которые будут использоваться для поиска .properties файла.
Второй параметр — отображаемое имя в всплывающем окне выбора языков.
Помимо надписей .properties, файлы поддерживают изменение любых свойств JavaFX, в том числе размеры и расположение элементов, пути до картинок, параметры объектов и вообще любые свойства, которые вы можете указать в .fxml файле
Кастомные serverButton
Вы можете использовать под каждый профиль, собственные serverButton
.
Для этого, в папке components
создайте папку serverButton
(регистр важен)
Cкопируйте туда файл serverButton.fxml
, переименовав его в PROFILE_UUID.fxml
,
где PROFILE_UUID
- UUID
вашего профиля, для которого вы делаете serverButton
Обратите внимание:
Так как папка теперь не components
, а components/serverButton
, в вашем fxml, необходимо изменить пути к некоторым файлам/папкам:
"@../../images/servers/example.png"
вместо "@../images/servers/example.png"
(где example.png
- изображение на serverButton
)
"@../components.css"
вместо "@components.css"
"@../../styles/global.css"
вместо "@../styles/global.css"
"@../../styles/variables.css"
вместо "@../styles/variables.css"
ProfileWhitelist профиля клиента
Позволяет скрыть клиент от всех пользователей, кроме записанных в profileWhitelist
В профиле клиента установите "limited": true,
В конфиге LaunchServer.json
:
"protectHandler": {
"profileWhitelist": {"TITLE ПРОФИЛЯ": ["Ник1", "Ник2"]},
Отладка рантайма
Для отладки рантайма из IDEA войдите в Run -> Edit configurations
и создайте новый Application
с такими параметрами:
- Модуль:
JavaRuntime.main
- Аргументы jvm:
-Dlauncherdebug.modules=pro.gravit.launcher.client.JavaRuntimeModule
(если параметры не отображаются, нажмитеModify Options —> Add VM options
) - Main Class:
pro.gravit.launcher.debug.DebugMain
Ограничения отладочного режима:
- Не будет работать опция "Сохранить пароль", так как ключ шифрования пароля внедряется ЛаунчСервером
- Невозможно запустить клиент Minecraft (при этом все этапы скачивания, проверки и подготовки к старту будут работать)
- Лаунчер не будет пытаться обновиться и получить список методов авторизации
- Может не работать проверка HWID, так как ЛаунчСервер не будет доверять Лаунчеру
- Отладочный режим невозможно активировать на уже собранном Лаунчере
- Никакие настройки модулей для Лаунчера из папки
config
не будут работать