gpt4 book ai didi

java - 3D 考虑玩家 Y 旋转,创建一个到一定距离的点

转载 作者:行者123 更新时间:2023-12-02 01:23:48 26 4
gpt4 key购买 nike

我需要在一个点(这是我们的玩家位置)前面定义一个 2D 平面区域,并检查其中有哪些点(敌人)。在游戏中,它用于确定我们面前的“盒子”内有哪些敌人,其X宽度、Y高度和Z长度。

我需要帮助计算飞机的左下角和右上角点。

输入:我们知道球员的位置并且知道球员的轮换。只有玩家的 Y 旋转很重要,因为飞机应该始终位于玩家的前面。

我们知道平面的宽度和长度。在这种情况下,高度无关紧要,我知道如何计算它。如果宽度为 8 米,长度为 20,如果玩家位置为 0,0,0,左下点将为 X= -4/Y = 0/Z = 0,右上角点将为 X=4/Y = 0/Z = 20

我的代码仅在玩家 Y 旋转为 0 时才有效,因为我只是将宽度/长度添加到当前的 X 和 Z 值。我需要正确的数学公式来确定左下点和右上角点的位置,并考虑玩家的 Y 旋转参数,以便平面区域始终与玩家所面对的方向相同

这是我所需要的直观表示:

https://gyazo.com/fd5ad0e393f6db8236ee7fd766e7286b

`

float AreaWidth = 8;
float AreaLength = 20;
float AreaHeight = 10;

Point AreaBTMLeftPoint = new Point(PlayerPosition.getX()-(AreaWidth/2),
PlayerPosition.getLoc().getY(), PlayerPosition.getLoc().getZ());

Point AreaTOPRightPoint = new Point(PlayerPosition.getLoc().getX()+
(AreaWidth/2), PlayerPosition.getLoc().getY(),
PlayerPosition.getLoc().getZ()+(AreaLength));

float AreaBTMX = AreaBTMLeftPoint.getX();
float AreaBTMZ = AreaBTMLeftPoint.getZ();
float AreaTOPX = AreaTOPRightPoint.getX();
float AreaTOPZ = AreaTOPRightPoint.getZ();
float AreaMaxY = PlayerPosition.getLoc().getY()+(AreaHeight/2);
float AreaMinY = PlayerPosition.getLoc().getY()-(AreaHeight/2);

if (TargetPosition.getLoc().getX() > AreaBTMX &&
TargetPosition.getLoc().getX() < AreaTOPX &&
TargetPosition.getLoc().getY() > AreaMinY &&
TargetPosition.getLoc().getY() < AreaMaxY &&
TargetPosition.getLoc().getZ() > AreaBTMZ &&
TargetPosition.getLoc().getZ() < AreaTOPZ) {

This target is inside the area, do stuff.

}`

最佳答案

设玩家位置为P,方向角为Fi,目标位置为T。
单位方向 vector D:

d.x = cos(Fi) //don't forget about radians
d.y = sin(Fi)

差异 vector

PT = T - P = (T.x - P.x, T.y - P.y)

T到玩家方向线的垂直距离为正交投影的长度

perplen = Abs(Pt x D) =                  //cross product
Abs(PT.x * d.y - Pt.y * d.x)
compare it with (AreaWidth/2)

沿方向线的距离:

alonglen = (Pt .dot. D) =                  //dot product
PT.x * d.x + PT.y * d.y
it should be >=0 and <= than AreaLength

如果两个条件都成立,则目标位于倾斜矩形内

概念验证 Delphi 代码:

var
i, px, py, tx, ty, XX, YY, ptx, pty: Integer;
perplen, alonglen: Double;
wdt, lng: Integer;
Fi, cs, sn: Double;
begin
px := 300; py := 300;
wdt := 150; lng := 250;
Fi := Pi / 6; cs := Cos(Fi); sn := Sin(Fi);
Canvas.Brush.Color := clBlack;
Canvas.Ellipse(px - 5, py - 5, px + 6, py + 6); //player

Canvas.Brush.Style := bsClear;
Canvas.MoveTo(px, py);
XX := px - Round(Wdt / 2 * sn); YY := py + Round(Wdt / 2 * cs);
Canvas.LineTo(XX, YY);
XX := XX + Round(lng * cs); YY := YY + Round(lng * sn);
Canvas.LineTo(XX, YY);
XX := XX + Round(Wdt * sn); YY := YY - Round(Wdt * cs);
Canvas.LineTo(XX, YY);
XX := XX - Round(lng * cs); YY := YY - Round(lng * sn);
Canvas.LineTo(XX, YY);
Canvas.LineTo(px, py); //rectangle finished

for i := 0 to 99 do begin
tx := 100 + Random(600); //random target
ty := 100 + Random(600);
ptx := tx - px;
pty := ty - py;
perplen := Abs(ptx * sn - pty * cs);
alonglen := ptx * cs + pty * sn;
if (perplen <= Wdt / 2) and (alonglen >= 0) and (alonglen <= lng) then
Canvas.Brush.Color := clBlue // in region
else
Canvas.Brush.Color := clRed;
Canvas.Ellipse(tx - 3, ty - 3, tx + 4, ty + 4);
end;

enter image description here

关于java - 3D 考虑玩家 Y 旋转,创建一个到一定距离的点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57599014/

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