我正在编码Java中的植绒算法,但我被困在某个点(使用Ardor3D库,在一个2D平面)。查找三角形角度用于旋转给定实体的位置,初始旋转和目标点'面向'
基本上,我需要找到要添加到当前旋转的角度差。如果你只能用极坐标指向北极0度的位置而不考虑差别,不用担心 - 我有一种方法可以返回角度差,同时考虑角度和负角度的环绕。
此刻,我有以下的代码,这显然不会因为算法的工作没有参考初始旋转:
long tpf = currUpdateTimeMS - lastUpdateTimeMS;
Vector2 pos = new Vector2();
rt.getPosition(pos);
double rot = pos.angleBetween(app.getAvgBoidPos(new Vector2()).normalizeLocal());
rt.setRotation(rot);
pos.addLocal(
Math.cos((rot - MathUtils.HALF_PI)) * (tpf/10f),
Math.sin((rot - MathUtils.HALF_PI)) * (tpf/10f)
);
rt.setPosition(pos);
super.updateLogic();
更新后的代码(不工作,从第一个答案):
long tpf = currUpdateTimeMS - lastUpdateTimeMS;
//rt.setRotation(rt.getRotation() + ((tpf/(ROT_SPEED/2f)) % 360));
Vector2 avgpos = app.getAvgBoidPos(new Vector2());
Vector2 pos = rt.getPosition(new Vector2());
avgpos.subtractLocal(pos);
double angleRads = rt.getRotation() * FastMath.DEG_TO_RAD;
double rot = MathUtils.acos((
(avgpos.getX() * MathUtils.sin(angleRads)
) +
(avgpos.getY() * MathUtils.cos(angleRads)
))/((Math.pow(avgpos.getX(), 2) + Math.pow(avgpos.getY(), 2)) * 0.5));
double adegdiff = rot * FastMath.RAD_TO_DEG;
rt.setRotation(rt.getRotation() - adegdiff);
double newrot = rt.getRotation();
pos.addLocal(
Math.cos((newrot - MathUtils.HALF_PI)) * (tpf/10f),
Math.sin((newrot - MathUtils.HALF_PI)) * (tpf/10f)
);
rt.setPosition(pos);
super.updateLogic();
基于对方的回答另一种修饰:
long tpf = currUpdateTimeMS - lastUpdateTimeMS;
//rt.setRotation(rt.getRotation() + ((tpf/(ROT_SPEED/2f)) % 360));
Vector2 avgpos = app.getAvgBoidPos(new Vector2());
Vector2 pos = rt.getPosition(new Vector2());
avgpos.subtractLocal(pos);
double rot = pos.angleBetween(
app.getAvgBoidPos(new Vector2()).normalizeLocal()
) - (rt.getRotation() * MathUtils.DEG_TO_RAD);
rt.setRotation(rt.getRotation() - (rot * MathUtils.RAD_TO_DEG));
double newrot = rt.getRotation();
pos.addLocal(
Math.cos((newrot - MathUtils.HALF_PI)) * (tpf/10f),
Math.sin((newrot - MathUtils.HALF_PI)) * (tpf/10f)
);
rt.setPosition(pos);
super.updateLogic();
我不是一个真正的数学问题不太好,所以代码将是有益的,而不是公式:)
输入
- 实体的当前位置
- 当前实体的旋转(极性取向)以度
输出
- 度或弧度来增加或减少当前旋转
- ...或学位或弧度提前表示为导向的极角
谢谢如果你能帮助:)
克里斯
所以'rt.getPosition'给出了实体的位置和'app.getAvgBOIDPos'给出了目标位置,是这样吗?什么给了实体的方向? – Beta 2010-10-29 15:41:07
这就是rt.getRotation(),它是以面向极坐标的度数表示的:) – 2010-10-29 15:42:25
糟糕,忘记说你对应用程序是正确的,getAvgBoidPos()给出了实体向实体移动的平均位置。 – 2010-10-29 15:53:58