mirror of
https://github.com/jugeeya/UltimateTrainingModpack.git
synced 2025-01-19 17:00:15 +00:00
Add Directional Air Dodge (#86)
* Rename Enum DirectionalInfluence => Direction * Move Angle Calculation To Common Renamed NO_DI to ANGLE_NONE and moved to common * Simplify Condition Removed need to check for no DI twice * Reuse Angle Calculation get_random now returns a random direction instead of the angle directly * Add Left Stick Mod Currently only used for air dodges * Extract Shared Condition * Remove Unused Includes * Fix Air Dodge Mash Fixed always flashing shield when set to air dodge mash * Update Menu * Update TrainingModpackOverlay
This commit is contained in:
commit
94d9d5623d
7 changed files with 191 additions and 30 deletions
|
@ -1 +1 @@
|
|||
Subproject commit ebe52ded3762dc3a45aa07652cbacbc410145ead
|
||||
Subproject commit 5ff4c5f02b77d21a49927bae629fc97f1bd0d318
|
|
@ -1,3 +1,4 @@
|
|||
use core::f64::consts::PI;
|
||||
use smash::lib::lua_const::*;
|
||||
|
||||
/// Hitbox Visualization
|
||||
|
@ -17,10 +18,48 @@ pub enum HitboxVisualization {
|
|||
/// DI
|
||||
#[repr(i32)]
|
||||
#[derive(Debug, Clone, Copy, PartialEq)]
|
||||
pub enum DirectionalInfluence {
|
||||
pub enum Direction {
|
||||
None = 0,
|
||||
Right = 1,
|
||||
UpRight = 2,
|
||||
Up = 3,
|
||||
UpLeft = 4,
|
||||
Left = 5,
|
||||
DownLeft = 6,
|
||||
Down = 7,
|
||||
DownRight = 8,
|
||||
// lol what goes here jug smh my head
|
||||
RandomInAway = 9,
|
||||
Random = 9,
|
||||
}
|
||||
|
||||
impl From<i32> for Direction {
|
||||
fn from(x: i32) -> Self {
|
||||
match x {
|
||||
0 => Direction::None,
|
||||
1 => Direction::Right,
|
||||
2 => Direction::UpRight,
|
||||
3 => Direction::Up,
|
||||
4 => Direction::UpLeft,
|
||||
5 => Direction::Left,
|
||||
6 => Direction::DownLeft,
|
||||
7 => Direction::Down,
|
||||
8 => Direction::DownRight,
|
||||
9 => Direction::Random,
|
||||
_ => panic!("Invalid direction {}", x),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
//pub static FIGHTER_FACING_LEFT: f32 = 1.0;
|
||||
pub static FIGHTER_FACING_RIGHT: f32 = -1.0;
|
||||
pub static ANGLE_NONE: f64 = -69.0;
|
||||
pub fn direction_to_angle(direction: Direction) -> f64 {
|
||||
match direction {
|
||||
Direction::None => ANGLE_NONE,
|
||||
Direction::Random => ANGLE_NONE, // Random Direction should be handled by the calling context
|
||||
_ => (direction as i32 - 1) as f64 * PI / 4.0,
|
||||
}
|
||||
}
|
||||
|
||||
/// Mash Attack States
|
||||
|
@ -220,7 +259,8 @@ pub enum MashInNeutral {
|
|||
#[repr(C)]
|
||||
pub struct TrainingModpackMenu {
|
||||
pub hitbox_vis: HitboxVisualization,
|
||||
pub di_state: DirectionalInfluence,
|
||||
pub di_state: Direction,
|
||||
pub left_stick: Direction, // Currently only used for air dodge direction
|
||||
pub mash_attack_state: Attack,
|
||||
pub ledge_state: LedgeOption,
|
||||
pub tech_state: TechOption,
|
||||
|
@ -228,5 +268,5 @@ pub struct TrainingModpackMenu {
|
|||
pub shield_state: Shield,
|
||||
pub defensive_state: Defensive,
|
||||
pub oos_offset: i32,
|
||||
pub mash_in_neutral: MashInNeutral
|
||||
pub mash_in_neutral: MashInNeutral,
|
||||
}
|
||||
|
|
|
@ -7,7 +7,8 @@ use smash::lib::lua_const::*;
|
|||
|
||||
pub static mut MENU_STRUCT: consts::TrainingModpackMenu = consts::TrainingModpackMenu {
|
||||
hitbox_vis: HitboxVisualization::On,
|
||||
di_state: DirectionalInfluence::None,
|
||||
di_state: Direction::None,
|
||||
left_stick: Direction::None,
|
||||
mash_attack_state: Attack::Nair,
|
||||
ledge_state: LedgeOption::Random,
|
||||
tech_state: TechOption::Random,
|
||||
|
|
|
@ -8,7 +8,6 @@ use smash::lib::L2CValue;
|
|||
use smash::lua2cpp::L2CFighterCommon;
|
||||
|
||||
pub static mut DI_ANGLE: f64 = 0.0;
|
||||
pub static NO_DI: f64 = -69.0;
|
||||
|
||||
#[skyline::hook(replace = smash::lua2cpp::L2CFighterCommon_FighterStatusDamage__correctDamageVectorCommon)]
|
||||
pub unsafe fn handle_correct_damage_vector_common(
|
||||
|
@ -24,7 +23,7 @@ unsafe fn mod_handle_di(fighter: &mut L2CFighterCommon, _arg1: L2CValue) {
|
|||
return;
|
||||
}
|
||||
|
||||
if MENU.di_state == DirectionalInfluence::None {
|
||||
if MENU.di_state == Direction::None {
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -34,22 +33,17 @@ unsafe fn mod_handle_di(fighter: &mut L2CFighterCommon, _arg1: L2CValue) {
|
|||
}
|
||||
|
||||
// Either left, right, or none
|
||||
if MENU.di_state == DirectionalInfluence::RandomInAway {
|
||||
DI_ANGLE = get_random_di();
|
||||
} else {
|
||||
DI_ANGLE = (MENU.di_state as i32 - 1) as f64 * PI / 4.0;
|
||||
DI_ANGLE = get_angle(MENU.di_state);
|
||||
// Nothig to do on no DI
|
||||
if DI_ANGLE == ANGLE_NONE {
|
||||
return;
|
||||
}
|
||||
|
||||
// If facing left, reverse angle
|
||||
if DI_ANGLE != NO_DI && PostureModule::lr(module_accessor) != -1.0 {
|
||||
if PostureModule::lr(module_accessor) != FIGHTER_FACING_RIGHT {
|
||||
DI_ANGLE -= PI;
|
||||
}
|
||||
|
||||
// Nothig to do on no DI
|
||||
if DI_ANGLE == NO_DI {
|
||||
return;
|
||||
}
|
||||
|
||||
WorkModule::set_float(
|
||||
module_accessor,
|
||||
DI_ANGLE.cos() as f32,
|
||||
|
@ -62,12 +56,23 @@ unsafe fn mod_handle_di(fighter: &mut L2CFighterCommon, _arg1: L2CValue) {
|
|||
);
|
||||
}
|
||||
|
||||
unsafe fn get_random_di() -> f64 {
|
||||
unsafe fn get_angle(direction: Direction) -> f64 {
|
||||
if direction == Direction::Random {
|
||||
let rand_direction = get_random_direction();
|
||||
return direction_to_angle(rand_direction);
|
||||
}
|
||||
|
||||
direction_to_angle(direction)
|
||||
}
|
||||
|
||||
unsafe fn get_random_direction() -> Direction {
|
||||
// Choose Left/Right/None
|
||||
let rand = app::sv_math::rand(hash40("fighter"), 3);
|
||||
if [0, 1].contains(&rand) {
|
||||
// Either 0 (right) or PI (left)
|
||||
rand as f64 * PI
|
||||
if rand == 0 {
|
||||
Direction::Left
|
||||
} else if rand == 1 {
|
||||
Direction::Right
|
||||
} else {
|
||||
NO_DI
|
||||
Direction::None
|
||||
}
|
||||
}
|
||||
|
|
74
src/training/left_stick.rs
Normal file
74
src/training/left_stick.rs
Normal file
|
@ -0,0 +1,74 @@
|
|||
use crate::common::consts::*;
|
||||
use crate::common::*;
|
||||
use core::f64::consts::PI;
|
||||
use smash::app::{self, lua_bind::*};
|
||||
use smash::hash40;
|
||||
|
||||
static mut STICK_DIRECTION: Direction = Direction::None;
|
||||
|
||||
pub unsafe fn mod_get_stick_x(
|
||||
module_accessor: &mut app::BattleObjectModuleAccessor,
|
||||
) -> Option<f32> {
|
||||
let angle: f64 = get_angle(module_accessor);
|
||||
|
||||
if angle == ANGLE_NONE {
|
||||
return None;
|
||||
}
|
||||
|
||||
Some(angle.cos() as f32)
|
||||
}
|
||||
|
||||
pub unsafe fn mod_get_stick_y(
|
||||
module_accessor: &mut app::BattleObjectModuleAccessor,
|
||||
) -> Option<f32> {
|
||||
let angle: f64 = get_angle(module_accessor);
|
||||
|
||||
if angle == ANGLE_NONE {
|
||||
return None;
|
||||
}
|
||||
|
||||
Some(angle.sin() as f32)
|
||||
}
|
||||
|
||||
unsafe fn get_angle(module_accessor: &mut app::BattleObjectModuleAccessor) -> f64 {
|
||||
if !is_training_mode() {
|
||||
return ANGLE_NONE;
|
||||
}
|
||||
|
||||
if !is_operation_cpu(module_accessor) {
|
||||
return ANGLE_NONE;
|
||||
}
|
||||
|
||||
// Currently used for air dodge//Drift only
|
||||
if !(is_airborne(module_accessor) && is_in_hitstun(module_accessor)) {
|
||||
return ANGLE_NONE;
|
||||
}
|
||||
|
||||
STICK_DIRECTION = MENU.left_stick;
|
||||
let mut angle: f64 = pick_angle(STICK_DIRECTION);
|
||||
|
||||
if angle == ANGLE_NONE {
|
||||
return ANGLE_NONE;
|
||||
}
|
||||
|
||||
// If facing left, reverse angle
|
||||
if PostureModule::lr(module_accessor) != FIGHTER_FACING_RIGHT {
|
||||
angle -= PI;
|
||||
}
|
||||
|
||||
angle
|
||||
}
|
||||
|
||||
unsafe fn pick_angle(direction: Direction) -> f64 {
|
||||
if direction == Direction::Random {
|
||||
let rand_direction = get_random_direction();
|
||||
return direction_to_angle(rand_direction);
|
||||
}
|
||||
|
||||
direction_to_angle(direction)
|
||||
}
|
||||
|
||||
unsafe fn get_random_direction() -> Direction {
|
||||
let rand = app::sv_math::rand(hash40("fighter"), 8);
|
||||
Direction::from(rand)
|
||||
}
|
|
@ -179,7 +179,7 @@ pub unsafe fn check_button_on(
|
|||
}
|
||||
|
||||
if MENU.mash_state == Mash::Airdodge
|
||||
&& !(is_in_hitstun(module_accessor)
|
||||
&& (is_in_hitstun(module_accessor)
|
||||
|| is_in_landing(module_accessor)
|
||||
|| is_in_footstool(module_accessor))
|
||||
{
|
||||
|
|
|
@ -7,6 +7,7 @@ pub mod directional_influence;
|
|||
pub mod shield;
|
||||
pub mod tech;
|
||||
|
||||
mod left_stick;
|
||||
mod ledge;
|
||||
mod mash;
|
||||
mod save_states;
|
||||
|
@ -54,6 +55,43 @@ pub unsafe fn handle_get_command_flag_cat(
|
|||
flag
|
||||
}
|
||||
|
||||
/**
|
||||
* This is called to get the stick position when
|
||||
* shielding (shield tilt)
|
||||
* 1 is fully right, -1 is fully left
|
||||
*/
|
||||
#[skyline::hook(replace = ControlModule::get_stick_x_no_clamp)]
|
||||
pub unsafe fn get_stick_x_no_clamp(module_accessor: &mut app::BattleObjectModuleAccessor) -> f32 {
|
||||
left_stick::mod_get_stick_x(module_accessor).unwrap_or_else(|| original!()(module_accessor))
|
||||
}
|
||||
/**
|
||||
* This is called to get the stick position when
|
||||
* shielding (shield tilt)
|
||||
* 1 is fully up, -1 is fully down
|
||||
*/
|
||||
#[skyline::hook(replace = ControlModule::get_stick_y_no_clamp)]
|
||||
pub unsafe fn get_stick_y_no_clamp(module_accessor: &mut app::BattleObjectModuleAccessor) -> f32 {
|
||||
left_stick::mod_get_stick_y(module_accessor).unwrap_or_else(|| original!()(module_accessor))
|
||||
}
|
||||
|
||||
/**
|
||||
* Called when:
|
||||
* Walking in the facing direction
|
||||
* Air Dodging
|
||||
*/
|
||||
#[skyline::hook(replace = ControlModule::get_stick_x)]
|
||||
pub unsafe fn get_stick_x(module_accessor: &mut app::BattleObjectModuleAccessor) -> f32 {
|
||||
left_stick::mod_get_stick_x(module_accessor).unwrap_or_else(|| original!()(module_accessor))
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
#[skyline::hook(replace = ControlModule::get_stick_y)]
|
||||
pub unsafe fn get_stick_y(module_accessor: &mut app::BattleObjectModuleAccessor) -> f32 {
|
||||
left_stick::mod_get_stick_y(module_accessor).unwrap_or_else(|| original!()(module_accessor))
|
||||
}
|
||||
|
||||
// int get_pad_flag(u64 module_accessor) {
|
||||
// u64 control_module = load_module(module_accessor, 0x48);
|
||||
// int (*get_pad_flag)(u64) = (int (*)(u64)) load_module_impl(control_module, 0x348);
|
||||
|
@ -78,13 +116,13 @@ pub unsafe fn handle_get_command_flag_cat(
|
|||
// return stick_x;
|
||||
// }
|
||||
|
||||
// float get_stick_y_replace(u64 module_accessor) {
|
||||
// float get_attack_air_stick_x_replace(u64 module_accessor) {
|
||||
// u64 control_module = load_module(module_accessor, 0x48);
|
||||
// float (*get_stick_y)(u64) = (float (*)(u64)) load_module_impl(control_module, 0x188);
|
||||
// float stick_y = get_stick_y(control_module);
|
||||
// float (*get_attack_air_stick_x)(u64) = (float (*)(u64)) load_module_impl(control_module, 0x188);
|
||||
// float stick_y = get_attack_air_stick_x(control_module);
|
||||
|
||||
// bool replace;
|
||||
// float ret = InputRecorder::get_stick_y(module_accessor, replace);
|
||||
// float ret = InputRecorder::get_attack_air_stick_x(module_accessor, replace);
|
||||
// if (replace) return ret;
|
||||
|
||||
// return stick_y;
|
||||
|
@ -161,6 +199,9 @@ pub fn training_mods() {
|
|||
handle_get_attack_air_kind,
|
||||
// Tech options
|
||||
handle_change_motion,
|
||||
// Directional AirDodge,
|
||||
get_stick_x,
|
||||
get_stick_y,
|
||||
);
|
||||
|
||||
// // Input recorder
|
||||
|
@ -168,6 +209,6 @@ pub fn training_mods() {
|
|||
// "_ZN3app8lua_bind31ControlModule__get_stick_x_implEPNS_26BattleObjectModuleAccessorE",
|
||||
// (u64)&ControlModule::get_stick_x_replace);
|
||||
// SaltySD_function_replace_sym(
|
||||
// "_ZN3app8lua_bind31ControlModule__get_stick_y_implEPNS_26BattleObjectModuleAccessorE",
|
||||
// (u64)&ControlModule::get_stick_y_replace);
|
||||
// "_ZN3app8lua_bind31ControlModule__get_attack_air_stick_x_implEPNS_26BattleObjectModuleAccessorE",
|
||||
// (u64)&ControlModule::get_attack_air_stick_x_replace);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue