/cuff positioning test

This commit is contained in:
2021-04-06 17:34:34 +02:00
parent 8ee68a5a54
commit b4fb23078b
5 changed files with 61 additions and 11 deletions

View File

@@ -51,8 +51,9 @@
setInterval(() => { setInterval(() => {
mp.players.forEachInStreamRange( mp.players.forEachInStreamRange(
(player) => { (player) => {
if (!player.getVariable("AnimationData")) if (!player.getVariable("AnimationData")) {
return; return;
}
let index = mp.game.joaat(player.getVariable("AnimationData")); let index = mp.game.joaat(player.getVariable("AnimationData"));
let currentAnim = animationSyncData.animations[index]; let currentAnim = animationSyncData.animations[index];
@@ -62,16 +63,20 @@
loadAnimDict(animDict, function () { loadAnimDict(animDict, function () {
mp.players.exists(player) && 0 !== player.handle && player.taskPlayAnim(animDict, animName, 8, 1, duration, parseInt(flag), 0, !1, !1, !1) mp.players.exists(player) && 0 !== player.handle && player.taskPlayAnim(animDict, animName, 8, 1, duration, parseInt(flag), 0, !1, !1, !1)
}); });
if (player == mp.players.local) { //block player from using LMB to attack if (player == mp.players.local) {
blockInput = true; blockInput = true;
} }
} else if (!loop) {
if (player == mp.players.local) {
blockInput = false;
mp.events.callRemote("CLIENT:ClearAnimationData", player);
}
} }
}); });
}, 100); }, 100);
mp.events.addDataHandler("AnimationData", (entity: PlayerMp, string) => { mp.events.addDataHandler("AnimationData", (entity: PlayerMp, string) => {
entity.clearTasksImmediately(); entity.clearTasksImmediately();
blockInput = false;
if (string == null) { if (string == null) {
return; return;
} }
@@ -88,12 +93,15 @@
mp.players.exists(entity) && 0 !== entity.handle && entity.taskPlayAnim(animDict, animName, 8, 1, duration, parseInt(flag), 0, !1, !1, !1) mp.players.exists(entity) && 0 !== entity.handle && entity.taskPlayAnim(animDict, animName, 8, 1, duration, parseInt(flag), 0, !1, !1, !1)
}); });
blockInput = true;
let pair = pairData.find(pair => pair.from == string); let pair = pairData.find(pair => pair.from == string);
if (!pair) if (!pair)
return; return;
blockInput = true;
let a = setInterval(function () { let a = setInterval(function () {
if (entity == mp.players.local) {
mp.events.callRemote("CLIENT:AnimPairTransition", entity, pair.transitionTo); mp.events.callRemote("CLIENT:AnimPairTransition", entity, pair.transitionTo);
}
clearInterval(a); clearInterval(a);
}, duration); }, duration);
}); });
@@ -101,6 +109,7 @@
mp.events.add("render", () => { mp.events.add("render", () => {
if (blockInput) { if (blockInput) {
mp.game.controls.disableControlAction(32, 24, true); mp.game.controls.disableControlAction(32, 24, true);
mp.game.controls.disableControlAction(32, 22, true);
} }
}); });
@@ -111,4 +120,17 @@
mp.game.streaming.hasAnimDictLoaded(animDict) && (clearInterval(c), callback()) mp.game.streaming.hasAnimDictLoaded(animDict) && (clearInterval(c), callback())
}, 100) }, 100)
} }
mp.events.add("SERVER:GetInFrontPosition", () => {
let player = mp.players.local;
let result = xyInFrontOfPos(player.position, player.heading, 0.5);
mp.events.callRemote("CLIENT:SET_InFrontOfPos", result);
});
function xyInFrontOfPos(pos, heading, dist): Vector3Mp {
heading *= Math.PI / 180
pos.x += (dist * Math.sin(-heading))
pos.y += (dist * Math.cos(-heading))
return pos;
}
} }

View File

@@ -46,10 +46,8 @@ namespace ReallifeGamemode.Server.Commands
if (target.Id == player.Id) if (target.Id == player.Id)
return; return;
float rad = player.Heading * MathF.PI / 180; target.Position = player.GetInFrontOfPosition();
Vector3 forwardV3 = new Vector3(player.Position.X + (1.2 * MathF.Sin(rad)), player.Position.Y + (1.2 * MathF.Cos(rad)), player.Position.Z); target.Heading = player.Heading;
target.Position = forwardV3;
if (!target.HasAnimation("Cuffed")) if (!target.HasAnimation("Cuffed"))
{ {

View File

@@ -0,0 +1,16 @@
using System;
using System.Collections.Generic;
using System.Text;
using GTANetworkAPI;
namespace ReallifeGamemode.Server.Events
{
internal class PlayerEvent : Script
{
[RemoteEvent("CLIENT:SET_InFrontOfPos")]
public void SetFrontOfPos(Player player, Vector3 pos)
{
player.SetSharedData("InFrontOf", pos);
}
}
}

View File

@@ -77,10 +77,12 @@ namespace ReallifeGamemode.Server.Extensions
var user = player.GetUser(); var user = player.GetUser();
return user.GetData("duty", false); return user.GetData("duty", false);
} }
public static bool IsAdminDuty(this Player player) public static bool IsAdminDuty(this Player player)
{ {
return player.HasData("Adminduty") ? player.GetData<bool>("Adminduty") : false; return player.HasData("Adminduty") ? player.GetData<bool>("Adminduty") : false;
} }
public static Vector3 GetPositionFromPlayer(Player player, float distance, int offset = 0) public static Vector3 GetPositionFromPlayer(Player player, float distance, int offset = 0)
{ {
var pos = player.Position; var pos = player.Position;
@@ -268,7 +270,7 @@ namespace ReallifeGamemode.Server.Extensions
} }
else if (user.FactionId != null) else if (user.FactionId != null)
{ {
if(user.FactionId > 3 || (user.FactionId >= 1 && user.FactionId <= 3 && duty)) if (user.FactionId > 3 || (user.FactionId >= 1 && user.FactionId <= 3 && duty))
{ {
nameTagColor = user.FactionId.Value; nameTagColor = user.FactionId.Value;
} }
@@ -314,5 +316,11 @@ namespace ReallifeGamemode.Server.Extensions
user.Player.SetSharedData("nameTagColor", nameTagColor); user.Player.SetSharedData("nameTagColor", nameTagColor);
user.Player.SetSharedData("blipColor", blipColor); user.Player.SetSharedData("blipColor", blipColor);
} }
public static Vector3 GetInFrontOfPosition(this Player player)
{
player.TriggerEvent("SERVER:GetInFrontPosition");
return player.GetSharedData<Vector3>("InFrontOf");
}
} }
} }

View File

@@ -56,6 +56,12 @@ namespace ReallifeGamemode.Server.Util
target.SyncAnimation(transitionTo); target.SyncAnimation(transitionTo);
} }
[RemoteEvent("CLIENT:ClearAnimationData")]
public void ClearAnimationData(Player player, Player target)
{
target.ClearAnimation();
}
[ServerEvent(Event.PlayerWeaponSwitch)] [ServerEvent(Event.PlayerWeaponSwitch)]
public void OnPlayerWeaponSwitch(Player player, WeaponHash oldWeapon, WeaponHash newWeapon) public void OnPlayerWeaponSwitch(Player player, WeaponHash oldWeapon, WeaponHash newWeapon)
{ {