Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

use external camera #419

Open
wants to merge 234 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
234 commits
Select commit Hold shift + click to select a range
a1861e7
use external camera
xAstroBoy Feb 23, 2024
458a952
Remove stuff
xAstroBoy Feb 23, 2024
1514ccc
Merge branch 'main' into New-Camera
xAstroBoy Feb 23, 2024
17be599
style: format scripts
github-actions[bot] Feb 23, 2024
954733d
Update LcHaxCamera.cs
xAstroBoy Feb 23, 2024
4ac4d9c
Update lc-hax/Scripts/Helpers/Players.cs
xAstroBoy Feb 23, 2024
8c6421e
Remove pepega moment
xAstroBoy Feb 23, 2024
60dab09
style: format scripts
github-actions[bot] Feb 23, 2024
319a5ba
Update LcHaxCamera.cs
xAstroBoy Feb 23, 2024
774a57a
style: format scripts
github-actions[bot] Feb 23, 2024
65ae816
Discard changes to lc-hax/Scripts/Modules/Possession/Controllers/Brac…
xAstroBoy Feb 23, 2024
3547b79
Merge branch 'main' into New-Camera
winstxnhdw Feb 23, 2024
dffa8e3
Update LcHaxCamera.cs
xAstroBoy Feb 23, 2024
68ac2d4
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 23, 2024
9380d0d
Update LcHaxCamera.cs
xAstroBoy Feb 23, 2024
7fa117c
Update LcHaxCamera.cs
xAstroBoy Feb 23, 2024
e9fc937
Update LcHaxCamera.cs
xAstroBoy Feb 23, 2024
df7bcba
Fixes
xAstroBoy Feb 23, 2024
2a3101f
style: format scripts
github-actions[bot] Feb 23, 2024
454adb4
Fix jester not killing & bugfixes
xAstroBoy Feb 23, 2024
d2566ff
style: format scripts
github-actions[bot] Feb 23, 2024
e1b2689
Update JesterEnemyController.cs
xAstroBoy Feb 23, 2024
54fa508
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 23, 2024
e539a31
style: format scripts
github-actions[bot] Feb 23, 2024
2d21d4a
Update MaskedController.cs
xAstroBoy Feb 23, 2024
a50f661
style: format scripts
github-actions[bot] Feb 23, 2024
7a0314c
Update MaskedController.cs
xAstroBoy Feb 23, 2024
b0e046d
Minor fixes and call collision of enemies that aren't supposed to be …
xAstroBoy Feb 23, 2024
5f3365a
foward collision with player to enemy collision detection.
xAstroBoy Feb 23, 2024
b0e7bd9
Update SandSpiderController.cs
xAstroBoy Feb 23, 2024
6ea97a9
foward collision with player to enemy collision detection.
xAstroBoy Feb 23, 2024
7688b39
Update PossessionMod.cs
xAstroBoy Feb 23, 2024
5be2bac
Update PossessionMod.cs
xAstroBoy Feb 23, 2024
a5030d6
Add Kills for inside enemies if they are outside
xAstroBoy Feb 23, 2024
10c543d
style: format scripts
github-actions[bot] Feb 23, 2024
36c49bf
fixes
xAstroBoy Feb 23, 2024
5056eb9
style: format scripts
github-actions[bot] Feb 23, 2024
2593e7b
fixes
xAstroBoy Feb 23, 2024
4f5a716
Update PhantomMod.cs
xAstroBoy Feb 24, 2024
f90fdc6
Final Fixes
xAstroBoy Feb 24, 2024
fd8f417
style: format scripts
github-actions[bot] Feb 24, 2024
f90153a
thans @D1GQ
xAstroBoy Feb 24, 2024
4bc7d3b
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 24, 2024
cf268c4
Update HoardingBugController.cs
xAstroBoy Feb 24, 2024
8d842a9
Make Lc-Hax camera a core module.
xAstroBoy Feb 24, 2024
c494225
style: format scripts
github-actions[bot] Feb 24, 2024
3d7311d
dont spawn it , only phantom can spawn the hax camera.
xAstroBoy Feb 24, 2024
93d884c
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 24, 2024
f65f3a9
apply @D1GQ Changes
xAstroBoy Feb 24, 2024
65a14c5
Update JesterEnemyController.cs
xAstroBoy Feb 24, 2024
99eb129
remove killAnimation Check.
xAstroBoy Feb 24, 2024
c0301a8
Fix Jester & Spider
xAstroBoy Feb 24, 2024
fae48cb
Fix ClientID
xAstroBoy Feb 24, 2024
33ecfad
style: format scripts
github-actions[bot] Feb 24, 2024
e6cff54
Merge branch 'main' into New-Camera
winstxnhdw Feb 24, 2024
c1e31ab
Apply suggestions from code review
xAstroBoy Feb 24, 2024
0b2bd7a
Update JesterEnemyController.cs
xAstroBoy Feb 24, 2024
3595251
Fix Kill Animation
xAstroBoy Feb 24, 2024
21ebf09
Merge branch 'main' into New-Camera
winstxnhdw Feb 25, 2024
132c33b
style: format scripts
github-actions[bot] Feb 25, 2024
ca4a607
refactor: use actual enemy names
winstxnhdw Feb 25, 2024
924c36a
Added camera offsets to all enemies
D1GQ Feb 25, 2024
b417761
Added old enemy rotation back for no clip.
D1GQ Feb 25, 2024
ea177a1
Update BaboonHawkController.cs
xAstroBoy Feb 25, 2024
db6718e
Update BrackenController.cs
xAstroBoy Feb 25, 2024
50f0094
Merge pull request #2 from D1GQ/main
xAstroBoy Feb 25, 2024
8817478
Update BaboonHawkController.cs
xAstroBoy Feb 25, 2024
c436282
style: format scripts
github-actions[bot] Feb 25, 2024
0c92940
add treshold back
xAstroBoy Feb 25, 2024
1d9dda1
Update SandSpiderController.cs
xAstroBoy Feb 25, 2024
70fd167
Get rid of OnPlayerCollision, just patch PlayerTargetable
xAstroBoy Feb 25, 2024
e4993db
restore chqnges
xAstroBoy Feb 25, 2024
149d153
restore chqnges
xAstroBoy Feb 25, 2024
a1fff9f
Get rid of OnPlayerCollision, just patch PlayerTargetable
xAstroBoy Feb 25, 2024
b5671ab
style: format scripts
github-actions[bot] Feb 25, 2024
6b40084
style: format scripts
github-actions[bot] Feb 25, 2024
94e7ebc
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 25, 2024
039ae74
Update HoardingBugController.cs
xAstroBoy Feb 25, 2024
233a6b9
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 25, 2024
69f2fea
Merge pull request #3 from D1GQ/main
xAstroBoy Feb 25, 2024
f6067ff
Renaming
xAstroBoy Feb 25, 2024
cbb85bc
Fix Spider rotation for good
xAstroBoy Feb 25, 2024
6fee407
Better approach for Cam & Position offsets
xAstroBoy Feb 26, 2024
e738e67
cleanup
xAstroBoy Feb 26, 2024
40a54b4
style: format scripts
github-actions[bot] Feb 26, 2024
ae0cf5f
add X offset for camera (if needed)
xAstroBoy Feb 26, 2024
4e95328
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 26, 2024
69ab3a4
style: format scripts
github-actions[bot] Feb 26, 2024
f9bfe92
Update EyelessDogController.cs
xAstroBoy Feb 26, 2024
b39b3f0
style: format scripts
github-actions[bot] Feb 26, 2024
0e99a59
Merge branch 'main' into New-Camera
winstxnhdw Feb 26, 2024
19a1624
Merge branch 'main' into New-Camera
winstxnhdw Feb 26, 2024
ae7a8ca
Merge branch 'main' into New-Camera
winstxnhdw Feb 26, 2024
20f6256
perf(reflector): add caching capability
winstxnhdw Feb 26, 2024
1a9812f
Merge branch 'main' into New-Camera
xAstroBoy Feb 26, 2024
afb6219
Merge branch 'main' into New-Camera
winstxnhdw Feb 27, 2024
e5e91a7
style: format scripts
github-actions[bot] Feb 27, 2024
512b32d
Dont destroy camera anymore
xAstroBoy Feb 27, 2024
95975f3
style: format scripts
github-actions[bot] Feb 27, 2024
3cef6b7
Attempt to make camera exactly where player is looking at.
xAstroBoy Feb 27, 2024
719426e
style: format scripts
github-actions[bot] Feb 27, 2024
80dd516
Update HaxCamera.cs
xAstroBoy Feb 27, 2024
b7cfd37
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 27, 2024
0090eb6
style: format scripts
github-actions[bot] Feb 27, 2024
c7abbb4
Minor fixes
xAstroBoy Feb 27, 2024
d67f9e6
Update HaxCamera.cs
xAstroBoy Feb 27, 2024
7fb3bfc
Update HaxCamera.cs
xAstroBoy Feb 27, 2024
b6e27c7
turn gameobject directly than component.
xAstroBoy Feb 27, 2024
9140e5c
Update HaxCamera.cs
xAstroBoy Feb 27, 2024
2ec1877
style: format scripts
github-actions[bot] Feb 27, 2024
7b0ba13
Merge branch 'main' into New-Camera
xAstroBoy Feb 27, 2024
fbf9c6d
Update PhantomMod.cs
xAstroBoy Feb 27, 2024
3e709bc
style: format scripts
github-actions[bot] Feb 27, 2024
077794b
Update HaxCamera.cs
xAstroBoy Feb 27, 2024
73c5157
style: format scripts
github-actions[bot] Feb 27, 2024
c6e3996
Fix camera not deactivating
xAstroBoy Feb 27, 2024
bea15e1
Update Camera.cs
xAstroBoy Feb 27, 2024
99a8c56
style: format scripts
github-actions[bot] Feb 27, 2024
6d6d8fb
Bring camera disabler again
xAstroBoy Feb 27, 2024
3507722
Since we are not setting the parent, we copy the camera properties
xAstroBoy Feb 27, 2024
d0d8231
use ActiveCamera from now on
xAstroBoy Feb 27, 2024
5e3f31b
style: format scripts
github-actions[bot] Feb 27, 2024
7da9d91
Update PlayerIsTargetablePatch.cs
xAstroBoy Feb 28, 2024
3f7f038
Merge pull request #4 from D1GQ/main
xAstroBoy Feb 28, 2024
7b830ac
style: format scripts
github-actions[bot] Feb 28, 2024
b698f3a
Update PossessionPatch.cs
xAstroBoy Feb 28, 2024
235fb20
style: format scripts
github-actions[bot] Feb 28, 2024
d9ebb82
Update PossessionPatch.cs
xAstroBoy Feb 28, 2024
b5029a0
style: format scripts
github-actions[bot] Feb 28, 2024
2f90006
Update PossessionPatch.cs
xAstroBoy Feb 28, 2024
92278ba
Fixed 9967d56c6ef19af86424e8ed04459a42df6aac24 change that broke Cent…
xAstroBoy Feb 28, 2024
0d78be7
style: format scripts
github-actions[bot] Feb 28, 2024
e927bdc
Update PlayerIsTargetablePatch.cs
xAstroBoy Feb 28, 2024
4c5a8c1
style: format scripts
github-actions[bot] Feb 28, 2024
71b50f9
Update PlayerIsTargetablePatch.cs
xAstroBoy Feb 28, 2024
e42bab4
style: format scripts
github-actions[bot] Feb 28, 2024
f47199b
Update PlayerIsTargetablePatch.cs
xAstroBoy Feb 28, 2024
cee2348
Remove Ghost Girl WIP Controller
xAstroBoy Feb 28, 2024
38cae27
Update PossessionMod.cs
xAstroBoy Feb 28, 2024
f7a6c88
Update PlayerIsTargetablePatch.cs
xAstroBoy Feb 28, 2024
b458261
Merge branch 'winstxnhdw:main' into New-Camera
xAstroBoy Feb 28, 2024
085467e
use the right states
xAstroBoy Feb 28, 2024
1969e2e
style: format scripts
github-actions[bot] Feb 28, 2024
8142955
Fixes
xAstroBoy Feb 28, 2024
75095a4
style: format scripts
github-actions[bot] Feb 28, 2024
bbf7282
Have a longer delay if in SENTRY mode
D1GQ Feb 28, 2024
3625403
Merge pull request #5 from D1GQ/main
xAstroBoy Feb 28, 2024
62543d7
Fixes
xAstroBoy Feb 28, 2024
8648749
Fixes
xAstroBoy Feb 28, 2024
fbfdcf5
style: format scripts
github-actions[bot] Feb 28, 2024
e301cde
Fixed issues with spider nesting.
D1GQ Feb 29, 2024
533f547
Merge branch 'main' of https://github.com/D1GQ/lc-hax-small-controlle…
D1GQ Feb 29, 2024
a4add73
Fixed reoccurring IsAbleToMove issues
D1GQ Feb 29, 2024
e8f8d21
Hoarder Bug special ability, Play chitterSFX, if Modded Yippee.
D1GQ Feb 29, 2024
e0eda9c
Merge pull request #6 from D1GQ/main
xAstroBoy Feb 29, 2024
7c98630
Overhaul of PossessionMod
xAstroBoy Feb 29, 2024
2db69ea
Overhaul of PossessionMod
xAstroBoy Feb 29, 2024
acd5961
style: format scripts
github-actions[bot] Feb 29, 2024
611c85d
Update HoardingBugController.cs
xAstroBoy Feb 29, 2024
b45bb2d
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 29, 2024
9610d11
Update PossessionMod.cs
xAstroBoy Feb 29, 2024
b0654fb
style: format scripts
github-actions[bot] Feb 29, 2024
2935fef
Discard changes to lc-hax/Scripts/Commands/Mod Toggles/SanityToggle.cs
xAstroBoy Feb 29, 2024
c1f1618
Discard changes to lc-hax/Scripts/Commands/UnlimitedJumpCommand.cs
xAstroBoy Feb 29, 2024
86cee92
Discard changes to lc-hax/Scripts/Modules/SaneMod.cs
xAstroBoy Feb 29, 2024
a42d507
Update HoardingBugController.cs
xAstroBoy Feb 29, 2024
6494b09
Disable certain keys if typing.
xAstroBoy Feb 29, 2024
a27616b
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 29, 2024
95c3873
Update PossessionPatch.cs
xAstroBoy Feb 29, 2024
3c42f4a
block possession movement if typing.
xAstroBoy Feb 29, 2024
5fd264c
style: format scripts
github-actions[bot] Feb 29, 2024
7d4a270
Update HudPatch.cs
xAstroBoy Feb 29, 2024
bd2f85f
Update HudPatch.cs
xAstroBoy Feb 29, 2024
5a900e7
Update HudPatch.cs
xAstroBoy Feb 29, 2024
1986b27
style: format scripts
github-actions[bot] Feb 29, 2024
bc2b2bd
Update PossessionMod.cs
xAstroBoy Feb 29, 2024
cc27f5a
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 29, 2024
fa8fdac
Remove cooldown, use E to interact
xAstroBoy Feb 29, 2024
a9013b3
make instead interact than just move
xAstroBoy Feb 29, 2024
37a22bd
style: format scripts
github-actions[bot] Feb 29, 2024
2322737
allow enemies to open/close doors.
xAstroBoy Feb 29, 2024
bad384b
Merge branch 'New-Camera' of https://github.com/xAstroBoy/lc-hax into…
xAstroBoy Feb 29, 2024
9459239
allow enemies to open/close doors.
xAstroBoy Feb 29, 2024
da39153
style: format scripts
github-actions[bot] Feb 29, 2024
420f678
Merge branch 'main' into New-Camera
winstxnhdw Feb 29, 2024
e21d88f
Fixes and allow interaction with E on doors for enemies.
xAstroBoy Feb 29, 2024
253592c
Fixes and allow interaction with E on doors for enemies.
xAstroBoy Feb 29, 2024
443b5b6
style: format scripts
github-actions[bot] Feb 29, 2024
7887539
Cleanup and prevent raycast if maxrange is 0
xAstroBoy Feb 29, 2024
384c7b0
style: format scripts
github-actions[bot] Feb 29, 2024
3c7d15a
Cleanup
xAstroBoy Feb 29, 2024
0ce5e0f
style: format scripts
github-actions[bot] Feb 29, 2024
40f2c00
Update MaskedController.cs
xAstroBoy Feb 29, 2024
69b6a17
Merge branch 'main' into New-Camera
xAstroBoy Mar 1, 2024
4d7200c
feat: introduce experimental `fall` command
winstxnhdw Mar 4, 2024
5ed85de
Merge branch 'main' into New-Camera
winstxnhdw Mar 4, 2024
1d2724c
Merge branch 'main' into New-Camera
xAstroBoy Mar 5, 2024
aba1218
Discard changes to lc-hax/Scripts/Commands/FallCommand.cs
xAstroBoy Mar 5, 2024
1672df3
Merge branch 'main' into New-Camera
winstxnhdw Mar 5, 2024
554d813
Merge branch 'main' into New-Camera
winstxnhdw Mar 7, 2024
02318b2
refactor: remove redundant conditionals
winstxnhdw Mar 7, 2024
62d10aa
Merge branch 'main' into New-Camera
winstxnhdw Mar 16, 2024
8e890d7
style: fix whitespaces and indentation
winstxnhdw Mar 16, 2024
d85b4b2
refactor: cheat-relevant code should not be coupled with generic list…
winstxnhdw Mar 16, 2024
40eca1b
refactor/perf: infinitely cleaner and some perf wins
winstxnhdw Mar 16, 2024
2b0dd62
style: format scripts
github-actions[bot] Mar 16, 2024
2c7809b
feat: add `space` event
winstxnhdw Mar 16, 2024
756ad78
refactor: clean up baboon and bracken controllers
winstxnhdw Mar 16, 2024
e2ef82f
Merge branch 'main' into New-Camera
winstxnhdw Mar 17, 2024
90e5057
refactor: clean up controllers
winstxnhdw Mar 17, 2024
16b32a7
Merge branch 'main' into New-Camera
winstxnhdw Mar 17, 2024
48602a2
style: use full name consistently
winstxnhdw Mar 17, 2024
c93264b
fix: properly toggle sprinting
winstxnhdw Mar 17, 2024
90c60c7
feat: nobody asked for this
winstxnhdw Mar 17, 2024
0bc6215
refactor: bring back possession patch
winstxnhdw Mar 17, 2024
c875fee
chore: revert HUDPatch
winstxnhdw Mar 17, 2024
94286d6
refactor: light clean up
winstxnhdw Mar 17, 2024
729dc6e
refactor: abstract long condition into method
winstxnhdw Mar 17, 2024
1d93b7f
feat: allow enemies to attack outside
winstxnhdw Mar 17, 2024
275daeb
style: rearrange and rename
winstxnhdw Mar 17, 2024
778dc4a
Merge branch 'main' into New-Camera
winstxnhdw Mar 17, 2024
c5b9e83
refactor: massively cleaner HaxCamera
winstxnhdw Mar 17, 2024
b39c60e
refactor: certain things need not be copied
winstxnhdw Mar 17, 2024
2a365f3
refactor: no longer necessary to disable kb and mouse
winstxnhdw Mar 17, 2024
eb7c0f4
refactor: remove unnecessary internal
winstxnhdw Mar 17, 2024
75eb030
feat/docs: set all placeable objects upright
winstxnhdw Mar 19, 2024
cd1881a
Merge branch 'main' into New-Camera
winstxnhdw Mar 19, 2024
f32b719
Merge branch 'main' into New-Camera
winstxnhdw Mar 19, 2024
9720f2a
Merge branch 'main' into New-Camera
winstxnhdw Mar 25, 2024
6bf31e5
Merge branch 'main' into New-Camera
winstxnhdw Apr 10, 2024
88768fb
Merge branch 'main' into New-Camera
winstxnhdw Apr 14, 2024
70bbbd8
Merge branch 'main' into New-Camera
winstxnhdw Apr 20, 2024
1bdbf05
Merge branch 'main' into New-Camera
xAstroBoy Apr 28, 2024
31e830b
Merge branch 'main' into New-Camera
winstxnhdw Oct 2, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
116 changes: 50 additions & 66 deletions lc-hax/Scripts/Components/CharacterMovement.cs
Original file line number Diff line number Diff line change
Expand Up @@ -5,27 +5,34 @@
using Hax;

