在Java中绘制网格网格表面

时间:2016-10-06 14:30:17

标签: java plot mesh surface jzy3d

我有一个40x40的数组,其中填充了double个值,这些值对应于由Java中的2个矩阵组成的网格。 我想在3D中绘制这些值的表面,并找到合适的JZY3D库,但我不知道从哪里开始以及如何编写这种情节。 有人在这个图书馆工作,可以就从哪里开始提供一个很好的建议吗?

1 个答案:

答案 0 :(得分:1)

看起来像是jzy3D的SurfaceDemo。 你需要创建表面而不是buildOrthonormal(SurfaceDemo.java中的第36行)。

ans:https://stackoverflow.com/a/8339474

算法:https://www.mathworks.com/help/matlab/ref/surf.html

double[][] Z = new double[40][40];
...
List<Polygon> polygons = new ArrayList<Polygon>();
for(int i = 0; i < zq.length -1; i++){
    for(int j = 0; j < zq[0].length -1; j++){
        Polygon polygon = new Polygon();
        polygon.add(new Point(new Coord3d(i, j, Z[i][j])));
        polygon.add(new Point(new Coord3d(i, j+1, Z[i][j+1])));
        polygon.add(new Point(new Coord3d(i+1, j+1, Z[i+1][j+1])));
        polygon.add(new Point(new Coord3d(i+1, j, Z[i+1][j])));
        polygons.add(polygon);
    }
}
final Shape surface = new Shape(polygons);
surface.setColorMapper(new ColorMapper(new ColorMapRainbow(), surface.getBounds().getZmin(), surface.getBounds().getZmax(), new Color(1, 1, 1, .5f)));
surface.setFaceDisplayed(true);
surface.setWireframeDisplayed(true);
// Create a chart and add it
Chart chart = new Chart();
chart.getAxeLayout().setMainColor(Color.WHITE);
chart.getView().setBackgroundColor(Color.BLACK);
chart.getScene().add(surface);
ChartLauncher.openChart(chart);

result