Bug fixes and new player movement

This commit is contained in:
EntenKoeniq 2021-12-24 03:16:16 +01:00
parent 96d2a9ca4c
commit b9703dd612
5 changed files with 123 additions and 115 deletions

View File

@ -48,8 +48,6 @@ namespace CoopClient.Entities
Character.IsInvincible = false;
Function.Call(Hash.START_ENTITY_FIRE, Character.Handle);
return;
}
else if (!IsOnFire && Character.IsOnFire)
{
@ -74,8 +72,6 @@ namespace CoopClient.Entities
{
Character.CanRagdoll = true;
Character.Ragdoll();
return;
}
else if (!IsRagdoll && Character.IsRagdoll)
{
@ -83,8 +79,9 @@ namespace CoopClient.Entities
Character.CanRagdoll = false;
}
if (IsJumping || IsOnFire)
if (IsJumping || IsOnFire || IsRagdoll)
{
UpdateOnFootPosition(true, true, false);
return;
}
@ -96,10 +93,8 @@ namespace CoopClient.Entities
Character.Task.ReloadWeapon();
}
if (Character.IsInRange(Position, 0.5f))
{
return;
}
UpdateOnFootPosition();
return;
}
if (Character.Weapons.Current.Hash != (WeaponHash)CurrentWeaponHash || !WeaponComponents.Compare(LastWeaponComponents))
@ -166,57 +161,72 @@ namespace CoopClient.Entities
private bool LastMoving;
private void WalkTo()
{
if (!Character.IsInRange(Position, 6.0f) && (LastMoving = true))
Vector3 predictPosition = Position + (Position - Character.Position) + Velocity;
float range = predictPosition.DistanceToSquared(Character.Position);
switch (Speed)
{
Character.Position = Position;
Character.Rotation = Rotation;
case 1:
if (!Character.IsWalking || range > 0.25f)
{
float nrange = range * 2;
if (nrange > 1.0f)
{
nrange = 1.0f;
}
Character.Task.GoStraightTo(predictPosition);
Function.Call(Hash.SET_PED_DESIRED_MOVE_BLEND_RATIO, Character.Handle, nrange);
}
LastMoving = true;
break;
case 2:
if (!Character.IsRunning || range > 0.50f)
{
Character.Task.RunTo(predictPosition, true);
Function.Call(Hash.SET_PED_DESIRED_MOVE_BLEND_RATIO, Character.Handle, 1.0f);
}
LastMoving = true;
break;
case 3:
if (!Character.IsSprinting || range > 0.75f)
{
Function.Call(Hash.TASK_GO_STRAIGHT_TO_COORD, Character.Handle, predictPosition.X, predictPosition.Y, predictPosition.Z, 3.0f, -1, 0.0f, 0.0f);
Function.Call(Hash.SET_RUN_SPRINT_MULTIPLIER_FOR_PLAYER, Character.Handle, 1.49f);
Function.Call(Hash.SET_PED_DESIRED_MOVE_BLEND_RATIO, Character.Handle, 1.0f);
}
LastMoving = true;
break;
default:
if (LastMoving)
{
Character.Task.StandStill(2000);
LastMoving = false;
}
break;
}
else
UpdateOnFootPosition();
}
private void UpdateOnFootPosition(bool updatePosition = true, bool updateRotation = true, bool updateVelocity = true)
{
if (updatePosition)
{
Vector3 predictPosition = Position + (Position - Character.Position) + Velocity;
float range = predictPosition.DistanceToSquared(Character.Position);
float lerpValue = ((int)((Latency * 1000 / 2) + Main.MainNetworking.Latency * 1000 / 2)) * 2 / 50000f;
switch (Speed)
{
case 1:
if ((!Character.IsWalking || range > 0.25f) && (LastMoving = true))
{
float nrange = range * 2;
if (nrange > 1.0f)
{
nrange = 1.0f;
}
Vector2 biDimensionalPos = Vector2.Lerp(new Vector2(Character.Position.X, Character.Position.Y), new Vector2(Position.X + (Velocity.X / 5), Position.Y + (Velocity.Y / 5)), lerpValue);
float zPos = Util.Lerp(Character.Position.Z, Position.Z, 0.1f);
Character.PositionNoOffset = new Vector3(biDimensionalPos.X, biDimensionalPos.Y, zPos);
}
Character.Task.GoStraightTo(predictPosition);
Function.Call(Hash.SET_PED_DESIRED_MOVE_BLEND_RATIO, Character.Handle, nrange);
}
break;
case 2:
if ((!Character.IsRunning || range > 0.50f) && (LastMoving = true))
{
Character.Task.RunTo(predictPosition, true);
Function.Call(Hash.SET_PED_DESIRED_MOVE_BLEND_RATIO, Character.Handle, 1.0f);
}
break;
case 3:
if ((!Character.IsSprinting || range > 0.75f) && (LastMoving = true))
{
Function.Call(Hash.TASK_GO_STRAIGHT_TO_COORD, Character.Handle, predictPosition.X, predictPosition.Y, predictPosition.Z, 3.0f, -1, 0.0f, 0.0f);
Function.Call(Hash.SET_RUN_SPRINT_MULTIPLIER_FOR_PLAYER, Character.Handle, 1.49f);
Function.Call(Hash.SET_PED_DESIRED_MOVE_BLEND_RATIO, Character.Handle, 1.0f);
}
break;
default:
if (!Character.IsInRange(Position, 0.5f))
{
Character.Task.RunTo(Position, true, 500);
}
else if (LastMoving && (LastMoving = false))
{
Character.Task.StandStill(1000);
}
break;
}
if (updateRotation)
{
Character.Rotation = Vector3.Lerp(Character.Rotation, Rotation, 0.10f);
}
if (updateVelocity)
{
Character.Velocity = Velocity;
}
}
}

