From 68e1b1d6fa46ec35d319e24bd4a6953e320c4051 Mon Sep 17 00:00:00 2001 From: That One Seong Date: Fri, 27 Sep 2024 19:10:28 +0000 Subject: [PATCH] I'm bad at syncing branches (#31) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Some fixes (#29) * Mapeadas flechas del teclado y añadida pulsacion del gatillo en modo serie -Se han mapeado las flechas del teclado y se han asignado al Dpad mientras la pistola está en modo Ratón+Teclado -Se ha añadido el botón "trigger" en modo mando mientras está activa la comunicación serie (mamehook) ya que anteriormente si se activaba la comunicación serie mientras la pistola estaba en modo "mando" dejaba de funcionar el gatillo * Algunas correcciones de como se muestra la vida (barra de vida) en la pantalla oled -Ahora calcula el porcentaje de "vida" y lo muestra correctamente. -Cambiado el tipo de variable usada para leer la "vida" de uint8_t cuyo valor máximo es 255 a uint16_t para mostrar correctamente la "vida en juegos que usen un valor mayor como Aliens Armageddon que usa de valor máximo 1000 * Reset SamcoEnhanced.ino Reset file to begin PR * Fix trigger in Gamepad mode + Serial -Added trigger button to work when serial comunication is enabled and gun is in Gamepad mode * Fix for life% shown in lifebar - Fix for life% shown in lifebar - Changed "serialLifeCount" from uint8_t to uint16_t, for handle life values higher than 255 * Translated some variable to maintain language consistency - Translated some variable to maintain language consistency * Consistency, slight cleanup * Bump Arduino-cli * Forgot this one. --------- Co-authored-by: kikexx <55745394+kikexx@users.noreply.github.com> --- .github/workflows/arduino-cli-builds.yml | 2 +- SamcoEnhanced/SamcoEnhanced.ino | 20 +++++++------------- 2 files changed, 8 insertions(+), 14 deletions(-) diff --git a/.github/workflows/arduino-cli-builds.yml b/.github/workflows/arduino-cli-builds.yml index 4a7d44b..7d635bf 100644 --- a/.github/workflows/arduino-cli-builds.yml +++ b/.github/workflows/arduino-cli-builds.yml @@ -62,7 +62,7 @@ jobs: submodules: true - name: Install Arduino-cli - uses: arduino/setup-arduino-cli@v1 + uses: arduino/setup-arduino-cli@v2 # arduino nano uses this just to access LEDs, grr... - name: Install Arduino Nano Connect library diff --git a/SamcoEnhanced/SamcoEnhanced.ino b/SamcoEnhanced/SamcoEnhanced.ino index ebb98b8..fa6a93e 100644 --- a/SamcoEnhanced/SamcoEnhanced.ino +++ b/SamcoEnhanced/SamcoEnhanced.ino @@ -3789,12 +3789,12 @@ void TriggerFireSimple() if(!buttonPressed && // Have we not fired the last cycle, offscreenButtonSerial && buttons.offScreen) { // and are pointing the gun off screen WITH the offScreen button mode set? if(buttons.analogOutput) { Gamepad16.press(LightgunButtons::ButtonDesc[BtnIdx_A].reportCode3); } - else { AbsMouse5.press(MOUSE_RIGHT); } + else { AbsMouse5.press(MOUSE_RIGHT); } offscreenBShot = true; // Mark we pressed the right button via offscreen shot mode, buttonPressed = true; // Mark so we're not spamming these press events. } else if(!buttonPressed) { // Else, have we simply not fired the last cycle? - if(buttons.analogOutput) { Gamepad16.press(LightgunButtons::ButtonDesc[BtnIdx_Trigger].reportCode3); } - else { AbsMouse5.press(MOUSE_LEFT); } + if(buttons.analogOutput) { Gamepad16.press(LightgunButtons::ButtonDesc[BtnIdx_Trigger].reportCode3); } + else { AbsMouse5.press(MOUSE_LEFT); } buttonPressed = true; // Set this so we won't spam a repeat press event again. } } @@ -3804,18 +3804,12 @@ void TriggerNotFireSimple() { if(buttonPressed) { // Just to make sure we aren't spamming mouse button events. if(offscreenBShot) { // if it was marked as an offscreen button shot, - if(buttons.analogOutput) { //Check if gamepad mode is enabled - Gamepad16.release(LightgunButtons::ButtonDesc[BtnIdx_A].reportCode3); //If gamepad mode is enabled release A Button - } else { - AbsMouse5.release(MOUSE_RIGHT); // Release the right mouse, - } + if(buttons.analogOutput) { Gamepad16.release(LightgunButtons::ButtonDesc[BtnIdx_A].reportCode3); } + else { AbsMouse5.release(MOUSE_RIGHT); } offscreenBShot = false; // And set it off. } else { // Else, - if(buttons.analogOutput) { //Check if gamepad mode is enabled - Gamepad16.release(LightgunButtons::ButtonDesc[BtnIdx_Trigger].reportCode3); // If gamepad mode is enabled release the Trigger button - } else { - AbsMouse5.release(MOUSE_LEFT); // It was a normal shot, so just release the left mouse button. - } + if(buttons.analogOutput) { Gamepad16.release(LightgunButtons::ButtonDesc[BtnIdx_Trigger].reportCode3); } + else { AbsMouse5.release(MOUSE_LEFT); } } buttonPressed = false; // Unset the button pressed bit. }