旋转对象以指向目标2D

时间:2012-01-30 05:42:01

标签: math rotation 2d angle

我正在尝试制作一个半圆,其直线从其终点指向目标。我已经尝试了一天的多种方式,并且不能让它准确地指向目标位置。到目前为止,这是我的进展:

enter image description here

我正试图让深绿线穿过黄线上的红点。

到目前为止发布代码:

vector init = <105.45535, 105.83867, 2239.99976>;
vector init_unit = <-0.54465, 0.83867, 0.00000>;
vector target = <106,104,2241>;

default{

    state_entry(){
        llListen(-215485231, "", NULL_KEY, "");
    }

    listen(integer c, string n, key i, string m){
        list temp = llParseString2List(m, ["|"], []);
        init = (vector)llList2String(temp, 0); //position
        init_unit = (vector)llList2String(temp, 1);
        init_unit = llVecNorm(<init_unit.x, init_unit.y, 0.0>); //line norm vector


        float angle = llAtan2(init_unit.y, init_unit.x); //find angle
        rotation delta = llEuler2Rot(<0.0, -PI_BY_TWO, PI>); //extra rotation
        rotation rot = delta * llEuler2Rot(<0.0, 0.0, angle>); //convert from vector to rotation
        init = init + <0.0, -0.45, 0.0>*rot; //make new offset

        vector p1 = target - init;
        float angle2 = llAtan2(p1.y, p1.x);
        rotation rot2 = llEuler2Rot(<0.0, 0.0, angle>);

        vector p2 = init + (<0.0, 0.45, 0.0>*(delta*rot2)); //find last other side of semi circle
        p2 = (p2 + p1) - init;
        float angle3 = llAcos((p1*p2)/(llVecMag(p1)*llVecMag(p2))); //find angle between vectors

        llSetRot(delta * llEuler2Rot(<0.0, 0.0, angle2+angle3>)); //set rotation
        llSetPos(init); //set postion
    }

}

半圆在y轴上为1m,每端的中间为+/- <0,0.45,0>。 如果有任何不清楚的地方,请询问。

0 个答案:

没有答案