mirror of
https://github.com/HarbourMasters/Shipwright.git
synced 2025-01-10 05:28:06 -05:00
Rocs Feather - LetItSnow Edition - No Save Edition - Limited Edition (#4577)
* Rocs Feather Take 2 * Tooltip
This commit is contained in:
parent
f1dc432589
commit
7d3b9e8211
@ -2461,6 +2461,9 @@ s32 Ship_CalcShouldDrawAndUpdate(PlayState* play, Actor* actor, Vec3f* projected
|
|||||||
void PauseWarp_HandleSelection();
|
void PauseWarp_HandleSelection();
|
||||||
void PauseWarp_Execute();
|
void PauseWarp_Execute();
|
||||||
|
|
||||||
|
// Exposing for Roc's Feather
|
||||||
|
void func_80838940(Player* this, LinkAnimationHeader* anim, f32 arg2, PlayState* play, u16 sfxId);
|
||||||
|
|
||||||
// #endregion
|
// #endregion
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
76
soh/soh/Enhancements/Holiday/aMannus.cpp
Normal file
76
soh/soh/Enhancements/Holiday/aMannus.cpp
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
#include "Holiday.hpp"
|
||||||
|
|
||||||
|
#define AUTHOR "aMannus"
|
||||||
|
#define CVAR(v) "gHoliday." AUTHOR "." v
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include <z64.h>;
|
||||||
|
#include "functions.h";
|
||||||
|
#include "variables.h";
|
||||||
|
#include "macros.h";
|
||||||
|
#include "objects/gameplay_keep/gameplay_keep.h"
|
||||||
|
extern PlayState* gPlayState;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t rocsUseCount = 0;
|
||||||
|
|
||||||
|
static void ConfigurationChanged() {
|
||||||
|
|
||||||
|
COND_HOOK(OnPlayerUpdate, CVarGetInteger(CVAR("RocsFeather"), 0), []() {
|
||||||
|
Player* player = GET_PLAYER(gPlayState);
|
||||||
|
// Reset Rocs count when touching the ground
|
||||||
|
if (player->actor.bgCheckFlags & 1) {
|
||||||
|
rocsUseCount = 0;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
COND_VB_SHOULD(VB_USE_ITEM, CVarGetInteger(CVAR("RocsFeather"), 0), {
|
||||||
|
int32_t* usedItem = va_arg(args, int32_t*);
|
||||||
|
Player* player = GET_PLAYER(gPlayState);
|
||||||
|
|
||||||
|
// Roc's Feather behaviour
|
||||||
|
if (*usedItem == ITEM_NAYRUS_LOVE) {
|
||||||
|
*should = false;
|
||||||
|
|
||||||
|
if (!rocsUseCount) {
|
||||||
|
rocsUseCount++;
|
||||||
|
player->linearVelocity = 5.0f;
|
||||||
|
player->actor.velocity.y = 8.0f;
|
||||||
|
player->actor.world.rot.y = player->yaw = player->actor.shape.rot.y;
|
||||||
|
|
||||||
|
func_80838940(player, (LinkAnimationHeader*)&gPlayerAnim_link_fighter_backturn_jump,
|
||||||
|
!(2 & 1) ? 5.8f : 3.5f, gPlayState, 0);
|
||||||
|
|
||||||
|
Vec3f effectsPos = player->actor.home.pos;
|
||||||
|
effectsPos.y += 3;
|
||||||
|
f32 effectsScale = 1;
|
||||||
|
if (!gSaveContext.linkAge) {
|
||||||
|
effectsScale = 1.5f;
|
||||||
|
}
|
||||||
|
EffectSsGRipple_Spawn(gPlayState, &effectsPos, 200 * effectsScale, 300 * effectsScale, 1);
|
||||||
|
EffectSsGSplash_Spawn(gPlayState, &effectsPos, NULL, NULL, 0, 150 * effectsScale);
|
||||||
|
|
||||||
|
player->stateFlags2 &= ~(PLAYER_STATE2_HOPPING);
|
||||||
|
|
||||||
|
Player_PlaySfx(&player->actor, NA_SE_PL_SKIP);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
static void DrawMenu() {
|
||||||
|
ImGui::SeparatorText(AUTHOR);
|
||||||
|
|
||||||
|
if (UIWidgets::EnhancementCheckbox("Roc's Feather", CVAR("RocsFeather"))) {
|
||||||
|
ConfigurationChanged();
|
||||||
|
}
|
||||||
|
UIWidgets::Tooltip("Using Nayru's Love will now act as Roc's Feather instead! No magic required.");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void RegisterMod() {
|
||||||
|
// #region Leave this alone unless you know what you are doing
|
||||||
|
ConfigurationChanged();
|
||||||
|
// #endregion
|
||||||
|
}
|
||||||
|
|
||||||
|
static Holiday holiday(DrawMenu, RegisterMod);
|
@ -344,6 +344,7 @@ typedef enum {
|
|||||||
VB_PLAY_THROW_ANIMATION,
|
VB_PLAY_THROW_ANIMATION,
|
||||||
VB_INFLICT_VOID_DAMAGE,
|
VB_INFLICT_VOID_DAMAGE,
|
||||||
VB_GANONDORF_DECIDE_TO_FIGHT,
|
VB_GANONDORF_DECIDE_TO_FIGHT,
|
||||||
|
VB_USE_ITEM,
|
||||||
|
|
||||||
/*** Give Items ***/
|
/*** Give Items ***/
|
||||||
|
|
||||||
|
@ -2572,8 +2572,10 @@ void Player_ProcessItemButtons(Player* this, PlayState* play) {
|
|||||||
sHeldItemButtonIsHeldDown = true;
|
sHeldItemButtonIsHeldDown = true;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
this->heldItemButton = i;
|
if (GameInteractor_Should(VB_USE_ITEM, true, &item)) {
|
||||||
Player_UseItem(play, this, item);
|
this->heldItemButton = i;
|
||||||
|
Player_UseItem(play, this, item);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user