use of org.fxyz.shapes.composites.SurfacePlot in project FXyzLib by Birdasaur.
the class SurfacePlotTest method start.
@Override
public void start(Stage primaryStage) throws Exception {
Group sceneRoot = new Group();
Scene scene = new Scene(sceneRoot, sceneWidth, sceneHeight, true, SceneAntialiasing.BALANCED);
scene.setFill(Color.BLACK);
camera = new PerspectiveCamera(true);
camera.setNearClip(0.1);
camera.setFarClip(10000.0);
camera.setTranslateZ(-1000);
scene.setCamera(camera);
int size = 10;
float[][] arrayY = new float[2 * size][2 * size];
// The Sombrero
for (int i = -size; i < size; i++) {
for (int j = -size; j < size; j++) {
double R = Math.sqrt((i * i) + (j * j)) + 0.00000000000000001;
arrayY[i + size][j + size] = ((float) -(Math.sin(R) / R)) * 100;
}
}
surfacePlot = new SurfacePlot(arrayY, 10, Color.AQUA, false, false);
sceneRoot.getChildren().addAll(surfacePlot);
PointLight light = new PointLight(Color.WHITE);
sceneRoot.getChildren().add(light);
light.setTranslateZ(sceneWidth / 2);
light.setTranslateY(-sceneHeight + 10);
PointLight light2 = new PointLight(Color.WHITE);
sceneRoot.getChildren().add(light2);
light2.setTranslateZ(-sceneWidth + 10);
light2.setTranslateY(-sceneHeight + 10);
scene.setOnKeyPressed(event -> {
double change = 10.0;
// Add shift modifier to simulate "Running Speed"
if (event.isShiftDown()) {
change = 50.0;
}
// What key did the user press?
KeyCode keycode = event.getCode();
// Step 2c: Add Zoom controls
if (keycode == KeyCode.W) {
camera.setTranslateZ(camera.getTranslateZ() + change);
}
if (keycode == KeyCode.S) {
camera.setTranslateZ(camera.getTranslateZ() - change);
}
// Step 2d: Add Strafe controls
if (keycode == KeyCode.A) {
camera.setTranslateX(camera.getTranslateX() - change);
}
if (keycode == KeyCode.D) {
camera.setTranslateX(camera.getTranslateX() + change);
}
});
// Add a Mouse Handler for Rotations
Rotate xRotate = new Rotate(0, Rotate.X_AXIS);
Rotate yRotate = new Rotate(0, Rotate.Y_AXIS);
Rotate zRotate = new Rotate(0, Rotate.Z_AXIS);
surfacePlot.getTransforms().addAll(xRotate, yRotate, zRotate);
// Use Binding so your rotation doesn't have to be recreated
xRotate.angleProperty().bind(angleX);
yRotate.angleProperty().bind(angleY);
zRotate.angleProperty().bind(angleZ);
// Start Tracking mouse movements only when a button is pressed
scene.setOnMousePressed(event -> {
scenex = event.getSceneX();
sceney = event.getSceneY();
fixedXAngle = angleX.get();
fixedYAngle = angleY.get();
if (event.isMiddleButtonDown()) {
scenez = event.getSceneX();
fixedZAngle = angleZ.get();
}
});
// Angle calculation will only change when the button has been pressed
scene.setOnMouseDragged(event -> {
if (event.isMiddleButtonDown())
angleZ.set(fixedZAngle - (scenez - event.getSceneY()));
else
angleX.set(fixedXAngle - (scenex - event.getSceneY()));
angleY.set(fixedYAngle + sceney - event.getSceneX());
});
primaryStage.setTitle("F(X)yz SurfacePlotTest");
primaryStage.setScene(scene);
primaryStage.show();
}
Aggregations