0

doubleJava の 2 つの行列で構成されるメッシュ グリッドに対応する値で満たされた 40x40 配列があります。これらの値からサーフェスを 3D でプロットしたいのですが、適切と思われるJZY3Dライブラリを見つけましたが、この種のプロットをどこから開始し、どのようにコーディングすればよいかわかりません。誰もがこのライブラリを使用しており、どこから始めるべきかについて良いアドバイスを与えることができますか?

4

1 に答える 1

1

jzy3D の SurfaceDemo のようです。buildOrthonormal (SurfaceDemo.java の 36 行目) ではなく、サーフェスを作成する必要があります。

回答: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);

結果

于 2016-10-12T01:16:14.567 に答える