Better ragdoll sync (maybe)
This commit is contained in:
parent
228ab9e727
commit
5d1a182e47
@ -102,9 +102,13 @@ namespace RageCoop.Client
|
|||||||
|
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
int pinPart = 0;
|
||||||
private void OnTick(object sender, EventArgs e)
|
private void OnTick(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
PlayerPosition=Game.Player.Character.Position;
|
var P = Game.Player.Character;
|
||||||
|
|
||||||
|
PlayerPosition=P.Position;
|
||||||
if (Game.IsLoading)
|
if (Game.IsLoading)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
@ -160,8 +164,6 @@ namespace RageCoop.Client
|
|||||||
Function.Call(Hash.IGNORE_NEXT_RESTART, true);
|
Function.Call(Hash.IGNORE_NEXT_RESTART, true);
|
||||||
Function.Call(Hash.FORCE_GAME_STATE_PLAYING);
|
Function.Call(Hash.FORCE_GAME_STATE_PLAYING);
|
||||||
Function.Call(Hash.TERMINATE_ALL_SCRIPTS_WITH_THIS_NAME, "respawn_controller");
|
Function.Call(Hash.TERMINATE_ALL_SCRIPTS_WITH_THIS_NAME, "respawn_controller");
|
||||||
|
|
||||||
var P = Game.Player.Character;
|
|
||||||
if (P.IsDead)
|
if (P.IsDead)
|
||||||
{
|
{
|
||||||
Function.Call(Hash.SET_FADE_OUT_AFTER_DEATH, false);
|
Function.Call(Hash.SET_FADE_OUT_AFTER_DEATH, false);
|
||||||
@ -187,6 +189,16 @@ namespace RageCoop.Client
|
|||||||
|
|
||||||
private void OnKeyDown(object sender, KeyEventArgs e)
|
private void OnKeyDown(object sender, KeyEventArgs e)
|
||||||
{
|
{
|
||||||
|
if(e.KeyCode == Keys.Right)
|
||||||
|
{
|
||||||
|
pinPart++;
|
||||||
|
GTA.UI.Notification.Show(pinPart.ToString());
|
||||||
|
}
|
||||||
|
if (e.KeyCode == Keys.Left)
|
||||||
|
{
|
||||||
|
pinPart--;
|
||||||
|
GTA.UI.Notification.Show(pinPart.ToString());
|
||||||
|
}
|
||||||
if (MainChat.Focused)
|
if (MainChat.Focused)
|
||||||
{
|
{
|
||||||
MainChat.OnKeyDown(e.KeyCode);
|
MainChat.OnKeyDown(e.KeyCode);
|
||||||
@ -337,7 +349,6 @@ namespace RageCoop.Client
|
|||||||
ServerItems.Clear();
|
ServerItems.Clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void DoQueuedActions()
|
private static void DoQueuedActions()
|
||||||
{
|
{
|
||||||
lock (QueuedActions)
|
lock (QueuedActions)
|
||||||
|
@ -287,7 +287,6 @@ namespace RageCoop.Client
|
|||||||
c.ID=packet.ID;
|
c.ID=packet.ID;
|
||||||
c.OwnerID=packet.OwnerID;
|
c.OwnerID=packet.OwnerID;
|
||||||
c.Health = packet.Health;
|
c.Health = packet.Health;
|
||||||
c.Position = packet.Position;
|
|
||||||
c.Rotation = packet.Rotation;
|
c.Rotation = packet.Rotation;
|
||||||
c.Velocity = packet.Velocity;
|
c.Velocity = packet.Velocity;
|
||||||
c.Speed = packet.Speed;
|
c.Speed = packet.Speed;
|
||||||
@ -304,6 +303,13 @@ namespace RageCoop.Client
|
|||||||
c.IsInCover = flags.HasPedFlag(PedDataFlags.IsInCover);
|
c.IsInCover = flags.HasPedFlag(PedDataFlags.IsInCover);
|
||||||
c.IsInStealthMode = flags.HasPedFlag(PedDataFlags.IsInStealthMode);
|
c.IsInStealthMode = flags.HasPedFlag(PedDataFlags.IsInStealthMode);
|
||||||
c.Heading=packet.Heading;
|
c.Heading=packet.Heading;
|
||||||
|
c.Position = packet.Position;
|
||||||
|
if (c.IsRagdoll)
|
||||||
|
{
|
||||||
|
c.HeadPosition=packet.HeadPosition;
|
||||||
|
c.RightFootPosition=packet.RightFootPosition;
|
||||||
|
c.LeftFootPosition=packet.LeftFootPosition;
|
||||||
|
}
|
||||||
c.LastSynced = Main.Ticked;
|
c.LastSynced = Main.Ticked;
|
||||||
if (c.IsAiming)
|
if (c.IsAiming)
|
||||||
{
|
{
|
||||||
|
@ -32,7 +32,6 @@ namespace RageCoop.Client
|
|||||||
ID =c.ID,
|
ID =c.ID,
|
||||||
OwnerID=c.OwnerID,
|
OwnerID=c.OwnerID,
|
||||||
Health = p.Health,
|
Health = p.Health,
|
||||||
Position = p.Position,
|
|
||||||
Rotation = p.Rotation,
|
Rotation = p.Rotation,
|
||||||
Velocity = p.Velocity,
|
Velocity = p.Velocity,
|
||||||
Speed = p.GetPedSpeed(),
|
Speed = p.GetPedSpeed(),
|
||||||
@ -44,6 +43,16 @@ namespace RageCoop.Client
|
|||||||
{
|
{
|
||||||
packet.AimCoords = p.GetAimCoord();
|
packet.AimCoords = p.GetAimCoord();
|
||||||
}
|
}
|
||||||
|
if (packet.Flags.HasPedFlag(PedDataFlags.IsRagdoll))
|
||||||
|
{
|
||||||
|
packet.HeadPosition=p.Bones[Bone.SkelHead].Position;
|
||||||
|
packet.RightFootPosition=p.Bones[Bone.SkelRightFoot].Position;
|
||||||
|
packet.LeftFootPosition=p.Bones[Bone.SkelLeftFoot].Position;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
packet.Position = p.Position;
|
||||||
|
}
|
||||||
if (full)
|
if (full)
|
||||||
{
|
{
|
||||||
packet.Flags |= PedDataFlags.IsFullSync;
|
packet.Flags |= PedDataFlags.IsFullSync;
|
||||||
|
@ -63,6 +63,11 @@ namespace RageCoop.Client
|
|||||||
public Ped MainPed { get; internal set; }
|
public Ped MainPed { get; internal set; }
|
||||||
internal int Health { get; set; }
|
internal int Health { get; set; }
|
||||||
internal bool IsInStealthMode { get; set; }
|
internal bool IsInStealthMode { get; set; }
|
||||||
|
|
||||||
|
internal Vector3 HeadPosition { get; set; }
|
||||||
|
internal Vector3 RightFootPosition { get; set; }
|
||||||
|
internal Vector3 LeftFootPosition { get; set; }
|
||||||
|
|
||||||
internal byte WeaponTint { get; set; }
|
internal byte WeaponTint { get; set; }
|
||||||
internal bool _lastEnteringVehicle=false;
|
internal bool _lastEnteringVehicle=false;
|
||||||
internal bool _lastSittingInVehicle=false;
|
internal bool _lastSittingInVehicle=false;
|
||||||
@ -703,12 +708,42 @@ namespace RageCoop.Client
|
|||||||
{
|
{
|
||||||
MainPed.Heading=Heading;
|
MainPed.Heading=Heading;
|
||||||
MainPed.Velocity=Velocity+5*dist*(Position-MainPed.Position);
|
MainPed.Velocity=Velocity+5*dist*(Position-MainPed.Position);
|
||||||
// if (MainPed.Speed<0.05) { f*=10; MainPed.Heading=Heading; }
|
|
||||||
}
|
}
|
||||||
else if (Main.Ticked-_lastRagdollTime<20)
|
else if (Main.Ticked-_lastRagdollTime<30)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
else if (IsRagdoll)
|
||||||
|
{
|
||||||
|
var helper = new GTA.NaturalMotion.ApplyImpulseHelper(MainPed);
|
||||||
|
var head = MainPed.Bones[Bone.SkelHead];
|
||||||
|
var rightFoot = MainPed.Bones[Bone.SkelRightFoot];
|
||||||
|
var leftFoot = MainPed.Bones[Bone.SkelLeftFoot];
|
||||||
|
|
||||||
|
// 20:head, 3:left foot, 6:right foot, 17:right hand,
|
||||||
|
|
||||||
|
helper.EqualizeAmount = 1;
|
||||||
|
helper.PartIndex=20;
|
||||||
|
helper.Impulse=20*(HeadPosition-head.Position);
|
||||||
|
helper.Start();
|
||||||
|
helper.Stop();
|
||||||
|
|
||||||
|
helper.EqualizeAmount = 1;
|
||||||
|
helper.PartIndex=6;
|
||||||
|
helper.Impulse=20*(RightFootPosition-rightFoot.Position);
|
||||||
|
helper.Start();
|
||||||
|
helper.Stop();
|
||||||
|
|
||||||
|
helper.EqualizeAmount = 1;
|
||||||
|
helper.PartIndex=3;
|
||||||
|
helper.Impulse=20*(LeftFootPosition-leftFoot.Position);
|
||||||
|
helper.Start();
|
||||||
|
helper.Stop();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MainPed.Velocity=Velocity+5*dist*(Position-MainPed.Position);
|
||||||
|
}
|
||||||
// MainPed.ApplyForce(f);
|
// MainPed.ApplyForce(f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -335,7 +335,6 @@ namespace RageCoop.Client
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
|
@ -219,6 +219,10 @@ namespace RageCoop.Client
|
|||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void ApplyForce(this Entity e,int boneIndex, Vector3 direction, Vector3 rotation = default(Vector3), ForceType forceType = ForceType.MaxForceRot2)
|
||||||
|
{
|
||||||
|
Function.Call(Hash.APPLY_FORCE_TO_ENTITY, e.Handle, forceType, direction.X, direction.Y, direction.Z, rotation.X, rotation.Y, rotation.Z, boneIndex, false, true, true, false, true);
|
||||||
|
}
|
||||||
public static byte GetPlayerRadioIndex()
|
public static byte GetPlayerRadioIndex()
|
||||||
{
|
{
|
||||||
return (byte)Function.Call<int>(Hash.GET_PLAYER_RADIO_STATION_INDEX);
|
return (byte)Function.Call<int>(Hash.GET_PLAYER_RADIO_STATION_INDEX);
|
||||||
|
@ -26,7 +26,12 @@ namespace RageCoop.Core
|
|||||||
|
|
||||||
public Vector3 Velocity { get; set; }
|
public Vector3 Velocity { get; set; }
|
||||||
|
|
||||||
// public Vector3 RotationVelocity { get; set; }
|
#region RAGDOLL
|
||||||
|
public Vector3 HeadPosition { get; set; }
|
||||||
|
public Vector3 RightFootPosition { get; set; }
|
||||||
|
public Vector3 LeftFootPosition { get; set; }
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
public byte Speed { get; set; }
|
public byte Speed { get; set; }
|
||||||
|
|
||||||
@ -71,8 +76,19 @@ namespace RageCoop.Core
|
|||||||
// Write ped health
|
// Write ped health
|
||||||
byteArray.AddRange(BitConverter.GetBytes(Health));
|
byteArray.AddRange(BitConverter.GetBytes(Health));
|
||||||
|
|
||||||
|
// ragdoll sync
|
||||||
|
if (Flags.HasPedFlag(PedDataFlags.IsRagdoll))
|
||||||
|
{
|
||||||
|
byteArray.AddVector3(HeadPosition);
|
||||||
|
byteArray.AddVector3(RightFootPosition);
|
||||||
|
byteArray.AddVector3(LeftFootPosition);
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// Write ped position
|
// Write ped position
|
||||||
byteArray.AddVector3(Position);
|
byteArray.AddVector3(Position);
|
||||||
|
}
|
||||||
|
|
||||||
// Write ped rotation
|
// Write ped rotation
|
||||||
byteArray.AddVector3(Rotation);
|
byteArray.AddVector3(Rotation);
|
||||||
@ -152,8 +168,18 @@ namespace RageCoop.Core
|
|||||||
// Read player health
|
// Read player health
|
||||||
Health = reader.ReadInt();
|
Health = reader.ReadInt();
|
||||||
|
|
||||||
|
if (Flags.HasPedFlag(PedDataFlags.IsRagdoll))
|
||||||
|
{
|
||||||
|
HeadPosition=reader.ReadVector3();
|
||||||
|
RightFootPosition=reader.ReadVector3();
|
||||||
|
LeftFootPosition=reader.ReadVector3();
|
||||||
|
Position=HeadPosition;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// Read player position
|
// Read player position
|
||||||
Position = reader.ReadVector3();
|
Position = reader.ReadVector3();
|
||||||
|
}
|
||||||
|
|
||||||
// Read player rotation
|
// Read player rotation
|
||||||
Rotation = reader.ReadVector3();
|
Rotation = reader.ReadVector3();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user