Compare commits

...

16 Commits

Author SHA1 Message Date
Martin Prokoph
e022fd1827 chore: bump version 2025-05-24 11:25:41 +02:00
Martin Prokoph
fbecfd5642 Merge pull request #346 from Hedwig7s/architectury-1.21
Fix Network Protocol Error when joining server on NeoForge
2025-05-24 11:21:06 +02:00
Martin Prokoph
036be42bec fix: camera randomly stops working 2025-05-24 11:18:01 +02:00
Martin Prokoph
4cfee5ba2e fix: working touchscreen camera 2025-05-19 14:12:10 +02:00
Hedwig7s
d753641fa9 Fix #326 2025-04-30 19:27:15 +02:00
Martin Prokoph
b96547dafb Merge pull request #319 from FlocosDEV/architectury-1.21
Create pt-br.json
2024-12-06 21:00:56 +01:00
Martin Prokoph
afb80fd89c Merge pull request #316 from Kichura/architectury-1.21
Replace Java 16/17 -> 21, Upgrade workflow system
2024-12-04 13:44:12 +01:00
Gabriel
b835a6c4ca Create pt-br.json
Create pt-br.json
2024-11-19 21:36:33 -03:00
Martin Prokoph
1aa449b5bd Release 1.10.0 as stable
Identical to rc2 :)
2024-11-12 13:52:46 +01:00
Kichura
35ab81f696 Apply "chmod +x" to gradlew. 2024-10-30 19:44:35 +01:00
Kichura
e08547a641 Ensure fabric requests end-user to use Java 21 instead. 2024-10-29 23:02:21 +01:00
Kichura
c93cc729f4 Upgrade the entire workflow system. 2024-10-29 22:57:47 +01:00
Kichura
1595fffc2c Change Java version reference to 21. 2024-10-29 22:52:02 +01:00
Martin Prokoph
953df7a8c4 Update MidnightLib & Fix various CompatHandlers 2024-10-20 17:21:40 +02:00
Martin Prokoph
a3b8d7cbb5 Various fixes
- Fix #309 (Missing translations)
- Fix controller input always being read
- Improved injection of options button (Closes #305)
2024-10-20 16:59:26 +02:00
Martin Prokoph
929639c081 Fix packets not being optional on Neoforge 2024-10-11 00:02:59 +02:00
19 changed files with 323 additions and 100 deletions

25
.github/workflows/build.yml vendored Normal file
View File

@@ -0,0 +1,25 @@
name: Build with Gradle
on: [ push, pull_request ]
jobs:
build:
runs-on: ubuntu-24.04
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Validate Gradle Wrapper
uses: gradle/actions/wrapper-validation@v3
- name: Set up JDK 21
uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: 21
check-latest: true
- name: Build with Gradle
run: ./gradlew build
- name: Upload artifacts to GitHub
uses: actions/upload-artifact@v4
with:
name: MidnightControls-Artifacts
path: /build/libs/

View File

@@ -1,23 +0,0 @@
name: Gradle Build
on: [ push, pull_request ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 16
uses: actions/setup-java@v1
with:
java-version: 16
server-id: github # Value of the distributionManagement/repository/id field of the pom.xml
settings-path: ${{ github.workspace }} # location for the settings.xml file
- name: Build with Gradle
run: ./gradlew build
- uses: actions/upload-artifact@v2
with:
name: Artifacts
path: ./build/libs/

View File

@@ -1,23 +0,0 @@
name: Gradle Build
on:
release:
types:
- published
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 16
uses: actions/setup-java@v1
with:
java-version: 16
server-id: github # Value of the distributionManagement/repository/id field of the pom.xml
settings-path: ${{ github.workspace }} # location for the settings.xml file
- name: Build with Gradle
env:
MODRINTH_TOKEN: ${{ secrets.MODRINTH_TOKEN }}
run: ./gradlew publishModrinth

40
.github/workflows/gradlepublish.yml → .github/workflows/publish.yml vendored Executable file → Normal file
View File

@@ -1,30 +1,24 @@
name: Gradle Package
name: Publish to Modrinth
on:
push:
tags:
- '*'
release:
types:
- published
jobs:
build:
runs-on: ubuntu-latest
publish:
runs-on: ubuntu-24.04
steps:
- uses: actions/checkout@v2
- name: Set up JDK 16
uses: actions/setup-java@v1
- name: Checkout Repository
uses: actions/checkout@v4
- name: Validate Gradle Wrapper
uses: gradle/actions/wrapper-validation@v3
- name: Set up JDK 21
uses: actions/setup-java@v4
with:
java-version: 16
server-id: github # Value of the distributionManagement/repository/id field of the pom.xml
settings-path: ${{ github.workspace }} # location for the settings.xml file
- name: Build with Gradle
run: ./gradlew build
- uses: actions/upload-artifact@v2
with:
name: Artifacts
path: ./build/libs/
distribution: 'temurin'
java-version: 21
check-latest: true
# The USERNAME and PASSWORD need to correspond to the credentials environment variables used in
# the publishing section of your build.gradle
- name: Publish to GitHub Packages and other Mavens
@@ -38,3 +32,7 @@ jobs:
midnightcontrols_MAVEN: ${{ secrets.MAVEN_URL }}
MAVEN_USERNAME: ${{ secrets.MAVEN_USERNAME }}
MAVEN_PASSWORD: ${{ secrets.MAVEN_PASSWORD }}
- name: Publish to Modrinth
env:
MODRINTH_TOKEN: ${{ secrets.MODRINTH_TOKEN }}
run: ./gradlew publishModrinth

View File

@@ -8,7 +8,7 @@
[![Version](https://img.shields.io/github/v/tag/TeamMidnightDust/MidnightControls?label=version&style=round)](https://github.com/TeamMidnightDust/MidnightControls/releases)
![Environment: Client](https://img.shields.io/badge/environment-client-1976d2?style=round)
[![Mod loader: Quilt/Fabric]][Quilt]
[![Java 17](https://img.shields.io/badge/language-Java%2017-9B599A.svg?style=round)](https://www.oracle.com/java/technologies/downloads/#java17)
[![Java 21](https://img.shields.io/badge/language-Java%2021-9B599A.svg?style=round)](https://www.oracle.com/java/technologies/downloads/#java21)
[![GitHub license](https://img.shields.io/github/license/TeamMidnightDust/MidnightControls?style=round)](LICENSE)
A Fabric Minecraft mod which adds better controls, reach-around and controller support.

View File

@@ -86,10 +86,16 @@ public class MidnightControlsClient extends MidnightControls {
int period = 1; // repeat every 0.001 sec. (1000 times a second)
Timer timer = new Timer();
timer.scheduleAtFixedRate(new TimerTask() {
public void run() { // TODO: Add a try/catch here after the alpha testing period
if (lateInitDone && client.isRunning()) {
input.tickCameraStick();
input.updateCamera();
public void run() {
try {
if (lateInitDone && client.isRunning()) {
if (MidnightControlsConfig.controlsMode != ControlsMode.DEFAULT && (client.isWindowFocused() || MidnightControlsConfig.unfocusedInput)) {
input.tickCameraStick();
input.updateCamera();
}
}
} catch (Exception | Error e) {
MidnightControls.logger.error("Exception encountered in camera loop: ",e);
}
}
}, delay, period);

View File

@@ -74,7 +74,7 @@ public class MidnightControlsConfig extends MidnightConfig {
@Entry(category = VISUAL, name = "Reacharound Outline Alpha", isSlider = true, min = 0, max = 255) public static int reacharoundOutlineColorAlpha = 102;
@Entry(category = CONTROLLER, name = "midnightcontrols.menu.right_dead_zone", isSlider = true, min = 0.05, max = 1) public static double rightDeadZone = 0.25;
@Entry(category = CONTROLLER, name = "midnightcontrols.menu.left_dead_zone", isSlider = true, min = 0.05, max = 1) public static double leftDeadZone = 0.25;
@Entry(category = CONTROLLER, name = "midnightcontrols.menu.trigger_dead_zone", isSlider = true, min = 0.05, max = 1) public static double triggerDeadZone = 0.1;
@Entry(category = CONTROLLER, name = "Trigger Dead-Zone", isSlider = true, min = 0.05, max = 1) public static double triggerDeadZone = 0.1;
@Entry(category = CONTROLLER, name = "midnightcontrols.menu.invert_right_y_axis") public static boolean invertRightYAxis = false;
@Entry(category = CONTROLLER, name = "midnightcontrols.menu.invert_right_x_axis") public static boolean invertRightXAxis = false;
@Entry(category = CONTROLLER, name = "midnightcontrols.menu.rotation_speed", isSlider = true, min = 0, max = 100, precision = 10) public static double rotationSpeed = 35.0; //used for x-axis, name kept for compatibility

View File

@@ -34,7 +34,8 @@ import static eu.midnightdust.midnightcontrols.client.MidnightControlsClient.cli
* @since 1.1.0
*/
public class MidnightControlsCompat {
private static final List<CompatHandler> HANDLERS = new ArrayList<>();
@Deprecated // INTERNAL -> PLEASE USE streamCompatHandlers() INSTEAD
public static final List<CompatHandler> HANDLERS = new ArrayList<>();
/**
* Initializes compatibility with other mods if needed.

View File

@@ -40,22 +40,22 @@ public abstract class GameOptionsScreenMixin extends Screen {
super(title);
}
@Inject(method = "initTabNavigation", at = @At("TAIL"))
public void addMidnightButton(CallbackInfo ci) {
@Inject(method = "init", at = @At("TAIL"))
public void midnightcontrols$addMCButton(CallbackInfo ci) {
if (this.getClass().toString().equals(ControlsOptionsScreen.class.toString())) {
this.midnightcontrols$setupButton();
this.midnightcontrols$setButtonPos();
this.addDrawableChild(midnightcontrols$button);
}
}
@Override
public void resize(MinecraftClient client, int width, int height) {
super.resize(client, width, height);
this.midnightcontrols$setupButton();
@Inject(method = "initTabNavigation", at = @At("TAIL"))
public void midnightcontrols$onResize(CallbackInfo ci) {
this.midnightcontrols$setButtonPos();
}
@Unique
public void midnightcontrols$setupButton() {
assert body != null;
midnightcontrols$button.setPosition(body.getWidth() / 2 + 158, body.getY() + 4);
public void midnightcontrols$setButtonPos() {
if (body != null) {
midnightcontrols$button.setPosition(body.getWidth() / 2 + 158, body.getY() + 4);
}
}
}

View File

@@ -130,8 +130,8 @@
"midnightcontrols.controls_mode.default": "Keyboard/Mouse",
"midnightcontrols.controls_mode.controller": "Controller",
"midnightcontrols.controls_mode.touchscreen": "Touchscreen (Beta)",
"midnightcontrols.hud_side.left": "Left",
"midnightcontrols.hud_side.right": "Right",
"midnightcontrols.hud_side.LEFT": "Left",
"midnightcontrols.hud_side.RIGHT": "Right",
"midnightcontrols.menu.analog_movement": "Analog Movement",
"midnightcontrols.menu.analog_movement.tooltip": "When possible, enables analog movement.",
"midnightcontrols.menu.auto_switch_mode": "Auto Switch Mode",

View File

@@ -0,0 +1,238 @@
{
"midnightcontrols.midnightconfig.title": "Configurações avançadas do MidnightControls",
"midnightcontrols.midnightconfig.enum.VirtualMouseSkin.DEFAULT_LIGHT": "Padrão claro",
"midnightcontrols.midnightconfig.enum.VirtualMouseSkin.DEFAULT_DARK": "Padrão escuro",
"midnightcontrols.midnightconfig.enum.VirtualMouseSkin.SECOND_LIGHT": "Segundo claro",
"midnightcontrols.midnightconfig.enum.VirtualMouseSkin.SECOND_DARK": "Segundo escuro",
"midnightcontrols.midnightconfig.enum.ControllerType.DEFAULT": "Padrão",
"midnightcontrols.midnightconfig.enum.ControllerType.DUALSHOCK": "DualShock",
"midnightcontrols.midnightconfig.enum.ControllerType.DUALSENSE": "DualSense",
"midnightcontrols.midnightconfig.enum.ControllerType.SWITCH": "Controle de Switch/Wii",
"midnightcontrols.midnightconfig.enum.ControllerType.XBOX": "Controle de Xbox One/Series",
"midnightcontrols.midnightconfig.enum.ControllerType.XBOX_360": "Controle de Xbox 360",
"midnightcontrols.midnightconfig.enum.ControllerType.STEAM_CONTROLLER": "Controle da Steam",
"midnightcontrols.midnightconfig.enum.ControllerType.STEAM_DECK": "Steam Deck",
"midnightcontrols.midnightconfig.enum.ControllerType.OUYA": "Controle de OUYA",
"midnightcontrols.midnightconfig.enum.ControllerType.NUMBERED": "Controle númerado",
"midnightcontrols.midnightconfig.enum.ControlsMode.DEFAULT": "Teclado/Mouse",
"midnightcontrols.midnightconfig.enum.ControlsMode.CONTROLLER": "Controle",
"midnightcontrols.midnightconfig.enum.ControlsMode.TOUCHSCREEN": "Tela sensível ao toque (Beta)",
"midnightcontrols.midnightconfig.enum.HudSide.LEFT": "Esquerda",
"midnightcontrols.midnightconfig.enum.HudSide.RIGHT": "Direita",
"midnightcontrols.midnightconfig.enum.TouchMode.CROSSHAIR": "Na mira",
"midnightcontrols.midnightconfig.enum.TouchMode.FINGER_POS": "Posição do dedo",
"midnightcontrols.midnightconfig.enum.CameraMode.FLAT": "Plano",
"midnightcontrols.midnightconfig.enum.CameraMode.ADAPTIVE": "Adaptativo",
"key.categories.midnightcontrols": "MidnightControls",
"key.midnightcontrols.look_down": "Olhar para baixo",
"key.midnightcontrols.look_left": "Olhar para a esquerda",
"key.midnightcontrols.look_right": "Olhar para a direita",
"key.midnightcontrols.look_up": "Olhar para cima",
"key.midnightcontrols.ring": "Abrir anel de teclas não vinculadas",
"midnightcontrols.action.attack": "Atacar",
"midnightcontrols.action.back": "Voltar",
"midnightcontrols.action.chat": "Abrir bate-papo",
"midnightcontrols.action.controls_ring": "Abrir anel de teclas não vinculadas",
"midnightcontrols.action.debug_screen": "Abrir HUD de depuração (F3)",
"midnightcontrols.action.drop_item": "Soltar item",
"midnightcontrols.action.drink": "Beber",
"midnightcontrols.action.eat": "Comer",
"midnightcontrols.action.equip": "Equipar",
"midnightcontrols.action.exit": "Sair da tela",
"midnightcontrols.action.forward": "Para frente",
"midnightcontrols.action.hit": "Atacar",
"midnightcontrols.action.hotbar_left": "Move a barra rápida para esquerda",
"midnightcontrols.action.hotbar_right": "Move a barra rápida para direita",
"midnightcontrols.action.inventory": "Invetário",
"midnightcontrols.action.jump": "Pular",
"midnightcontrols.action.left": "Esquerda",
"midnightcontrols.action.pause_game": "Pausar",
"midnightcontrols.action.pick_block": "Pegar bloco",
"midnightcontrols.action.pickup": "Pegar",
"midnightcontrols.action.pickup_all": "Pegar todos",
"midnightcontrols.action.place": "Colocar",
"midnightcontrols.action.player_list": "Lista de jogadores",
"midnightcontrols.action.quick_move": "Mover rápido",
"midnightcontrols.action.right": "Direita",
"midnightcontrols.action.screenshot": "Tirar Screenshot",
"midnightcontrols.action.slot_up": "Mover Slot para cima",
"midnightcontrols.action.slot_down": "Mover Slot para baixo",
"midnightcontrols.action.slot_left": "Mover Slot para esquerda",
"midnightcontrols.action.slot_right": "Mover Slot para direita",
"midnightcontrols.action.sneak": "Esgueirar",
"midnightcontrols.action.sprint": "Correr",
"midnightcontrols.action.swap_hands": "Trocar de mãos",
"midnightcontrols.action.toggle_perspective": "Alternar perspectiva",
"midnightcontrols.action.toggle_smooth_camera": "Ativar câmera cinemática",
"midnightcontrols.action.page_back": "Página anterior",
"midnightcontrols.action.page_next": "Próxima página",
"midnightcontrols.action.tab_back": "Aba anterior",
"midnightcontrols.action.tab_next": "Próxima aba",
"midnightcontrols.action.take": "Pegar item",
"midnightcontrols.action.take_all": "Pegar pilha",
"midnightcontrols.action.use": "Usar",
"midnightcontrols.action.zoom": "Zoom",
"midnightcontrols.action.zoom_in": "Aumentar o Zoom",
"midnightcontrols.action.zoom_out": "Diminuir o Zoom",
"midnightcontrols.action.zoom_reset": "Resetar o Zoom",
"midnightcontrols.action.emi_page_left": "Página anterior",
"midnightcontrols.action.emi_page_right": "Próxima pickup",
"midnightcontrols.category.emi": "EMI",
"midnightcontrols.button.a": "A",
"midnightcontrols.button.b": "B",
"midnightcontrols.button.x": "X",
"midnightcontrols.button.y": "Y",
"midnightcontrols.button.left_bumper": "Botão L1",
"midnightcontrols.button.right_bumper": "Botão R1",
"midnightcontrols.button.back": "Voltar",
"midnightcontrols.button.start": "Começar",
"midnightcontrols.button.guide": "Guia",
"midnightcontrols.button.left_thumb": "Analógico esquerdo",
"midnightcontrols.button.right_thumb": "Analógico direito",
"midnightcontrols.button.dpad_up": "Botão direcional para cima",
"midnightcontrols.button.dpad_right": "Botão direcional para direita",
"midnightcontrols.button.dpad_down": "Botão direcional para baixo",
"midnightcontrols.button.dpad_left": "Botão direcional para esquerda",
"midnightcontrols.button.l4": "L4",
"midnightcontrols.button.l5": "L5",
"midnightcontrols.button.r4": "R4",
"midnightcontrols.button.r5": "L5",
"midnightcontrols.axis.left_x+": "Esquerda X+",
"midnightcontrols.axis.left_y+": "Esquerda Y+",
"midnightcontrols.axis.right_x+": "Direita X+",
"midnightcontrols.axis.right_y+": "Direita Y+",
"midnightcontrols.axis.left_trigger": "Gatilho da esquerda",
"midnightcontrols.axis.right_trigger": "Gatilho da direita",
"midnightcontrols.axis.left_x-": "Esquerda X-",
"midnightcontrols.axis.left_y-": "Esquerda Y-",
"midnightcontrols.axis.right_x-": "Direita X-",
"midnightcontrols.axis.right_y-": "Direita Y-",
"midnightcontrols.button.unknown": "Desconhecido (%d)",
"midnightcontrols.controller.tutorial.title": "Jogue o jogo com um controle!",
"midnightcontrols.controller.tutorial.description": "Vá para %s -> %s -> %s",
"midnightcontrols.controller.connected": "Controle %d conectado.",
"midnightcontrols.controller.disconnected": "Controle %d desconectado.",
"midnightcontrols.controller.mappings.1": "Para configurar o mapeamento do controle, por favor use %s",
"midnightcontrols.controller.mappings.3": "e cole o mapeamento no editor de arquivos do mapeamento.",
"midnightcontrols.controller.mappings.error": "Erro ao carregar mapeamentos.",
"midnightcontrols.controller.mappings.error.write": "Erro ao gravar mapeamentos no arquivo.",
"midnightcontrols.controller.mappings.updated": "Atualizando mapeamentos!",
"midnightcontrols.controller_type.default": "Padrão",
"midnightcontrols.controller_type.dualshock": "DualShock",
"midnightcontrols.controller_type.dualsense": "DualSense",
"midnightcontrols.controller_type.switch": "Controle de Switch/Wii",
"midnightcontrols.controller_type.xbox": "Controle de Xbox One/Series",
"midnightcontrols.controller_type.xbox_360": "Controle de Xbox 360",
"midnightcontrols.controller_type.steam_controller": "Controle da Steam",
"midnightcontrols.controller_type.steam_deck": "Steam Deck",
"midnightcontrols.controller_type.ouya": "Controle de OUYA",
"midnightcontrols.controller_type.numbered": "Controle númerado",
"midnightcontrols.controls_mode.default": "Teclado/Mouse",
"midnightcontrols.controls_mode.controller": "Controle",
"midnightcontrols.controls_mode.touchscreen": "Tela sensível ao toque (Beta)",
"midnightcontrols.hud_side.LEFT": "Esquerda",
"midnightcontrols.hud_side.RIGHT": "Direita",
"midnightcontrols.menu.analog_movement": "Movemento analógico",
"midnightcontrols.menu.analog_movement.tooltip": "Quando possível, ative o movemento analógico.",
"midnightcontrols.menu.auto_switch_mode": "Modo de troca automática",
"midnightcontrols.menu.auto_switch_mode.tooltip": "Se o modo de controle deve ser alterado automaticamente para o controle quando um for conectado.",
"midnightcontrols.menu.camera_mode": "Modo de câmera",
"midnightcontrols.menu.controller": "Controle",
"midnightcontrols.menu.controller2": "Segundo controle",
"midnightcontrols.menu.controller2.tooltip": "Segundo controle a ser usado, o que permite (por exemplo) o suporte a Joy-Cons.",
"midnightcontrols.menu.controller_toggle_sneak": "Alternar Esgueirar no Controle",
"midnightcontrols.menu.controller_toggle_sprint": "Alternar Correr no Controle",
"midnightcontrols.menu.controller_type": "Tipo de controle",
"midnightcontrols.menu.controller_type.tooltip": "O tipo de controle que você está usando (é preciso para mostrar os botões corretos)",
"midnightcontrols.menu.controls_mode": "Modo",
"midnightcontrols.menu.controls_mode.tooltip": "O modo de controle.",
"midnightcontrols.menu.copy_controller_guid": "Copiar o GUID",
"midnightcontrols.menu.current_controller_guid": "GUID do controle atual: %s",
"midnightcontrols.menu.double_tap_to_sprint": "Toque duplo para correr",
"midnightcontrols.menu.double_tap_to_sprint.tooltip": "Alterna se a tecla Andar para Frente faz o jogador correr quando pressionada duas vezes rapidamente",
"midnightcontrols.menu.fast_block_placing": "Colocação Rápida de Blocos",
"midnightcontrols.menu.fast_block_placing.tooltip": "Enquanto voando no criativo, ativar a Colocação de Rápida de Blocos. §cEm alguns servidores isso pode ser considerado como trapaça.",
"midnightcontrols.menu.fly_drifting": "Derrapagem ao Voar",
"midnightcontrols.menu.fly_drifting.tooltip": "Enquanto voando, ativa a deparragem/inércia Vanilla.",
"midnightcontrols.menu.fly_drifting_vertical": "Derrapagem vertical ao Voar",
"midnightcontrols.menu.fly_drifting_vertical.tooltip": "Enquanto voando, ativa a deparragem/inércia vertical Vanilla.",
"midnightcontrols.menu.hud_enable": "Ativar HUD",
"midnightcontrols.menu.hud_enable.tooltip": "Alterna o indicador de botão do controle na tela.",
"midnightcontrols.menu.hud_side": "Lado do HUD",
"midnightcontrols.menu.hud_side.tooltip": "A posição do HUD.",
"midnightcontrols.menu.invert_right_x_axis": "Inverter X Direito",
"midnightcontrols.menu.invert_right_y_axis": "Inverter Y Direito",
"midnightcontrols.menu.joystick_as_mouse": "Sempre usar analógico esquerdo como mouse",
"midnightcontrols.menu.joystick_as_mouse.tooltip": "Fazer o analógico agir como um mouse em todos os menus.",
"midnightcontrols.menu.eye_tracker_as_mouse": "Usar o rastreador ocular como um mouse",
"midnightcontrols.menu.eye_tracker_as_mouse.tooltip": "Substituir o mouse com um dispositivo de rastreamento ocular, (por exemplo) o Tobii 5.",
"midnightcontrols.menu.eye_tracker_deadzone": "Tamanho da zona morta do rastreador ocular",
"midnightcontrols.menu.eye_tracker_deadzone.tooltip": "Parar o movimento da camera quando olhar perto da mira",
"midnightcontrols.menu.keyboard_controls": "Controles do teclado...",
"midnightcontrols.menu.left_dead_zone": "Zona morta do analógico esquerdo",
"midnightcontrols.menu.left_dead_zone.tooltip": "A zona morta para o analógico esquerdo do controle.",
"midnightcontrols.menu.mappings.open_input_str": "Abrir editor de arquivo de mapeamentos",
"midnightcontrols.menu.max_left_x_value": "Valor máximo do eixo X esquerdo",
"midnightcontrols.menu.max_left_x_value.tooltip": "Altera o valor máximo considerado pelo mod para o eixo X esquerdo. Útil se o seu eixo não usa toda a faixa e parece lento.",
"midnightcontrols.menu.max_left_y_value": "Valor máximo do eixo Y esquerdo",
"midnightcontrols.menu.max_left_y_value.tooltip": "Altera o valor máximo considerado pelo mod para o eixo Y esquerdo. Útil se o seu eixo não usa toda a faixa e parece lento.",
"midnightcontrols.menu.max_right_x_value": "Valor máximo do eixo X direito",
"midnightcontrols.menu.max_right_x_value.tooltip": "Altera o valor máximo considerado pelo mod para o eixo X direito. Útil se o seu eixo não usa toda a faixa e parece lento.",
"midnightcontrols.menu.max_right_y_value": "Valor máximo do eixo Y direito",
"midnightcontrols.menu.max_right_y_value.tooltip": "Altera o valor máximo considerado pelo mod para o eixo Y direito. Útil se o seu eixo não usa toda a faixa e parece lento.",
"midnightcontrols.menu.mouse_speed": "Velocidade do mouse",
"midnightcontrols.menu.mouse_speed.tooltip": "A velocidade do mouse emulado pelo controle",
"midnightcontrols.menu.move_chat": "Mover a caixa do chat para o topo",
"midnightcontrols.menu.move_chat.tooltip": "Move a caixa do chat para o topo, para uma melhor digitação em dispositivos com teclados na tela.",
"midnightcontrols.menu.multiple_mapping_tip": "(Dica: Você também pode inserir múltiplos mapeamentos ao mesmo tempo)",
"midnightcontrols.menu.reacharound.horizontal": "Colocação frontal de blocos",
"midnightcontrols.menu.reacharound.horizontal.tooltip": "Ativa colocação frontal de blocos, §cEm alguns servidores isso pode ser considerado como trapaça.§r.",
"midnightcontrols.menu.reacharound.vertical": "Alcance vertical",
"midnightcontrols.menu.reacharound.vertical.tooltip": "Ativa alcance vertical, §c§cEm alguns servidores isso pode ser considerado como trapaça.§r.",
"midnightcontrols.menu.reload_controller_mappings": "Recarregar o mapeamento do controle",
"midnightcontrols.menu.reload_controller_mappings.tooltip": "Recarrega o arquivo de mapeamentos do controle.",
"midnightcontrols.menu.right_dead_zone": "Zona morta do analógico direito",
"midnightcontrols.menu.right_dead_zone.tooltip": "A zona morta para o analógico direito do controle..",
"midnightcontrols.menu.rotation_speed": "Velocidade de rotação do eixo X",
"midnightcontrols.menu.rotation_speed.tooltip": "A velocidade de rotação do eixo X da câmera no modo controle.",
"midnightcontrols.menu.y_axis_rotation_speed": "Velocidade de rotação do eixo Y",
"midnightcontrols.menu.y_axis_rotation_speed.tooltip": "A velocidade de rotação do eixo Y da câmera no modo controle.",
"midnightcontrols.menu.separate_controller_profile": "Separar perfil do controle",
"midnightcontrols.menu.separator.controller": "Controle",
"midnightcontrols.menu.separator.general": "Geral",
"midnightcontrols.menu.title": "MidnightControls - Configurações",
"midnightcontrols.menu.title.controller": "Configurações do controle",
"midnightcontrols.menu.title.controller_controls": "Mapeamento de controle",
"midnightcontrols.menu.title.gameplay": "Configurações de jogabilidade",
"midnightcontrols.menu.title.general": "Configurações gerais",
"midnightcontrols.menu.title.hud": "Configurações de HUD",
"midnightcontrols.menu.title.mappings.string": "Editor de arquivo de mapeamentos",
"midnightcontrols.menu.title.touch": "Configurações de toque",
"midnightcontrols.menu.title.visual": "Configurações de aparência",
"midnightcontrols.menu.touch_break_delay": "Atrasado de destruição do toque",
"midnightcontrols.menu.touch_speed": "Velocidade do toque",
"midnightcontrols.menu.invert_touch": "Inverter direção do toque",
"midnightcontrols.menu.touch_mode": "Modo de interação de toque",
"midnightcontrols.menu.touch_transparency": "Transparência do HUD de toque",
"midnightcontrols.menu.touch_with_controller": "Toque no modo do controle",
"midnightcontrols.menu.unfocused_input": "Entrada desfocada",
"midnightcontrols.menu.unfocused_input.tooltip": "Permite entrada de sinais do controle quando a janela não está em foco.",
"midnightcontrols.menu.virtual_mouse": "Mouse virtual",
"midnightcontrols.menu.virtual_mouse.tooltip": "Ativa o mouse virtual, que é útil durante o modo tela dividida.",
"midnightcontrols.menu.virtual_mouse.skin": "Tema do mouse virtual",
"midnightcontrols.menu.hide_cursor": "Desativar cursor do mouse padrão",
"midnightcontrols.menu.hide_cursor.tooltip": "Esconde o cursor padrão do mouse, deixando apenas o mouse virtual visível.",
"midnightcontrols.narrator.unbound": "Desmapear %s",
"midnightcontrols.not_bound": "Não mapeado",
"midnightcontrols.virtual_mouse.skin.default_light": "Padrão claro",
"midnightcontrols.virtual_mouse.skin.default_dark": "Padrão escuro",
"midnightcontrols.virtual_mouse.skin.second_light": "Segundo claro",
"midnightcontrols.virtual_mouse.skin.second_dark": "Segundo escuro",
"midnightcontrols.midnightconfig.category.controller": "Controle",
"midnightcontrols.midnightconfig.category.misc": "Variados",
"midnightcontrols.midnightconfig.category.screens": "Telas",
"midnightcontrols.midnightconfig.category.gameplay": "Jogabilidade",
"midnightcontrols.midnightconfig.category.touch": "Toque",
"midnightcontrols.midnightconfig.category.visual": "Visual",
"modmenu.descriptionTranslation.midnightcontrols": "Adiciona suporte a controles e aprimora o controle no geral.\nDerivado do LambdaControls, que infelizmente foi descontinuado."
}

View File

@@ -1,7 +1,7 @@
{
"required": true,
"package": "eu.midnightdust.midnightcontrols.client.mixin",
"compatibilityLevel": "JAVA_16",
"compatibilityLevel": "JAVA_21",
"client": [
"ClickableWidgetAccessor",
"AdvancementsScreenAccessor",

View File

@@ -2,7 +2,7 @@
"required": true,
"package": "eu.midnightdust.midnightcontrols.client.compat.mixin",
"plugin": "eu.midnightdust.midnightcontrols.client.compat.MidnightControlsMixinPlugin",
"compatibilityLevel": "JAVA_16",
"compatibilityLevel": "JAVA_21",
"client": [
"sodium.SodiumOptionsGUIAccessor"
],

View File

@@ -92,7 +92,7 @@ unifiedPublishing {
curseforge {
token = CURSEFORGE_TOKEN
id = rootProject.curseforge_id
gameVersions.addAll "Java 21", project.minecraft_version
gameVersions.addAll "Java 21", project.minecraft_version, project.supported_versions
}
}
@@ -102,7 +102,7 @@ unifiedPublishing {
token = MODRINTH_TOKEN
id = rootProject.modrinth_id
version = "$project.version-$project.name"
gameVersions.addAll project.minecraft_version
gameVersions.addAll project.minecraft_version, project.supported_versions
}
}
}

View File

@@ -54,7 +54,7 @@
"fabric": ">=0.71.0",
"minecraft": ">=1.20.5",
"obsidianui": ">=0.2.5",
"java": ">=17"
"java": ">=21"
},
"suggests": {
"kontrolo": "*"

View File

@@ -3,18 +3,19 @@ org.gradle.parallel=true
org.gradle.jvmargs=-Xmx2048M
minecraft_version=1.21
supported_versions=1.21.1
yarn_mappings=1.21+build.2
enabled_platforms=fabric,neoforge
archives_base_name=midnightcontrols
mod_version=1.10.0-beta.1
mod_version=1.10.0.1
maven_group=eu.midnightdust
release_type=release
release_type=beta
modrinth_id = bXX9h73M
curseforge_id = 621768
# Configure the IDs here after creating the projects on the websites
midnightlib_version=1.6.1
midnightlib_version=1.6.3
fabric_loader_version=0.15.11
fabric_api_version=0.100.1+1.21

View File

@@ -104,7 +104,7 @@ unifiedPublishing {
curseforge {
token = CURSEFORGE_TOKEN
id = rootProject.curseforge_id
gameVersions.addAll "Java 21", project.minecraft_version
gameVersions.addAll "Java 21", project.minecraft_version, project.supported_versions
}
}
@@ -114,7 +114,7 @@ unifiedPublishing {
token = MODRINTH_TOKEN
id = rootProject.modrinth_id
version = "$project.version-$project.name"
gameVersions.addAll project.minecraft_version
gameVersions.addAll project.minecraft_version, project.supported_versions
}
}
}

View File

@@ -3,7 +3,7 @@ package eu.midnightdust.midnightcontrols.client.util.platform.neoforge;
import net.minecraft.client.network.ClientPlayNetworkHandler;
import net.minecraft.network.packet.CustomPayload;
import net.minecraft.network.packet.Packet;
import net.minecraft.network.packet.c2s.common.CustomPayloadC2SPacket;
import net.neoforged.neoforge.network.PacketDistributor;
import static eu.midnightdust.midnightcontrols.client.MidnightControlsClient.client;
@@ -19,7 +19,7 @@ public class NetworkUtilImpl {
handler.send(packet);
}
public static void sendPayloadC2S(CustomPayload payload) {
if (handler != null && client.world != null)
handler.send(new CustomPayloadC2SPacket(payload));
if (handler != null && client.world != null && handler.hasChannel(payload.getId().id()))
PacketDistributor.sendToServer(payload);
}
}

View File

@@ -27,7 +27,7 @@ public class MidnightControlsNeoforge {
public class CommonEvents {
@SubscribeEvent
public static void registerPayloads(RegisterPayloadHandlersEvent event) {
PayloadRegistrar registrar = event.registrar("1");
PayloadRegistrar registrar = event.registrar("1").optional();
registrar.playToServer(HelloPayload.PACKET_ID, HelloPayload.codec, (payload, context) -> {
ControlsMode.byId(payload.controlsMode()).ifPresent(controlsMode -> new PlayerChangeControlsModeEvent(context.player(), controlsMode));
context.connection().send(new CustomPayloadS2CPacket(new FeaturePayload(MidnightControlsFeature.HORIZONTAL_REACHAROUND)));