使用 xyz 坐标和 jzy3d 构建 3d 曲面图 [英] Build a 3d surface plot using xyz coordinates with jzy3d

查看:43
本文介绍了使用 xyz 坐标和 jzy3d 构建 3d 曲面图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我一直在寻找一种将 coord(x,y,z) 列表发送到 jzy3d 的方法.但没有成功.

I've been searching for a way to send a list of coord(x,y,z) to jzy3d. But without success.

我发现的唯一方法是使用带有coord3d"和tesselator"列表的builder",但它实际上不起作用.

The only way I found is to use a "builder" with a list of "coord3d" and a "tesselator", but it actually doesn't work.

实际上我真的不明白 Tesselator 的含义?

I don't realy get the meaning of the Tesselator in fact ?

这是我试过的代码:

public Chart getChart(){

    List<Coord3d> coordinates = new ArrayList<Coord3d>();
    for(int i=0; i<200; i++)
        coordinates.add( new Coord3d(5, 10, 15) );
    Tesselator tesselator = new Tesselator() {          
        @Override
        public AbstractComposite build(float[] x, float[] y, float[] z) {
            return null;
        }
    };      
    tesselator.build(coordinates);
     org.jzy3d.plot3d.primitives.Shape surface = (Shape)Builder.build(coordinates, tesselator);


/*/ Define a function to plot
  Mapper mapper = new Mapper(){
     public double f(double x, double y) {
        return 10*Math.sin(x/10)*Math.cos(y/20)*x;
     }
  };*/

  // Define range and precision for the function to plot
 // Range range = new Range(-150,150);
 // int steps   = 50;

  // Create the object to represent the function over the given range.
 // org.jzy3d.plot3d.primitives.Shape surface = (Shape)Builder.buildOrthonormal(new OrthonormalGrid(range, steps, range, steps), mapper);
  //surface.setColorMapper(new ColorMapper(new ColorMapRainbow(), surface.getBounds().getZmin(), surface.getBounds().getZmax(), new Color(1,1,1,.5f)));
 // surface.setWireframeDisplayed(true);
//  surface.setWireframeColor(Color.BLACK);
  //surface.setFace(new ColorbarFace(surface));
  //surface.setFaceDisplayed(true);
  //surface.setFace2dDisplayed(true); // opens a colorbar on the right part of the display

  // Create a chart
  Chart chart = new Chart("swing");
  chart.getScene().getGraph().add(surface);
  return chart;
}

有人可以告诉我如何用许多 XYZ 坐标输入我的图形,以便我可以得到这样的 3d 曲面图:

Could someone please tell me how to feed my graph with many XYZ coordonates so that I may get a 3d surface plot like this one :


(来源:free.fr)

推荐答案

曲面细分器允许从点列表中创建多边形.Jzy3d 提供了两种基本曲面细分器:一种支持站在规则网格上的点(称为 OrthonormalTesselator),一种支持将非结构化点作为输入(DelaunayTesselator).第二个并不总是工作良好":不是关于它的实现的问题,而是主要的事实是很难决定点应该如何一起工作以形成 3d 多边形.你可以在 Jzy3d wiki 和讨论组上找到一些关于它的讨论.

A tesselator allows creating polygons out of a list of points. Jzy3d provides two base tesselators: one that supports points standing on a regular grid (called OrthonormalTesselator), one that supports unstructured points as input (DelaunayTesselator). The second one is not always "working good": not a problem concerning its implementation but mainly the fact that it's difficult to decide how points should work together to form a polygon in 3d. You may find some discussions about it on Jzy3d wiki and discussion groups.

要手动构建多边形,您应该执行以下操作:

To manually build polygons, here's what you should do:

// Build a polygon list
    double [][]distDataProp = new double[][] {{.25,.45, .20},{.56, .89, .45}, {.6, .3,.7}};
    List<Polygon> polygons = new ArrayList<Polygon>();
    for(int i = 0; i < distDataProp.length -1; i++){
        for(int j = 0; j < distDataProp[i].length -1; j++){
            Polygon polygon = new Polygon();
            polygon.add(new Point( new Coord3d(i, j, distDataProp[i][j]) ));
            polygon.add(new Point( new Coord3d(i, j+1, distDataProp[i][j+1]) ));
            polygon.add(new Point( new Coord3d(i+1, j+1, distDataProp[i+1][j+1]) ));
            polygon.add(new Point( new Coord3d(i+1, j, distDataProp[i+1][j]) ));
            polygons.add(polygon);
        }
    }

    // Creates the 3d object
    Shape surface = new Shape(polygons);
    surface.setColorMapper(new ColorMapper(new ColorMapRainbow(), surface.getBounds().getZmin(), surface.getBounds().getZmax(), new org.jzy3d.colors.Color(1,1,1,1f)));
    surface.setWireframeDisplayed(true);
    surface.setWireframeColor(org.jzy3d.colors.Color.BLACK);

    chart = new Chart();
    chart.getScene().getGraph().add(surface);

这篇关于使用 xyz 坐标和 jzy3d 构建 3d 曲面图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