看看 FXyz库。它是开源的,你可以从代码中学习。
对于纹理,看看这篇文章。
FXyz 有一个类可以完全满足您的要求:使用参数SurfacePlotMesh
绘制基于函数的 3D 表面。g = f(x,y)
Function<Point2D, Number> function
它还包括纹理,因此您可以根据Function<Point3D, Number> density
. 每个值都映射到一种颜色。
Function2DPlotTest
在此处检查此测试。
使用此代码段,您可以绘制一个函数:
@Override
public void start(Stage primaryStage) {
PerspectiveCamera camera = new PerspectiveCamera(true);
camera.setTranslateZ(-30);
SurfacePlotMesh surface = new SurfacePlotMesh(
p-> Math.sin(p.magnitude() + 1e-10) / (p.magnitude() + 1e-10),
20, 20, 100, 100, 4);
surface.setCullFace(CullFace.NONE);
surface.setTextureModeVertices3D(1530, p -> p.magnitude());
surface.getTransforms().addAll(new Rotate(200, Rotate.X_AXIS), new Rotate(-20, Rotate.Y_AXIS));
final Group group = new Group(surface);
Scene scene = new Scene(group, 600, 400, true, SceneAntialiasing.BALANCED);
scene.setCamera(camera);
primaryStage.setScene(scene);
primaryStage.show();
}
data:image/s3,"s3://crabby-images/86548/8654844eedd789b615c5b221a7d4985ea6fa1a95" alt="SurfacePlotMesh"
如果添加密度图:
surface.setTextureModeVertices3D(1530, p -> p.magnitude());
你会得到这个:
data:image/s3,"s3://crabby-images/34198/34198802ff2fafdbbc7dc39236c29bfdaa93caa0" alt="纹理表面绘图网格"
现在如果你想要一个表面的动画,你只需要创建一个:
private SurfacePlotMesh surface;
private long lastEffect;
@Override
public void start(Stage primaryStage) {
PerspectiveCamera camera = new PerspectiveCamera(true);
camera.setTranslateZ(-30);
surface = new SurfacePlotMesh(
p-> Math.sin(p.magnitude() + 1e-10) / (p.magnitude() + 1e-10),
20, 20, 100, 100, 4);
surface.setCullFace(CullFace.NONE);
surface.setTextureModeVertices3D(1530, p -> p.magnitude());
surface.getTransforms().addAll(new Rotate(200, Rotate.X_AXIS), new Rotate(-20, Rotate.Y_AXIS));
final Group group = new Group(surface);
Scene scene = new Scene(group, 600, 400, true, SceneAntialiasing.BALANCED);
scene.setCamera(camera);
primaryStage.setScene(scene);
primaryStage.show();
lastEffect = System.nanoTime();
AtomicInteger count=new AtomicInteger();
AnimationTimer timerEffect = new AnimationTimer() {
@Override
public void handle(long now) {
if (now > lastEffect + 1_000_000_000l) {
double t = (count.get() % 5 + 1);
surface.setFunction2D(p -> Math.sin(t * p.magnitude() + 1e-10)/(t * p.magnitude() + 1e-10));
count.getAndIncrement();
lastEffect = now;
}
}
};
timerEffect.start();
}
你会得到你的表面动画:
data:image/s3,"s3://crabby-images/519e4/519e400751b8bb0e25a24461fe92ab48f78809e2" alt="SurfacePlotMesh 2"
data:image/s3,"s3://crabby-images/6e2d7/6e2d7ccdebe2a84debb7980855d9e631bca92706" alt="SurfacePlotMesh 3"
data:image/s3,"s3://crabby-images/355d9/355d9fcff2199b033cab37e3b1d55e0fab55fa46" alt="SurfacePlotMesh 4"