mirror of
https://github.com/HarbourMasters/Shipwright.git
synced 2025-01-08 12:28:10 -05:00
Free Camera (#337)
* wip free cam * Almost done, needs collision still * Added free cam behind cvar * added WIP collision * Fixed & implemented "Manual mode" from WW & TP * Fixed camera not rotating when Link is moving * fixed initialized camera rotation * Fixed camera getting stuck + made it smoother * reduced deadzone * fixed epona camera height + added WW z-target free camera * Adjusted player camera height & fixed fov * Fixed camera roll * fixed fov when moving the camera while in z-target * Camera resets to Auto when going through doors or changing maps * Fixed building * touch * more touch work * Added WIP mouse support to the free cam * gui stuff * fixed building * fixed building error * ok fixed building for real this time * oops * Fix compilation issues * removed mouse stuff that magically appeared in this branch * smoothed out stick values & removed remains of mouse support * re-added manual camera when pressing Z * reduced minimum Y position of camera * Addressed dcsv's nitpicks * part 2 * oops Co-authored-by: David Chavez <david@dcvz.io>
This commit is contained in:
parent
3aa93b9855
commit
66ec623542
@ -2,6 +2,12 @@
|
|||||||
#include "GlobalCtx2.h"
|
#include "GlobalCtx2.h"
|
||||||
#include "stox.h"
|
#include "stox.h"
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
#if __APPLE__
|
||||||
|
#include <SDL_events.h>
|
||||||
|
#else
|
||||||
|
#include <SDL2/SDL_events.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace Ship {
|
namespace Ship {
|
||||||
Controller::Controller(int32_t dwControllerNumber) : dwControllerNumber(dwControllerNumber) {
|
Controller::Controller(int32_t dwControllerNumber) : dwControllerNumber(dwControllerNumber) {
|
||||||
@ -16,8 +22,12 @@ namespace Ship {
|
|||||||
void Controller::Read(OSContPad* pad) {
|
void Controller::Read(OSContPad* pad) {
|
||||||
ReadFromSource();
|
ReadFromSource();
|
||||||
|
|
||||||
|
SDL_PumpEvents();
|
||||||
|
|
||||||
|
// Button Inputs
|
||||||
pad->button |= dwPressedButtons & 0xFFFF;
|
pad->button |= dwPressedButtons & 0xFFFF;
|
||||||
|
|
||||||
|
// Stick Inputs
|
||||||
if (pad->stick_x == 0) {
|
if (pad->stick_x == 0) {
|
||||||
if (dwPressedButtons & BTN_STICKLEFT) {
|
if (dwPressedButtons & BTN_STICKLEFT) {
|
||||||
pad->stick_x = -128;
|
pad->stick_x = -128;
|
||||||
@ -42,8 +52,13 @@ namespace Ship {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Gyro
|
||||||
pad->gyro_x = wGyroX;
|
pad->gyro_x = wGyroX;
|
||||||
pad->gyro_y = wGyroY;
|
pad->gyro_y = wGyroY;
|
||||||
|
|
||||||
|
// Right Stick
|
||||||
|
pad->cam_x = wCamX;
|
||||||
|
pad->cam_y = wCamY;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Controller::SetButtonMapping(const std::string& szButtonName, int32_t dwScancode) {
|
void Controller::SetButtonMapping(const std::string& szButtonName, int32_t dwScancode) {
|
||||||
|
@ -13,7 +13,6 @@
|
|||||||
|
|
||||||
namespace Ship {
|
namespace Ship {
|
||||||
class Controller {
|
class Controller {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Controller(int32_t dwControllerNumber);
|
Controller(int32_t dwControllerNumber);
|
||||||
|
|
||||||
@ -38,6 +37,8 @@ namespace Ship {
|
|||||||
int8_t wStickY;
|
int8_t wStickY;
|
||||||
float wGyroX;
|
float wGyroX;
|
||||||
float wGyroY;
|
float wGyroY;
|
||||||
|
float wCamX;
|
||||||
|
float wCamY;
|
||||||
|
|
||||||
virtual std::string GetControllerType() = 0;
|
virtual std::string GetControllerType() = 0;
|
||||||
virtual std::string GetConfSection() = 0;
|
virtual std::string GetConfSection() = 0;
|
||||||
|
@ -1143,6 +1143,8 @@ namespace SohImGui {
|
|||||||
EnhancementCheckbox("Skip Text", "gSkipText");
|
EnhancementCheckbox("Skip Text", "gSkipText");
|
||||||
Tooltip("Holding down B skips text\nKnown to cause a cutscene softlock in Water Temple\nSoftlock can be fixed by pressing D-Right in Debug mode");
|
Tooltip("Holding down B skips text\nKnown to cause a cutscene softlock in Water Temple\nSoftlock can be fixed by pressing D-Right in Debug mode");
|
||||||
|
|
||||||
|
EnhancementCheckbox("Free Camera", "gFreeCamera");
|
||||||
|
|
||||||
ImGui::EndMenu();
|
ImGui::EndMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,7 +114,9 @@ typedef struct {
|
|||||||
/* 0x04 */ u8 err_no;
|
/* 0x04 */ u8 err_no;
|
||||||
/* 0x05 */ f32 gyro_x;
|
/* 0x05 */ f32 gyro_x;
|
||||||
/* 0x09 */ f32 gyro_y;
|
/* 0x09 */ f32 gyro_y;
|
||||||
} OSContPad; // size = 0x0D
|
/* 0x1C */ f32 cam_x;
|
||||||
|
/* 0x20 */ f32 cam_y;
|
||||||
|
} OSContPad; // size = 0x24
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
/* 0x00 */ u8 rumble;
|
/* 0x00 */ u8 rumble;
|
||||||
|
@ -132,7 +132,7 @@ namespace Ship {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void SDLController::NormalizeStickAxis(int16_t wAxisValueX, int16_t wAxisValueY, int16_t wAxisThreshold) {
|
void SDLController::NormalizeStickAxis(int16_t wAxisValueX, int16_t wAxisValueY, int16_t wAxisThreshold, bool isRightStick) {
|
||||||
//scale {-32768 ... +32767} to {-84 ... +84}
|
//scale {-32768 ... +32767} to {-84 ... +84}
|
||||||
auto ax = wAxisValueX * 85.0 / 32767.0;
|
auto ax = wAxisValueX * 85.0 / 32767.0;
|
||||||
auto ay = wAxisValueY * 85.0 / 32767.0;
|
auto ay = wAxisValueY * 85.0 / 32767.0;
|
||||||
@ -163,9 +163,16 @@ namespace Ship {
|
|||||||
ay *= scale;
|
ay *= scale;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!isRightStick) {
|
||||||
wStickX = +ax;
|
wStickX = +ax;
|
||||||
wStickY = -ay;
|
wStickY = -ay;
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
//SOHTODO KIRITO: Camera Sensitivity
|
||||||
|
wCamX = +ax * 15.0f;
|
||||||
|
wCamY = -ay * 15.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void SDLController::ReadFromSource() {
|
void SDLController::ReadFromSource() {
|
||||||
std::string ConfSection = GetBindingConfSection();
|
std::string ConfSection = GetBindingConfSection();
|
||||||
@ -187,6 +194,10 @@ namespace Ship {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto cameraX = SDL_GameControllerGetAxis(Cont, SDL_CONTROLLER_AXIS_RIGHTX);
|
||||||
|
auto cameraY = SDL_GameControllerGetAxis(Cont, SDL_CONTROLLER_AXIS_RIGHTY);
|
||||||
|
NormalizeStickAxis(cameraX, cameraY, ThresholdMapping[SDL_CONTROLLER_AXIS_LEFTX], true);
|
||||||
|
|
||||||
if (SDL_GameControllerHasSensor(Cont, SDL_SENSOR_GYRO))
|
if (SDL_GameControllerHasSensor(Cont, SDL_SENSOR_GYRO))
|
||||||
{
|
{
|
||||||
size_t contNumber = GetControllerNumber();
|
size_t contNumber = GetControllerNumber();
|
||||||
@ -328,7 +339,7 @@ namespace Ship {
|
|||||||
if (StickAxisX != SDL_CONTROLLER_AXIS_INVALID && StickAxisY != SDL_CONTROLLER_AXIS_INVALID) {
|
if (StickAxisX != SDL_CONTROLLER_AXIS_INVALID && StickAxisY != SDL_CONTROLLER_AXIS_INVALID) {
|
||||||
auto AxisValueX = SDL_GameControllerGetAxis(Cont, StickAxisX);
|
auto AxisValueX = SDL_GameControllerGetAxis(Cont, StickAxisX);
|
||||||
auto AxisValueY = SDL_GameControllerGetAxis(Cont, StickAxisY);
|
auto AxisValueY = SDL_GameControllerGetAxis(Cont, StickAxisY);
|
||||||
NormalizeStickAxis(AxisValueX, AxisValueY, StickDeadzone);
|
NormalizeStickAxis(AxisValueX, AxisValueY, StickDeadzone, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -365,12 +376,13 @@ namespace Ship {
|
|||||||
void SDLController::CreateDefaultBinding() {
|
void SDLController::CreateDefaultBinding() {
|
||||||
std::string ConfSection = GetBindingConfSection();
|
std::string ConfSection = GetBindingConfSection();
|
||||||
std::shared_ptr<ConfigFile> pConf = GlobalCtx2::GetInstance()->GetConfig();
|
std::shared_ptr<ConfigFile> pConf = GlobalCtx2::GetInstance()->GetConfig();
|
||||||
|
|
||||||
ConfigFile& Conf = *pConf.get();
|
ConfigFile& Conf = *pConf.get();
|
||||||
|
|
||||||
Conf[ConfSection][STR(BTN_CRIGHT)] = std::to_string((SDL_CONTROLLER_AXIS_RIGHTX + AXIS_SCANCODE_BIT));
|
Conf[ConfSection][STR(BTN_CRIGHT)] = std::to_string(SDL_CONTROLLER_BUTTON_RIGHTSHOULDER);
|
||||||
Conf[ConfSection][STR(BTN_CLEFT)] = std::to_string(-(SDL_CONTROLLER_AXIS_RIGHTX + AXIS_SCANCODE_BIT));
|
Conf[ConfSection][STR(BTN_CLEFT)] = std::to_string(SDL_CONTROLLER_BUTTON_Y);
|
||||||
Conf[ConfSection][STR(BTN_CDOWN)] = std::to_string((SDL_CONTROLLER_AXIS_RIGHTY + AXIS_SCANCODE_BIT));
|
Conf[ConfSection][STR(BTN_CDOWN)] = std::to_string(SDL_CONTROLLER_BUTTON_X);
|
||||||
Conf[ConfSection][STR(BTN_CUP)] = std::to_string(-(SDL_CONTROLLER_AXIS_RIGHTY + AXIS_SCANCODE_BIT));
|
Conf[ConfSection][STR(BTN_CUP)] = std::to_string(SDL_CONTROLLER_BUTTON_RIGHTSTICK);
|
||||||
//Conf[ConfSection][STR(BTN_CRIGHT + "_2")] = std::to_string(SDL_CONTROLLER_BUTTON_X);
|
//Conf[ConfSection][STR(BTN_CRIGHT + "_2")] = std::to_string(SDL_CONTROLLER_BUTTON_X);
|
||||||
//Conf[ConfSection][STR(BTN_CLEFT + "_2")] = std::to_string(SDL_CONTROLLER_BUTTON_Y);
|
//Conf[ConfSection][STR(BTN_CLEFT + "_2")] = std::to_string(SDL_CONTROLLER_BUTTON_Y);
|
||||||
//Conf[ConfSection][STR(BTN_CDOWN + "_2")] = std::to_string(SDL_CONTROLLER_BUTTON_RIGHTSHOULDER);
|
//Conf[ConfSection][STR(BTN_CDOWN + "_2")] = std::to_string(SDL_CONTROLLER_BUTTON_RIGHTSHOULDER);
|
||||||
|
@ -44,7 +44,7 @@ namespace Ship {
|
|||||||
std::map<int32_t, int16_t> ThresholdMapping;
|
std::map<int32_t, int16_t> ThresholdMapping;
|
||||||
|
|
||||||
void LoadAxisThresholds();
|
void LoadAxisThresholds();
|
||||||
void NormalizeStickAxis(int16_t wAxisValueX, int16_t wAxisValueY, int16_t wAxisThreshold);
|
void NormalizeStickAxis(int16_t wAxisValueX, int16_t wAxisValueY, int16_t wAxisThreshold, bool isRightStick);
|
||||||
bool Open();
|
bool Open();
|
||||||
bool Close();
|
bool Close();
|
||||||
};
|
};
|
||||||
|
@ -120,7 +120,9 @@ typedef struct {
|
|||||||
/* 0x04 */ uint8_t err_no;
|
/* 0x04 */ uint8_t err_no;
|
||||||
/* 0x05 */ float gyro_x;
|
/* 0x05 */ float gyro_x;
|
||||||
/* 0x09 */ float gyro_y;
|
/* 0x09 */ float gyro_y;
|
||||||
} OSContPad; // size = 0x0D
|
/* 0x1C */ float cam_x;
|
||||||
|
/* 0x20 */ float cam_y;
|
||||||
|
} OSContPad; // size = 0x24
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
/* 0x00 */ uint8_t rumble;
|
/* 0x00 */ uint8_t rumble;
|
||||||
|
@ -1203,6 +1203,9 @@ typedef struct GlobalContext {
|
|||||||
/* 0x00790 */ Camera* cameraPtrs[NUM_CAMS];
|
/* 0x00790 */ Camera* cameraPtrs[NUM_CAMS];
|
||||||
/* 0x007A0 */ s16 activeCamera;
|
/* 0x007A0 */ s16 activeCamera;
|
||||||
/* 0x007A2 */ s16 nextCamera;
|
/* 0x007A2 */ s16 nextCamera;
|
||||||
|
/* 0x007A2 */ bool manualCamera;
|
||||||
|
/* 0x007A2 */ f32 camX;
|
||||||
|
/* 0x007A2 */ f32 camY;
|
||||||
/* 0x007A4 */ SequenceContext sequenceCtx;
|
/* 0x007A4 */ SequenceContext sequenceCtx;
|
||||||
/* 0x007A8 */ LightContext lightCtx;
|
/* 0x007A8 */ LightContext lightCtx;
|
||||||
/* 0x007B8 */ FrameAdvanceContext frameAdvCtx;
|
/* 0x007B8 */ FrameAdvanceContext frameAdvCtx;
|
||||||
|
@ -1409,7 +1409,125 @@ s32 Camera_Noop(Camera* camera) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
s32 SetCameraManual(Camera* camera) {
|
||||||
|
f32 newCamX = -D_8015BD7C->state.input[0].cur.cam_x;
|
||||||
|
f32 newCamY = D_8015BD7C->state.input[0].cur.cam_y;
|
||||||
|
|
||||||
|
if ((fabsf(newCamX) >= 15.0f || fabsf(newCamY) >= 15.0f) && camera->globalCtx->manualCamera == false) {
|
||||||
|
camera->globalCtx->manualCamera = true;
|
||||||
|
|
||||||
|
VecSph eyeAdjustment;
|
||||||
|
OLib_Vec3fDiffToVecSphGeo(&eyeAdjustment, &camera->at, &camera->eye);
|
||||||
|
|
||||||
|
camera->globalCtx->camX = eyeAdjustment.yaw;
|
||||||
|
camera->globalCtx->camY = eyeAdjustment.pitch;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (camera->globalCtx->manualCamera) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
s32 Camera_Free(Camera* camera) {
|
||||||
|
Normal1* norm1 = (Normal1*)camera->paramData;
|
||||||
|
|
||||||
|
f32 playerHeight = Player_GetHeight(camera->player);
|
||||||
|
f32 sp94;
|
||||||
|
CamColChk camBgChk;
|
||||||
|
PosRot* playerPosRot = &camera->playerPosRot;
|
||||||
|
Vec3f at;
|
||||||
|
|
||||||
|
sCameraInterfaceFlags = norm1->interfaceFlags;
|
||||||
|
|
||||||
|
if (RELOAD_PARAMS) {
|
||||||
|
VecSph eyeAdjustment1;
|
||||||
|
OLib_Vec3fDiffToVecSphGeo(&eyeAdjustment1, &camera->at, &camera->eye);
|
||||||
|
|
||||||
|
camera->globalCtx->camX = eyeAdjustment1.yaw;
|
||||||
|
camera->globalCtx->camY = eyeAdjustment1.pitch;
|
||||||
|
|
||||||
|
CameraModeValue* values = sCameraSettings[camera->setting].cameraModes[camera->mode].values;
|
||||||
|
f32 yNormal = (1.0f + PCT(R_CAM_YOFFSET_NORM) - PCT(R_CAM_YOFFSET_NORM) * (68.0f / playerHeight));
|
||||||
|
sp94 = yNormal * PCT(playerHeight);
|
||||||
|
|
||||||
|
norm1->yOffset = NEXTSETTING * sp94;
|
||||||
|
norm1->distMin = NEXTSETTING * sp94;
|
||||||
|
norm1->distMax = NEXTSETTING * sp94;
|
||||||
|
norm1->pitchTarget = DEGF_TO_BINANG(NEXTSETTING);
|
||||||
|
norm1->unk_0C = NEXTSETTING;
|
||||||
|
norm1->unk_10 = NEXTSETTING;
|
||||||
|
norm1->unk_14 = NEXTPCT;
|
||||||
|
norm1->fovTarget = NEXTSETTING;
|
||||||
|
norm1->atLERPScaleMax = NEXTPCT;
|
||||||
|
norm1->interfaceFlags = NEXTSETTING;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (R_RELOAD_CAM_PARAMS) {
|
||||||
|
Camera_CopyPREGToModeValues(camera);
|
||||||
|
}
|
||||||
|
|
||||||
|
VecSph eyeAdjustment;
|
||||||
|
const f32 camSpeed = 0.5f;
|
||||||
|
|
||||||
|
camera->animState = 0;
|
||||||
|
|
||||||
|
at.x = Camera_LERPCeilF(camera->player->actor.world.pos.x, camera->at.x, camSpeed, 1.0f);
|
||||||
|
at.y = Camera_LERPCeilF(camera->player->actor.world.pos.y + (camera->player->rideActor != NULL ? Player_GetHeight(camera->player) / 2 : Player_GetHeight(camera->player)) / 1.2f, camera->at.y, camSpeed, 1.0f);
|
||||||
|
at.z = Camera_LERPCeilF(camera->player->actor.world.pos.z, camera->at.z, camSpeed, 1.0f);
|
||||||
|
|
||||||
|
OLib_Vec3fDiffToVecSphGeo(&eyeAdjustment, &at, &camera->eye);
|
||||||
|
|
||||||
|
camBgChk.pos = camera->eye;
|
||||||
|
|
||||||
|
float maxRadius = 160.0f;
|
||||||
|
if (Camera_BGCheckInfo(camera, &at, &camBgChk)) {
|
||||||
|
VecSph collSphere;
|
||||||
|
OLib_Vec3fDiffToVecSphGeo(&collSphere, &at, &camBgChk.pos);
|
||||||
|
float rad = collSphere.r;
|
||||||
|
|
||||||
|
if (rad >= maxRadius) {
|
||||||
|
camera->dist = eyeAdjustment.r = Camera_LERPCeilF(maxRadius, camera->dist, camSpeed / 4, 1.0f);
|
||||||
|
} else {
|
||||||
|
camera->dist = eyeAdjustment.r = rad;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
camera->dist = eyeAdjustment.r = Camera_LERPCeilF(maxRadius, camera->dist, camSpeed / 4, 1.0f);
|
||||||
|
}
|
||||||
|
|
||||||
|
f32 newCamX = -D_8015BD7C->state.input[0].cur.cam_x;
|
||||||
|
f32 newCamY = D_8015BD7C->state.input[0].cur.cam_y;
|
||||||
|
|
||||||
|
camera->globalCtx->camX += newCamX;
|
||||||
|
camera->globalCtx->camY += newCamY;
|
||||||
|
|
||||||
|
if (camera->globalCtx->camY > 0x32A4) {
|
||||||
|
camera->globalCtx->camY = 0x32A4;
|
||||||
|
}
|
||||||
|
if (camera->globalCtx->camY < -0x228C) {
|
||||||
|
camera->globalCtx->camY = -0x228C;
|
||||||
|
}
|
||||||
|
|
||||||
|
eyeAdjustment.yaw = camera->globalCtx->camX;
|
||||||
|
eyeAdjustment.pitch = camera->globalCtx->camY;
|
||||||
|
|
||||||
|
Camera_Vec3fVecSphGeoAdd(&camera->eye, &at, &eyeAdjustment);
|
||||||
|
|
||||||
|
camera->at = at;
|
||||||
|
camera->fov = Camera_LERPCeilF(60.0f, camera->fov, camSpeed / 2, 1.0f);
|
||||||
|
camera->roll = 0;
|
||||||
|
camera->eyeNext = camera->eye;
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
s32 Camera_Normal1(Camera* camera) {
|
s32 Camera_Normal1(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
@ -1637,6 +1755,11 @@ s32 Camera_Normal1(Camera* camera) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
s32 Camera_Normal2(Camera* camera) {
|
s32 Camera_Normal2(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
@ -1803,6 +1926,11 @@ s32 Camera_Normal2(Camera* camera) {
|
|||||||
|
|
||||||
// riding epona
|
// riding epona
|
||||||
s32 Camera_Normal3(Camera* camera) {
|
s32 Camera_Normal3(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
@ -1997,6 +2125,8 @@ s32 Camera_Parallel1(Camera* camera) {
|
|||||||
OLib_Vec3fDiffToVecSphGeo(&atToEyeDir, at, eye);
|
OLib_Vec3fDiffToVecSphGeo(&atToEyeDir, at, eye);
|
||||||
OLib_Vec3fDiffToVecSphGeo(&atToEyeNextDir, at, eyeNext);
|
OLib_Vec3fDiffToVecSphGeo(&atToEyeNextDir, at, eyeNext);
|
||||||
|
|
||||||
|
camera->globalCtx->manualCamera = false;
|
||||||
|
|
||||||
switch (camera->animState) {
|
switch (camera->animState) {
|
||||||
case 0:
|
case 0:
|
||||||
case 0xA:
|
case 0xA:
|
||||||
@ -2162,6 +2292,11 @@ s32 Camera_Parallel0(Camera* camera) {
|
|||||||
* Generic jump, jumping off ledges
|
* Generic jump, jumping off ledges
|
||||||
*/
|
*/
|
||||||
s32 Camera_Jump1(Camera* camera) {
|
s32 Camera_Jump1(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
@ -2307,6 +2442,11 @@ s32 Camera_Jump1(Camera* camera) {
|
|||||||
|
|
||||||
// Climbing ladders/vines
|
// Climbing ladders/vines
|
||||||
s32 Camera_Jump2(Camera* camera) {
|
s32 Camera_Jump2(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
@ -2489,6 +2629,11 @@ s32 Camera_Jump2(Camera* camera) {
|
|||||||
|
|
||||||
// swimming
|
// swimming
|
||||||
s32 Camera_Jump3(Camera* camera) {
|
s32 Camera_Jump3(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
@ -2946,6 +3091,11 @@ s32 Camera_Battle3(Camera* camera) {
|
|||||||
* setting value.
|
* setting value.
|
||||||
*/
|
*/
|
||||||
s32 Camera_Battle4(Camera* camera) {
|
s32 Camera_Battle4(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
@ -4476,6 +4626,11 @@ s32 Camera_Data4(Camera* camera) {
|
|||||||
* Hanging off of a ledge
|
* Hanging off of a ledge
|
||||||
*/
|
*/
|
||||||
s32 Camera_Unique1(Camera* camera) {
|
s32 Camera_Unique1(Camera* camera) {
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && SetCameraManual(camera) == 1) {
|
||||||
|
Camera_Free(camera);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
Vec3f* eye = &camera->eye;
|
Vec3f* eye = &camera->eye;
|
||||||
Vec3f* at = &camera->at;
|
Vec3f* at = &camera->at;
|
||||||
Vec3f* eyeNext = &camera->eyeNext;
|
Vec3f* eyeNext = &camera->eyeNext;
|
||||||
|
@ -530,6 +530,10 @@ void Gameplay_Update(GlobalContext* globalCtx) {
|
|||||||
ActorOverlayTable_LogPrint();
|
ActorOverlayTable_LogPrint();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (CVar_GetS32("gFreeCamera", 0) && Player_InCsMode(globalCtx)) {
|
||||||
|
globalCtx->manualCamera = false;
|
||||||
|
}
|
||||||
|
|
||||||
gSegments[4] = VIRTUAL_TO_PHYSICAL(globalCtx->objectCtx.status[globalCtx->objectCtx.mainKeepIndex].segment);
|
gSegments[4] = VIRTUAL_TO_PHYSICAL(globalCtx->objectCtx.status[globalCtx->objectCtx.mainKeepIndex].segment);
|
||||||
gSegments[5] = VIRTUAL_TO_PHYSICAL(globalCtx->objectCtx.status[globalCtx->objectCtx.subKeepIndex].segment);
|
gSegments[5] = VIRTUAL_TO_PHYSICAL(globalCtx->objectCtx.status[globalCtx->objectCtx.subKeepIndex].segment);
|
||||||
gSegments[2] = VIRTUAL_TO_PHYSICAL(globalCtx->sceneSegment);
|
gSegments[2] = VIRTUAL_TO_PHYSICAL(globalCtx->sceneSegment);
|
||||||
|
@ -203,6 +203,11 @@ void FileChoose_DrawOptions(GameState* thisx);
|
|||||||
void FileChoose_DrawNameEntry(GameState* thisx);
|
void FileChoose_DrawNameEntry(GameState* thisx);
|
||||||
void FileChoose_DrawCharacter(GraphicsContext* gfxCtx, void* texture, s16 vtx);
|
void FileChoose_DrawCharacter(GraphicsContext* gfxCtx, void* texture, s16 vtx);
|
||||||
|
|
||||||
|
void HandleMouseInput(Input* input);
|
||||||
|
u8 HandleMouseCursor(FileChooseContext* this, Input* input, int minx, int miny, int maxx, int maxy);
|
||||||
|
Vec2f HandleMouseCursorSplit(FileChooseContext* this, Input* input, int minx, int miny, int maxx, int maxy, int countx,
|
||||||
|
int county);
|
||||||
|
|
||||||
extern s16 D_808123F0[];
|
extern s16 D_808123F0[];
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user