class CharacterMovement : MonoBehaviour {
// Movement constants
const float WalkingSpeed = 0.5f; // Walking speed when left control is held
const float SprintDuration = 0.0f; // Duration sprint key must be held for sprinting (adjust as needed)
const float WalkingSpeed = 0.5f;
const float SprintDuration = 0.0f;
const float JumpForce = 9.2f;
const float Gravity = 18.0f;

internal float CharacterSpeed { get; set; } = 5.0f;
internal float CharacterSprintSpeed { get; set; } = 2.8f;

// used to sync with the enemy to make sure it plays the correct animation when it is moving
internal bool CanMove { get; set; } = true;
internal bool IsMoving { get; private set; } = false;
internal bool IsSprinting { get; private set; } = false;

// Components and state variables
float VelocityY { get; set; } = 0.0f;
bool IsSprintHeld { get; set; } = false;
float SprintTimer { get; set; } = 0.0f;
Keyboard Keyboard { get; set; } = Keyboard.current;
KeyboardMovement? NoClipKeyboard { get; set; } = null;
bool IsSprintHeld { get; set; } = false;

Keyboard Keyboard { get; } = Keyboard.current;
KeyboardMovement? NoClipKeyboard { get; set; }
CharacterController? CharacterController { get; set; }

void Awake() {
this.NoClipKeyboard = this.gameObject.AddComponent<KeyboardMovement>();
this.CharacterController = this.gameObject.AddComponent<CharacterController>();
}

void OnEnable() => InputListener.OnSpacePress += this.Jump;

void OnDisable() => InputListener.OnSpacePress -= this.Jump;

internal void SetNoClipMode(bool enabled) {
if (this.NoClipKeyboard is null) return;
this.NoClipKeyboard.enabled = enabled;
Expand All @@ -44,7 +51,6 @@ internal void SetPosition(Vector3 newPosition) {
this.CharacterController.enabled = true;
}


internal void CalibrateCollision(EnemyAI enemy) {
if (this.CharacterController is null) return;

Expand All @@ -60,56 +66,11 @@ internal void CalibrateCollision(EnemyAI enemy) {
.ForEach(collider => Physics.IgnoreCollision(this.CharacterController, collider));
}


void Awake() {
this.Keyboard = Keyboard.current;
this.NoClipKeyboard = this.gameObject.AddComponent<KeyboardMovement>();
this.CharacterController = this.gameObject.AddComponent<CharacterController>();
}

// Update is called once per frame
void Update() {
if (this.NoClipKeyboard is { enabled: true }) return;
if (this.CharacterController is { enabled: false }) return;

Vector2 moveInput = new Vector2(
this.Keyboard.dKey.ReadValue() - this.Keyboard.aKey.ReadValue(),
this.Keyboard.wKey.ReadValue() - this.Keyboard.sKey.ReadValue()
).normalized;

this.IsMoving = moveInput.magnitude > 0.0f;

float speedModifier = this.Keyboard.leftCtrlKey.isPressed
? CharacterMovement.WalkingSpeed
: 1.0f;

// Calculate movement direction relative to character's forward direction
Vector3 forward = Vector3.ProjectOnPlane(this.transform.forward, Vector3.up);
Vector3 right = Vector3.ProjectOnPlane(this.transform.right, Vector3.up);
Vector3 moveDirection = (forward * moveInput.y) + (right * moveInput.x);

// Apply speed and sprint modifiers
moveDirection *= speedModifier * (
this.IsSprinting
? this.CharacterSpeed * this.CharacterSprintSpeed
: this.CharacterSpeed
);

// Apply gravity
this.ApplyGravity();

// Attempt to move
_ = this.CharacterController?.Move(moveDirection * Time.deltaTime);

// Jump if jump key is pressed
if (this.Keyboard.spaceKey.wasPressedThisFrame) {
this.Jump();
}

// Sprinting mechanic: Hold to sprint
void Move(Vector3 moveDirection) {
if (Helper.LocalPlayer is { isTypingChat: true } || !this.CanMove) return;
if (this.Keyboard.leftShiftKey.isPressed) {
if (!this.IsSprintHeld) {
this.SprintTimer = 0f;
this.SprintTimer = 0.0f;
this.IsSprintHeld = true;
}

winstxnhdw marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -122,23 +83,46 @@ void Update() {

else {
this.IsSprintHeld = false;

if (this.IsSprinting) {
this.IsSprinting = false;
}
this.IsSprinting = !this.IsSprinting;
}

_ = this.CharacterController?.Move(moveDirection * Time.deltaTime);
}

Vector3 GetMovementDirection() {
Vector2 moveInput = new(
this.Keyboard.dKey.ReadValue() - this.Keyboard.aKey.ReadValue(),
this.Keyboard.wKey.ReadValue() - this.Keyboard.sKey.ReadValue()
);

float speedModifier = this.Keyboard.leftCtrlKey.isPressed ? CharacterMovement.WalkingSpeed : 1.0f;
float sprintModifier = this.IsSprinting ? this.CharacterSpeed * this.CharacterSprintSpeed : this.CharacterSpeed;

return sprintModifier * (
(this.transform.forward * moveInput.y) +
(this.transform.right * moveInput.x * speedModifier)
Comment on lines +98 to +103
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Apply speedModifier consistently to movement

Currently, speedModifier is applied only to the horizontal movement (line 103) but not to the forward/backward movement (line 102). This could lead to inconsistent movement speeds when moving diagonally, as holding the left control key will slow horizontal movement but not forward movement.

Consider applying speedModifier to both movement axes to ensure consistent speed adjustments.

Apply this diff to adjust the movement calculation:

return sprintModifier * (
-    (this.transform.forward * moveInput.y) +
-    (this.transform.right * moveInput.x * speedModifier)
+    (this.transform.forward * moveInput.y * speedModifier) +
+    (this.transform.right * moveInput.x * speedModifier)
);
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
float speedModifier = this.Keyboard.leftCtrlKey.isPressed ? CharacterMovement.WalkingSpeed : 1.0f;
float sprintModifier = this.IsSprinting ? this.CharacterSpeed * this.CharacterSprintSpeed : this.CharacterSpeed;
return sprintModifier * (
(this.transform.forward * moveInput.y) +
(this.transform.right * moveInput.x * speedModifier)
float speedModifier = this.Keyboard.leftCtrlKey.isPressed ? CharacterMovement.WalkingSpeed : 1.0f;
float sprintModifier = this.IsSprinting ? this.CharacterSpeed * this.CharacterSprintSpeed : this.CharacterSpeed;
return sprintModifier * (
(this.transform.forward * moveInput.y * speedModifier) +
(this.transform.right * moveInput.x * speedModifier)
);

);
}

void Update() {
if (this.NoClipKeyboard is { enabled: true }) return;
if (this.CharacterController is { enabled: false }) return;

Comment on lines +107 to +110
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Prevent potential null reference exceptions

In the Update method, you check if NoClipKeyboard is enabled or if CharacterController is disabled. However, if CharacterController is null, accessing CharacterController.enabled could throw a null reference exception.

Consider adding a null check for CharacterController before accessing its enabled property:

if (this.NoClipKeyboard is { enabled: true }) return;
-if (this.CharacterController is { enabled: false }) return;
+if (this.CharacterController == null || !this.CharacterController.enabled) return;
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
void Update() {
if (this.NoClipKeyboard is { enabled: true }) return;
if (this.CharacterController is { enabled: false }) return;
void Update() {
if (this.NoClipKeyboard is { enabled: true }) return;
if (this.CharacterController == null || !this.CharacterController.enabled) return;

Vector3 moveDirection = this.GetMovementDirection();
this.IsMoving = moveDirection != Vector3.zero;
this.ApplyGravity();
this.Move(moveDirection);
}

// Apply gravity to the character controller
void ApplyGravity() {
this.VelocityY = this.CharacterController is { isGrounded: false }
? this.VelocityY - (CharacterMovement.Gravity * Time.deltaTime)
: 0.0f;

Vector3 motion = new(0.0f, this.VelocityY, 0.0f);
_ = this.CharacterController?.Move(motion * Time.deltaTime);
_ = this.CharacterController?.Move(
new Vector3(0.0f, this.VelocityY, 0.0f) * Time.deltaTime
);
}

// Jumping action
void Jump() => this.VelocityY = CharacterMovement.JumpForce;
}
155 changes: 155 additions & 0 deletions lc-hax/Scripts/Core/HaxCamera.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,155 @@
using GameNetcodeStuff;
using Hax;
using UnityEngine;
using UnityEngine.Rendering.HighDefinition;

internal class HaxCamera : MonoBehaviour {
internal static HaxCamera? Instance { get; private set; }
KeyboardMovement? KeyboardMovement { get; set; }
MousePan? MousePan { get; set; }
GameObject? HaxCameraAudioContainer { get; set; }
AudioListener? HaxCameraAudioListener { get; set; }
internal GameObject? HaxCameraContainer { get; private set; }
internal Camera? CustomCamera { get; private set; }

void OnEnable() {
GameListener.OnGameStart += this.DisableCamera;
GameListener.OnGameEnd += this.DisableCamera;

Instance = this;
_ = this.GetCamera();
}

void OnDisable() {
GameListener.OnGameStart -= this.DisableCamera;
GameListener.OnGameEnd -= this.DisableCamera;
}

void LateUpdate() {
if (this.HaxCameraContainer is null) return;
if (this.KeyboardMovement is null) return;
if (!this.HaxCameraContainer.activeSelf) return;

this.KeyboardMovement.IsPaused = Helper.LocalPlayer is { isTypingChat: true };
}

void DisableCamera() {
if (PhantomMod.Instance is PhantomMod phantom) {
phantom.DisablePhantom();
}

this.HaxCameraContainer?.SetActive(false);
}

internal void SetActive(bool active) {
if (Helper.StartOfRound is not StartOfRound startOfRound) return;
if (Helper.LocalPlayer is not PlayerControllerB player) return;
if (player.activeAudioListener is not AudioListener playerlistener) return;
if (this.HaxCameraContainer is null) return;
if (this.HaxCameraAudioListener is not AudioListener haxListener) return;
if (this.GetCamera() is not Camera camera) return;

this.HaxCameraContainer.SetActive(active);

if (!this.HaxCameraContainer.activeSelf) {
playerlistener.enabled = true;
startOfRound.audioListener = playerlistener;
startOfRound.activeCamera.enabled = true;
}

else {
this.CopyFromCamera(camera, startOfRound.activeCamera);
startOfRound.activeCamera.enabled = false;
playerlistener.enabled = false;
startOfRound.audioListener = haxListener;
}
}

Camera? GetCamera() {
if (this.CustomCamera is not null) return this.CustomCamera;

this.HaxCameraAudioContainer ??= new GameObject("HaxCamera Audio Container");
this.HaxCameraContainer ??= new GameObject("HaxCamera Container");
DontDestroyOnLoad(this.HaxCameraContainer);

this.CustomCamera = this.HaxCameraContainer.AddComponent<Camera>();

this.HaxCameraAudioListener =
this.HaxCameraAudioContainer.GetComponent<AudioListener>() ??
this.HaxCameraAudioContainer.AddComponent<AudioListener>();

this.HaxCameraAudioContainer.transform.SetParent(this.HaxCameraContainer.transform, false);
this.HaxCameraAudioListener.transform.SetParent(this.HaxCameraContainer.transform, false);
this.HaxCameraAudioListener.transform.localScale = new Vector3(0.8196f, 0.8196f, 0.8196f);
this.HaxCameraAudioListener.transform.localPosition = Vector3.zero;
this.HaxCameraAudioListener.transform.localRotation = Quaternion.identity;

this.KeyboardMovement =
this.CustomCamera.GetComponent<KeyboardMovement>() ??
this.CustomCamera.gameObject.AddComponent<KeyboardMovement>();

this.MousePan =
this.CustomCamera.GetComponent<MousePan>() ??
this.CustomCamera.gameObject.AddComponent<MousePan>();

this.MousePan.enabled = true;
this.KeyboardMovement.enabled = true;
this.HaxCameraAudioListener.enabled = true;
this.HaxCameraContainer.SetActive(false);

return this.CustomCamera;
}

void AddHDCameraCompatibility(Camera camera) {
if (!camera.TryGetComponent(out HDAdditionalCameraData dataToCopy)) return;

HDAdditionalCameraData hdData =
camera.GetComponent<HDAdditionalCameraData>() ??
camera.gameObject.AddComponent<HDAdditionalCameraData>();

hdData.customRenderingSettings = true;
hdData.renderingPathCustomFrameSettingsOverrideMask.mask = dataToCopy.renderingPathCustomFrameSettingsOverrideMask.mask;
hdData.renderingPathCustomFrameSettings.lodBiasMode = dataToCopy.renderingPathCustomFrameSettings.lodBiasMode;
hdData.renderingPathCustomFrameSettings.lodBias = dataToCopy.renderingPathCustomFrameSettings.lodBias;
hdData.antialiasing = dataToCopy.antialiasing;

hdData.renderingPathCustomFrameSettings.SetEnabled(
FrameSettingsField.CustomPass,
dataToCopy.renderingPathCustomFrameSettings.IsEnabled(FrameSettingsField.CustomPass)
);

hdData.renderingPathCustomFrameSettings.SetEnabled(
FrameSettingsField.Volumetrics,
dataToCopy.renderingPathCustomFrameSettings.IsEnabled(FrameSettingsField.Volumetrics)
);

hdData.renderingPathCustomFrameSettings.SetEnabled(
FrameSettingsField.ShadowMaps,
dataToCopy.renderingPathCustomFrameSettings.IsEnabled(FrameSettingsField.ShadowMaps)
);
}

void UpdateCameraTransform(Transform target) {
if (this.HaxCameraContainer is not GameObject cameraContainer) return;
if (this.KeyboardMovement != null) {
this.KeyboardMovement.LastPosition = target.position;
}

cameraContainer.transform.position = target.position;
cameraContainer.transform.rotation = target.rotation;
}

void CopyFromCamera(Camera camera, Camera originalCamera) {
camera.CopyFrom(originalCamera);
camera.transform.localRotation = originalCamera.transform.localRotation;
camera.backgroundColor = originalCamera.backgroundColor;
camera.renderingPath = originalCamera.renderingPath;
camera.nearClipPlane = originalCamera.nearClipPlane;
camera.farClipPlane = originalCamera.farClipPlane;
camera.depth = originalCamera.depth;
camera.tag = originalCamera.tag;

this.AddHDCameraCompatibility(camera);
this.UpdateCameraTransform(originalCamera.transform);
}
}
22 changes: 15 additions & 7 deletions lc-hax/Scripts/Core/InputListener.cs
Original file line number Diff line number Diff line change
Expand Up @@ -17,16 +17,20 @@ class InputListener : MonoBehaviour {
internal static event Action? OnLeftBracketPress;
internal static event Action? OnRightBracketPress;
internal static event Action? OnBackslashPress;
internal static event Action? OnZPress;
internal static event Action? OnDelPress;
internal static event Action? OnXPress;
internal static event Action? OnNPress;
internal static event Action? OnUpArrowPress;
internal static event Action? OnDownArrowPress;
internal static event Action? OnF4Press;
internal static event Action? OnF5Press;
internal static event Action? OnF9Press;
internal static event Action<bool>? OnRightButtonHold;
internal static event Action<bool>? OnLeftAltButtonHold;
internal static event Action? OnZPress;
internal static event Action? OnXPress;
internal static event Action? OnNPress;
internal static event Action? OnQPress;
internal static event Action? OnEPress;
internal static event Action? OnSpacePress;

(Func<bool>, Action)[] InputActions { get; } = [
(() => Mouse.current.middleButton.wasPressedThisFrame, () => InputListener.OnMiddleButtonPress?.Invoke()),
Expand All @@ -41,21 +45,25 @@ class InputListener : MonoBehaviour {
(() => Keyboard.current[Key.RightBracket].wasPressedThisFrame, () => InputListener.OnRightBracketPress?.Invoke()),
(() => Keyboard.current[Key.Backslash].wasPressedThisFrame, () => InputListener.OnBackslashPress?.Invoke()),
(() => Keyboard.current[Key.Delete].wasPressedThisFrame, () => InputListener.OnDelPress?.Invoke()),
(() => Keyboard.current[Key.Z].wasPressedThisFrame, () => InputListener.OnZPress?.Invoke()),
(() => Keyboard.current[Key.X].wasPressedThisFrame, () => InputListener.OnXPress?.Invoke()),
(() => Keyboard.current[Key.N].wasPressedThisFrame, () => InputListener.OnNPress?.Invoke()),
(() => Keyboard.current[Key.UpArrow].wasPressedThisFrame, () => InputListener.OnUpArrowPress?.Invoke()),
(() => Keyboard.current[Key.DownArrow].wasPressedThisFrame, () => InputListener.OnDownArrowPress?.Invoke()),
(() => Keyboard.current[Key.F4].wasPressedThisFrame, () => InputListener.OnF4Press?.Invoke()),
(() => Keyboard.current[Key.F5].wasPressedThisFrame, () => InputListener.OnF5Press?.Invoke()),
(() => Keyboard.current[Key.F9].wasPressedThisFrame, () => InputListener.OnF9Press?.Invoke()),
(() => Keyboard.current[Key.Z].wasPressedThisFrame, () => InputListener.OnZPress?.Invoke()),
(() => Keyboard.current[Key.X].wasPressedThisFrame, () => InputListener.OnXPress?.Invoke()),
(() => Keyboard.current[Key.N].wasPressedThisFrame, () => InputListener.OnNPress?.Invoke()),
(() => Keyboard.current[Key.Q].wasPressedThisFrame, () => InputListener.OnQPress?.Invoke()),
(() => Keyboard.current[Key.E].wasPressedThisFrame, () => InputListener.OnEPress?.Invoke()),
(() => Keyboard.current[Key.Space].wasPressedThisFrame, () => InputListener.OnSpacePress?.Invoke()),
];

void Update() {
InputListener.OnShiftButtonHold?.Invoke(Keyboard.current[Key.LeftShift].isPressed);
InputListener.OnFButtonHold?.Invoke(Keyboard.current[Key.F].isPressed);
InputListener.OnEButtonHold?.Invoke(Keyboard.current[Key.E].isPressed);
InputListener.OnShiftButtonHold?.Invoke(Keyboard.current[Key.LeftShift].isPressed);
InputListener.OnRightButtonHold?.Invoke(Mouse.current.rightButton.isPressed);
InputListener.OnLeftAltButtonHold?.Invoke(Keyboard.current[Key.LeftAlt].isPressed);

foreach ((Func<bool> keyPressed, Action eventAction) in this.InputActions) {
if (!keyPressed()) continue;
Expand Down
6 changes: 3 additions & 3 deletions lc-hax/Scripts/Helpers/Camera.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,9 @@ namespace Hax;

static partial class Helper {
internal static Camera? CurrentCamera =>
Helper.LocalPlayer?.gameplayCamera is Camera { enabled: true } gameplayCamera
? gameplayCamera
: Helper.StartOfRound?.spectateCamera;
HaxCamera.Instance?.HaxCameraContainer is { activeSelf: true }
? HaxCamera.Instance.CustomCamera
: Helper.StartOfRound?.activeCamera;

internal static Vector3 WorldToEyesPoint(this Camera camera, Vector3 worldPosition) {
Vector3 screen = camera.WorldToViewportPoint(worldPosition);
Expand Down
Loading