mirror of
https://github.com/jugeeya/UltimateTrainingModpack.git
synced 2024-11-24 10:54:16 +00:00
GC Digital Triggers Menu Fix (#497)
* Check for digital triggers * Update menu.rs * Special case digital triggers * JK * Update rust.yml * Update menu.rs
This commit is contained in:
parent
c3a36e78e5
commit
0395bbe8ca
2 changed files with 167 additions and 152 deletions
2
.github/workflows/rust.yml
vendored
2
.github/workflows/rust.yml
vendored
|
@ -24,7 +24,7 @@ jobs:
|
||||||
- uses: Swatinem/rust-cache@v2
|
- uses: Swatinem/rust-cache@v2
|
||||||
name: Rust Cache
|
name: Rust Cache
|
||||||
with:
|
with:
|
||||||
prefix-key: "checker"
|
prefix-key: "checker-2"
|
||||||
- name: Clippy
|
- name: Clippy
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
|
|
|
@ -181,7 +181,7 @@ pub static mut BUTTON_PRESSES: ButtonPresses = ButtonPresses {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
pub fn handle_get_npad_state(state: *mut NpadGcState, _controller_id: *const u32) {
|
pub fn handle_get_npad_state(state: *mut NpadGcState, controller_id: *const u32) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let update_count = (*state).updateCount;
|
let update_count = (*state).updateCount;
|
||||||
let flags = (*state).Flags;
|
let flags = (*state).Flags;
|
||||||
|
@ -227,6 +227,17 @@ pub fn handle_get_npad_state(state: *mut NpadGcState, _controller_id: *const u32
|
||||||
BUTTON_PRESSES.up.is_pressed = true;
|
BUTTON_PRESSES.up.is_pressed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For digital triggers: these at TRIGGER_MAX means we should consider a press
|
||||||
|
if controller_is_gcc(*controller_id) {
|
||||||
|
if (*state).LTrigger == 0x7FFF {
|
||||||
|
BUTTON_PRESSES.l.is_pressed = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*state).RTrigger == 0x7FFF {
|
||||||
|
BUTTON_PRESSES.r.is_pressed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// If we're here, remove all other Npad presses...
|
// If we're here, remove all other Npad presses...
|
||||||
// Should we exclude the home button?
|
// Should we exclude the home button?
|
||||||
(*state) = NpadGcState::default();
|
(*state) = NpadGcState::default();
|
||||||
|
@ -247,10 +258,14 @@ lazy_static! {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub unsafe fn controller_is_gcc(controller_id: u32) -> bool {
|
||||||
|
let style_set = GetNpadStyleSet(&controller_id as *const _);
|
||||||
|
(style_set.flags & (1 << 5)) > 0
|
||||||
|
}
|
||||||
|
|
||||||
pub unsafe fn p1_controller_is_gcc() -> bool {
|
pub unsafe fn p1_controller_is_gcc() -> bool {
|
||||||
let p1_controller_id = crate::training::input_delay::p1_controller_id();
|
let p1_controller_id = crate::training::input_delay::p1_controller_id();
|
||||||
let p1_style_set = GetNpadStyleSet(&p1_controller_id as *const _);
|
controller_is_gcc(p1_controller_id)
|
||||||
(p1_style_set.flags & (1 << 5)) > 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub unsafe fn quick_menu_loop() {
|
pub unsafe fn quick_menu_loop() {
|
||||||
|
|
Loading…
Reference in a new issue