Java OpenGL:3D空间中的鼠标拾取

时间:2012-09-10 18:15:11

标签: java opengl mouse lwjgl picking

我正在尝试使用Java和OpenGL制作某种3D编辑器。现在我正在实现3D编辑器的基本功能,例如围绕特定位置旋转相机并进行缩放。接下来,我想进行3D拾取,使用鼠标在3D空间中选择对象,线条和顶点。我认为这很容易,因为我可以在相机聚焦时选择对象。

以下是具有相机焦点的对象选择示例:

在类摄像机中有以下方法:

    public boolean isVecInFocus(Vec3 vec) {

    //returns the distance between camera and target

    float c = new Vec3(posX,posY,posZ).getDistanceTo(vec);

    // returns a Vector by drawing an imiginary line with the length of c and the position and rotation of the camera

    Vec3 target = getFocusedPoint(c);

    //checks if the calculated Vector is near to the target

    if(target.x > vec.x - 0.05f && target.x < vec.x + 0.05f && target.y > vec.y - 0.05f && target.y < vec.y + 0.05f && target.z > vec.z - 0.05f && target.z < vec.z + 0.05f) {

        return true;
    } else {

        return false;
    }
}

现在,我想对鼠标输入做同样的事情:

    //Mouse positions
    float mX = Mouse.getX();
    float mY = Mouse.getY();

    //My test Vector
    Vec3 vec = new Vec3(-5,5,-8);

    //Camera Position
    Vec3 camV = new Vec3(cam.getPosX(),cam.getPosY(),cam.getPosZ());

    //Distance from Test Vector to Camera
    float c = camV.getDistanceTo(vec);

    //Calculating of the aspect between width and height (Because fov_x and fov_y are different because of the Screen Resolution, I think)
    float aspect = (float) sb.getDisplayWidth() / (float) sb.getDisplayHeight();

    //Normal fov refers to fov_y, so here is the fov_x
    float fovx = cam.fov * aspect;

    //Changing the Rotations to calculate the target Vector with the values of the Mouse position and rotations , not the Camera
    float rotY = cam.getRotationY() + (fovx / (float) sb.getDisplayWidth()) * (mX) - (fovx / 2F);
    float rotX = cam.getRotationX() + (cam.fov / (float) sb.getDisplayHeight()) * ((float) sb.getDisplayHeight() - mY) - (cam.fov / 2F);

    //Calculating the target Vector with simple Math ...

    double xDis = c * Math.sin(Math.toRadians(rotY)) * Math.cos(Math.toRadians(rotX));
    double yDis = c * Math.sin(Math.toRadians(rotX));
    double zDis = c * Math.cos(Math.toRadians(rotY)) * Math.cos(Math.toRadians(rotX));

    float posX = (float) (camV.x + xDis);
    float posY = (float) (camV.y - yDis);
    float posZ = (float) (camV.z - zDis);

    Vec3 target = new Vec3(posX,posY,posZ);

    //Check if the target Vector and the Test Vector are the same.

如果我使用此代码,并将我的鼠标指向Test-Vector,则结果不正确。 Point的精度越低,Screen-middle和Mouse位置之间的差异就越大。

我认为这与OpenGL Perspective有关,但我不确定......

0 个答案:

没有答案