我正在尝试使用 Jonathan Feinberg 的 Peasycam 库进行处理,以围绕对象的 Z 轴旋转相机。文档指定旋转是围绕主题,而不是对象。这似乎很难实现。peasycam 旋转围绕主题(即相机)而不是对象,尽管在控制意义上 peasycam 的重点是面向对象的。并且设置camera()
似乎也有问题,因为我无法让 peasycam 记住分配的相机的位置。还有一个差异,即 peasycam 的 y 轴映射到数据空间的 z 轴。
我已经制作了一个基本模型来帮助以交互方式解释这一点。如果一些新鲜的眼睛可以帮助解开这个问题,我将不胜感激。Peasycam 可能需要安装到应用程序的库文件夹中。总体目标是为了动画目的能够在 Z 轴上旋转 3D 数据图。提前致谢。
import peasy.*;
PVector camPos;
PVector[] points = new PVector[50];
float angleXY, d;
PeasyCam cam;
void setup() {
size(300,300,P3D);
cam = new PeasyCam(this, 100);
cam.setMinimumDistance(50);
cam.setMaximumDistance(150);
for(int i=0; i<50; i++) points[i] = new PVector(random(-15,15),random(-15,15),random(-15,15));
}
void draw() {
background(250);
noFill();
box(30);
// axes for frame of reference
stroke(255,0,0); // red = Z
line(0,0,-100,0,0,100);
stroke(0,255,0); // green = Y
line(0,-100,0,0,100,0);
stroke(0,0,255); // blue = X
line(-100,0,0,100,0,0);
// points on axes to denote positive orientation
strokeWeight(3);
for(PVector p:points) point(p.x, p.y, p.z);
strokeWeight(5);
point(40,0,0);
point(0,40,0);
point(0,0,40);
strokeWeight(1);
stroke(0);
camPos = new PVector(cam.getPosition()[0], cam.getPosition()[1], cam.getPosition()[2]);
angleXY = degrees(atan2(camPos.z, camPos.x)); // camera XY angle from origin
d = sqrt(pow(camPos.z, 2) + pow(camPos.x, 2)); // camera-object XY distance (compare to cam.getDistance())
// ZX campera slots map to XY data plane:
println("campos: " + camPos + " " + ", ang: " + angleXY + ", dist:" + d);
}
void keyPressed(){
if(key=='r') setup(); // restart
if(key==' ') camera(camPos.x, camPos.y, camPos.z, 0, 0, 0, 0, 0, 1); // stabilise image on Z axis
if(key=='d') {
angleXY += radians(1);
camera(sin(angleXY)*d, camPos.y, cos(angleXY)*d, 0, 0, 0, 0, 1, 0);
}
// peasycam's rotations work around the subject:
if(key=='p') cam.rotateY(radians(2));
}