/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(() => {
mp.players.forEachInStreamRange(
(player) => {
if (!player.getVariable("AnimationData"))
if (!player.getVariable("AnimationData")) {
return;
}
let index = mp.game.joaat(player.getVariable("AnimationData"));
let currentAnim = animationSyncData.animations[index];
@@ -62,16 +63,20 @@
loadAnimDict(animDict, function () {
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;
}
} else if (!loop) {
if (player == mp.players.local) {
blockInput = false;
mp.events.callRemote("CLIENT:ClearAnimationData", player);
}
}
});
}, 100);
mp.events.addDataHandler("AnimationData", (entity: PlayerMp, string) => {
entity.clearTasksImmediately();
blockInput = false;
if (string == null) {
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)
});
blockInput = true;
let pair = pairData.find(pair => pair.from == string);
if (!pair)
return;
blockInput = true;
let a = setInterval(function () {
mp.events.callRemote("CLIENT:AnimPairTransition", entity, pair.transitionTo);
if (entity == mp.players.local) {
mp.events.callRemote("CLIENT:AnimPairTransition", entity, pair.transitionTo);
}
clearInterval(a);
}, duration);
});
@@ -101,6 +109,7 @@
mp.events.add("render", () => {
if (blockInput) {
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())
}, 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)
return;
float rad = player.Heading * MathF.PI / 180;
Vector3 forwardV3 = new Vector3(player.Position.X + (1.2 * MathF.Sin(rad)), player.Position.Y + (1.2 * MathF.Cos(rad)), player.Position.Z);
target.Position = forwardV3;
target.Position = player.GetInFrontOfPosition();
target.Heading = player.Heading;
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();
return user.GetData("duty", false);
}
public static bool IsAdminDuty(this Player player)
{
return player.HasData("Adminduty") ? player.GetData<bool>("Adminduty") : false;
}
public static Vector3 GetPositionFromPlayer(Player player, float distance, int offset = 0)
{
var pos = player.Position;
@@ -268,7 +270,7 @@ namespace ReallifeGamemode.Server.Extensions
}
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;
}
@@ -314,5 +316,11 @@ namespace ReallifeGamemode.Server.Extensions
user.Player.SetSharedData("nameTagColor", nameTagColor);
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);
}
[RemoteEvent("CLIENT:ClearAnimationData")]
public void ClearAnimationData(Player player, Player target)
{
target.ClearAnimation();
}
[ServerEvent(Event.PlayerWeaponSwitch)]
public void OnPlayerWeaponSwitch(Player player, WeaponHash oldWeapon, WeaponHash newWeapon)
{