我目前正在使用这段代码:
struct vec3_t
{
public:
float x, y, z;
};
vec3_t Subtract(vec3_t src, vec3_t dst)
{
vec3_t diff;
diff.x = src.x - dst.x;
diff.y = src.y - dst.y;
diff.z = src.z - dst.z;
return diff;
}
float Magnitude(vec3_t vec)
{
return std::sqrt(vec.x * vec.x + vec.y * vec.y + vec.z * vec.z);
}
float Distance(vec3_t src, vec3_t dst)
{
vec3_t diff = Subtract(src, dst);
return Magnitude(diff);
}
vec3_t CalcAngle(vec3_t src, vec3_t dst)
{
vec3_t angles;
angles.x = (-(float)std::atan2(dst.x - src.x, dst.y - src.y)) / PI * 180.0f + 180.0f;
angles.y = (std::atan2(dst.z - src.z, Distance(src, dst))) * (180.0f / PI);
angles.z = 0.0f;
printf("%f - %f\n", src.z - dst.z, angles.y);
return angles;
}
然而,当Z值的差增加时,我的角度无法完全工作。 角度缺乏陡峭度,并且瞄准目标位置上方。
然而,当Z轴的差小于20时,角度可以正常工作,并且瞄准我想要的玩家。
这里有一些例子:
当差非常小的时候:
当变化量很大时
P.S 我正在从以下调用所有内容
vec3_t CurrentPos;
CurrentPos.x = x.ReadMemory<float>(LocalPlayer + PlayerOffsetList["PosX"]);
CurrentPos.y = x.ReadMemory<float>(LocalPlayer + PlayerOffsetList["PosY"]);
CurrentPos.z = x.ReadMemory<float>(LocalPlayer + PlayerOffsetList["PosZ"]);
vec3_t EnemyPos;
EnemyPos.x = Enemy.Posx;
EnemyPos.y = Enemy.Posy;
EnemyPos.z = Enemy.Posz;
vec3_t Result;
Result = AimbotMath.CalcAngle(EnemyPos, CurrentPos);
x.WriteMemory<float>(AddrList["ViewX"], (Result.x + 90.0f));
x.WriteMemory<float>(AddrList["ViewY"], Result.y);