diff --git a/autogen/lua_definitions/functions.lua b/autogen/lua_definitions/functions.lua index 2368f4055..7c60af805 100644 --- a/autogen/lua_definitions/functions.lua +++ b/autogen/lua_definitions/functions.lua @@ -3750,6 +3750,11 @@ function djui_hud_world_pos_to_screen_pos(pos, out) -- ... end +--- @return nil +function djui_open_pause_menu() + -- ... +end + --- @param message string --- @param lines integer --- @return nil diff --git a/docs/lua/functions-3.md b/docs/lua/functions-3.md index 17274cfa4..07547fd7d 100644 --- a/docs/lua/functions-3.md +++ b/docs/lua/functions-3.md @@ -2444,6 +2444,24 @@
+## [djui_open_pause_menu](#djui_open_pause_menu) + +### Lua Example +`djui_open_pause_menu()` + +### Parameters +- None + +### Returns +- None + +### C Prototype +`void djui_open_pause_menu(void);` + +[:arrow_up_small:](#) + +
+ --- # functions from djui_popup.h diff --git a/docs/lua/functions.md b/docs/lua/functions.md index 11f7b230c..0ab3fd853 100644 --- a/docs/lua/functions.md +++ b/docs/lua/functions.md @@ -735,6 +735,7 @@ - [djui_hud_set_resolution](functions-3.md#djui_hud_set_resolution) - [djui_hud_set_rotation](functions-3.md#djui_hud_set_rotation) - [djui_hud_world_pos_to_screen_pos](functions-3.md#djui_hud_world_pos_to_screen_pos) + - [djui_open_pause_menu](functions-3.md#djui_open_pause_menu)
diff --git a/src/game/interaction.c b/src/game/interaction.c index fd6ce58f9..7c15f85a1 100644 --- a/src/game/interaction.c +++ b/src/game/interaction.c @@ -2360,7 +2360,7 @@ void pss_end_slide(struct MarioState *m) { } void mario_handle_special_floors(struct MarioState *m) { - if ((m->action & ACT_GROUP_MASK) == ACT_GROUP_CUTSCENE) { + if ((m->action & ACT_GROUP_MASK) == ACT_GROUP_CUTSCENE || gDjuiInMainMenu) { return; } diff --git a/src/game/mario_actions_airborne.c b/src/game/mario_actions_airborne.c index 5eab3854b..e28ee43d3 100644 --- a/src/game/mario_actions_airborne.c +++ b/src/game/mario_actions_airborne.c @@ -55,7 +55,7 @@ void play_knockback_sound(struct MarioState *m) { s32 lava_boost_on_wall(struct MarioState *m) { bool allow = true; smlua_call_event_hooks_mario_param_and_int_ret_bool(HOOK_ALLOW_HAZARD_SURFACE, m, HAZARD_TYPE_LAVA_WALL, &allow); - if ((gServerSettings.enableCheats && gCheats.godMode) || (!allow)) { return FALSE; } + if ((gServerSettings.enableCheats && gCheats.godMode) || (!allow) || gDjuiInMainMenu) { return FALSE; } m->faceAngle[1] = atan2s(m->wallNormal[2], m->wallNormal[0]); if (m->forwardVel < 24.0f) { diff --git a/src/game/mario_step.c b/src/game/mario_step.c index 443b428e5..23f96b6b5 100644 --- a/src/game/mario_step.c +++ b/src/game/mario_step.c @@ -111,7 +111,8 @@ void mario_bonk_reflection(struct MarioState *m, u32 negateSpeed) { u32 mario_update_quicksand(struct MarioState *m, f32 sinkingSpeed) { bool allow = true; smlua_call_event_hooks_mario_param_and_int_ret_bool(HOOK_ALLOW_HAZARD_SURFACE, m, HAZARD_TYPE_QUICKSAND, &allow); - if (m->action & ACT_FLAG_RIDING_SHELL || (gServerSettings.enableCheats && gCheats.godMode && m->playerIndex == 0) || (!allow)) { + extern bool gDjuiInMainMenu; + if (m->action & ACT_FLAG_RIDING_SHELL || (gServerSettings.enableCheats && gCheats.godMode && m->playerIndex == 0) || (!allow) || gDjuiInMainMenu) { m->quicksandDepth = 0.0f; } else { if (m->quicksandDepth < 1.1f) { diff --git a/src/pc/djui/djui_hud_utils.c b/src/pc/djui/djui_hud_utils.c index 4132bf262..d6f58eb3a 100644 --- a/src/pc/djui/djui_hud_utils.c +++ b/src/pc/djui/djui_hud_utils.c @@ -560,3 +560,7 @@ void djui_hud_set_render_behind_hud(bool enable) { bool djui_hud_is_pause_menu_created(void) { return gDjuiPanelPauseCreated; } + +void djui_open_pause_menu(void) { + djui_panel_pause_create(NULL); +} diff --git a/src/pc/djui/djui_hud_utils.h b/src/pc/djui/djui_hud_utils.h index d069153f6..7372338ba 100644 --- a/src/pc/djui/djui_hud_utils.h +++ b/src/pc/djui/djui_hud_utils.h @@ -69,4 +69,6 @@ void djui_hud_set_render_behind_hud(bool enable); bool djui_hud_is_pause_menu_created(void); +void djui_open_pause_menu(void); + #endif \ No newline at end of file diff --git a/src/pc/lua/smlua_functions_autogen.c b/src/pc/lua/smlua_functions_autogen.c index 6f3c2b3b5..8b0b78b01 100644 --- a/src/pc/lua/smlua_functions_autogen.c +++ b/src/pc/lua/smlua_functions_autogen.c @@ -12422,6 +12422,21 @@ int smlua_func_djui_hud_world_pos_to_screen_pos(lua_State* L) { return 1; } +int smlua_func_djui_open_pause_menu(UNUSED lua_State* L) { + if (L == NULL) { return 0; } + + int top = lua_gettop(L); + if (top != 0) { + LOG_LUA_LINE("Improper param count for '%s': Expected %u, Received %u", "djui_open_pause_menu", 0, top); + return 0; + } + + + djui_open_pause_menu(); + + return 1; +} + ////////////////// // djui_popup.h // ////////////////// @@ -30727,6 +30742,7 @@ void smlua_bind_functions_autogen(void) { smlua_bind_function(L, "djui_hud_set_resolution", smlua_func_djui_hud_set_resolution); smlua_bind_function(L, "djui_hud_set_rotation", smlua_func_djui_hud_set_rotation); smlua_bind_function(L, "djui_hud_world_pos_to_screen_pos", smlua_func_djui_hud_world_pos_to_screen_pos); + smlua_bind_function(L, "djui_open_pause_menu", smlua_func_djui_open_pause_menu); // djui_popup.h smlua_bind_function(L, "djui_popup_create", smlua_func_djui_popup_create);