gpt4 book ai didi

java - 让我的世界玩家看向点

转载 作者:行者123 更新时间:2023-12-02 06:17:00 24 4
gpt4 key购买 nike

我试图让玩家看向特定的点。我所看到的只是在它的视野范围内。我希望它也能向上和向下查看

 public static void lookAt(double x, double y, double z) {
double l;
double w;
double c;
l = x - playerX;
w = z - playerZ;
c = Math.sqrt(l * l + w + w);
double alpha1 = -Math.asin(l / c) / Math.PI * 180;
double alpha2 = Math.acos(w / c) / Math.PI * 180;
if (alpha2 > 180) {
playerYaw = 180 - (float) alpha1;

} else {
playerYaw = (float) alpha1;

}

}

我寻找了一种音调算法,但似乎没有一个有效。

最佳答案

迟到的答案,但是哦,好吧,如果您可以获得一个表示从您的位置到您想要查看的点的方向的单位 vector ,您可以使用简单的三角学来计算俯仰和偏航。

首先,您需要将您的位置减去该点并对结果进行归一化,这将为我们提供所需的方向 vector (单位 vector )。

现在我们可以计算角度了,Y 的反正弦将为我们提供俯仰角,X 和 Z 的反正切将为我们提供偏航角。

要了解原因:https://en.wikipedia.org/wiki/Inverse_trigonometric_functions

现在您应该有了俯仰角和偏航角,不要忘记将它们转换为度数!

这是一些代码:

public static void LookAt(double px, double py, double pz , EntityPlayer me)
{
double dirx = me.getPosition(0f).X - px;
double diry = me.getPosition(0f).Y - py;
double dirz = me.getPosition(0f).Z - pz;

double len = Math.sqrt(dirx*dirx + diry*diry + dirz*dirz);

dirx /= len
diry /= len;
dirz /= len;

double pitch = Math.asin(dir.y);
double yaw = Math.atan2(dir.z, dir.x);

//to degree
pitch = pitch * 180.0 / Math.PI;
yaw = yaw * 180.0 / Math.PI;

yaw += 90f;
me.rotationPitch = (float)pitch;
me.rotationYaw = (float)yaw;
}

关于java - 让我的世界玩家看向点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21363968/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com