View File

@ -275,7 +275,7 @@ namespace CoopClient
DebugSyncPed = Players[0];
}
if ((Util.GetTickCount64() - ArtificialLagCounter) < 56)
if ((Util.GetTickCount64() - ArtificialLagCounter) < 30)
{
return;
}

View File

@ -482,10 +482,10 @@ namespace CoopClient
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write player velocity
@ -517,6 +517,7 @@ namespace CoopClient
byteArray.AddRange(BitConverter.GetBytes((ushort)WeaponComponents.Count));
foreach (KeyValuePair<uint, bool> component in WeaponComponents)
{
byteArray.AddRange(BitConverter.GetBytes(component.Key));
byteArray.AddRange(BitConverter.GetBytes(component.Value));
}
}
@ -587,8 +588,7 @@ namespace CoopClient
for (ushort i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read player velocity
@ -624,10 +624,9 @@ namespace CoopClient
{
WeaponComponents = new Dictionary<uint, bool>();
ushort comCount = reader.ReadUShort();
for (ushort i = 0; i < comCount; i++)
{
WeaponComponents.Add(i, reader.ReadBool());
WeaponComponents.Add(reader.ReadUInt(), reader.ReadBool());
}
}
@ -706,10 +705,10 @@ namespace CoopClient
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write vehicle model hash
@ -775,7 +774,8 @@ namespace CoopClient
foreach (KeyValuePair<int, int> mod in VehMods)
{
// Write the mod value
byteArray.AddRange(BitConverter.GetBytes((short)mod.Value));
byteArray.AddRange(BitConverter.GetBytes(mod.Key));
byteArray.AddRange(BitConverter.GetBytes(mod.Value));
}
if (!VehDamageModel.Equals(default(VehicleDamageModel)))
@ -836,11 +836,10 @@ namespace CoopClient
// Read the count of clothes
ushort clothCount = reader.ReadUShort();
// For clothCount
for (int i = 0; i < clothCount; i++)
for (ushort i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read vehicle model hash
@ -921,8 +920,7 @@ namespace CoopClient
for (int i = 0; i < vehModCount; i++)
{
// Read the mod value
short mod = reader.ReadShort();
VehMods.Add(i, mod);
VehMods.Add(reader.ReadInt(), reader.ReadInt());
}
if (reader.ReadBool())
@ -1667,10 +1665,10 @@ namespace CoopClient
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write npc health
@ -1749,8 +1747,7 @@ namespace CoopClient
for (ushort i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read npc health
@ -1853,10 +1850,10 @@ namespace CoopClient
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write vehicle model hash
@ -1914,7 +1911,8 @@ namespace CoopClient
foreach (KeyValuePair<int, int> mod in VehMods)
{
// Write the mod value
byteArray.AddRange(BitConverter.GetBytes((short)mod.Value));
byteArray.AddRange(BitConverter.GetBytes(mod.Key));
byteArray.AddRange(BitConverter.GetBytes(mod.Value));
}
if (!VehDamageModel.Equals(default(VehicleDamageModel)))
@ -1974,8 +1972,7 @@ namespace CoopClient
for (int i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read vehicle model hash
@ -2045,8 +2042,7 @@ namespace CoopClient
for (int i = 0; i < vehModCount; i++)
{
// Read the mod value
short mod = reader.ReadShort();
VehMods.Add(i, mod);
VehMods.Add(reader.ReadInt(), reader.ReadInt());
}
if (reader.ReadBool())

View File

@ -47,6 +47,12 @@ namespace CoopClient
}
#endregion
// Dirty & dangerous
public static dynamic Lerp(dynamic from, dynamic to, float fAlpha)
{
return ((to - from) * fAlpha + from);
}
public static T GetGameMs<T>() where T : IConvertible
{
return (T)Convert.ChangeType(1f / (Game.FPS > 60f ? 60f : Game.FPS) * 1000f, typeof(T));

View File

@ -422,10 +422,10 @@ namespace CoopServer
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write player velocity
@ -457,6 +457,7 @@ namespace CoopServer
byteArray.AddRange(BitConverter.GetBytes((ushort)WeaponComponents.Count));
foreach (KeyValuePair<uint, bool> component in WeaponComponents)
{
byteArray.AddRange(BitConverter.GetBytes(component.Key));
byteArray.AddRange(BitConverter.GetBytes(component.Value));
}
}
@ -527,8 +528,7 @@ namespace CoopServer
for (ushort i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read player velocity
@ -564,10 +564,9 @@ namespace CoopServer
{
WeaponComponents = new Dictionary<uint, bool>();
ushort comCount = reader.ReadUShort();
for (ushort i = 0; i < comCount; i++)
{
WeaponComponents.Add(i, reader.ReadBool());
WeaponComponents.Add(reader.ReadUInt(), reader.ReadBool());
}
}
@ -646,10 +645,10 @@ namespace CoopServer
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write vehicle model hash
@ -715,7 +714,8 @@ namespace CoopServer
foreach (KeyValuePair<int, int> mod in VehMods)
{
// Write the mod value
byteArray.AddRange(BitConverter.GetBytes((short)mod.Value));
byteArray.AddRange(BitConverter.GetBytes(mod.Key));
byteArray.AddRange(BitConverter.GetBytes(mod.Value));
}
if (!VehDamageModel.Equals(default(VehicleDamageModel)))
@ -776,11 +776,10 @@ namespace CoopServer
// Read the count of clothes
ushort clothCount = reader.ReadUShort();
// For clothCount
for (int i = 0; i < clothCount; i++)
for (ushort i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read vehicle model hash
@ -861,8 +860,7 @@ namespace CoopServer
for (int i = 0; i < vehModCount; i++)
{
// Read the mod value
short mod = reader.ReadShort();
VehMods.Add(i, mod);
VehMods.Add(reader.ReadInt(), reader.ReadInt());
}
if (reader.ReadBool())
@ -1607,10 +1605,10 @@ namespace CoopServer
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write npc health
@ -1689,8 +1687,7 @@ namespace CoopServer
for (ushort i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read npc health
@ -1793,10 +1790,10 @@ namespace CoopServer
// Write the count of clothes
byteArray.AddRange(BitConverter.GetBytes((ushort)Clothes.Count));
// Loop the dictionary and add the values
for (int i = 0; i < Clothes.Count; i++)
foreach (KeyValuePair<byte, short> cloth in Clothes)
{
// Write the cloth value
byteArray.AddRange(BitConverter.GetBytes(Clothes[(byte)i]));
byteArray.Add(cloth.Key);
byteArray.AddRange(BitConverter.GetBytes(cloth.Value));
}
// Write vehicle model hash
@ -1854,7 +1851,8 @@ namespace CoopServer
foreach (KeyValuePair<int, int> mod in VehMods)
{
// Write the mod value
byteArray.AddRange(BitConverter.GetBytes((short)mod.Value));
byteArray.AddRange(BitConverter.GetBytes(mod.Key));
byteArray.AddRange(BitConverter.GetBytes(mod.Value));
}
if (!VehDamageModel.Equals(default(VehicleDamageModel)))
@ -1914,8 +1912,7 @@ namespace CoopServer
for (int i = 0; i < clothCount; i++)
{
// Read cloth value
short clothValue = reader.ReadShort();
Clothes.Add((byte)i, clothValue);
Clothes.Add(reader.ReadByte(), reader.ReadShort());
}
// Read vehicle model hash
@ -1985,8 +1982,7 @@ namespace CoopServer
for (int i = 0; i < vehModCount; i++)
{
// Read the mod value
short mod = reader.ReadShort();
VehMods.Add(i, mod);
VehMods.Add(reader.ReadInt(), reader.ReadInt());
}
if (reader.ReadBool())