具有多个子网格的ModelRenderable仅显示一个子网格

时间:2019-07-07 04:08:09

标签: java android arcore sceneform

我需要在ARCore中合并多个多维数据集以成为一个ModelRenderable。我有从每个多维数据集获取顶点和子网格并创建一个ModelRenderable的代码,但是,仅渲染最后添加的多维数据集。

我只有添加的最后一个多维数据集显示,如前所述。我可以看到的一件奇怪的事是,有些顶点的位置相同,所以我不确定那是正确的。

这是我的代码,获取每个多维数据集并添加子网格和顶点。

List<RenderableDefinition.Submesh> submeshes = new ArrayList<>();
List<Vertex> vertices = new ArrayList<>();

for (SubCube cube : cubes) {
    submeshes.add(cube.getSubmesh());
    vertices.addAll(cube.getVertices());
}

RenderableDefinition renderableDefinition = RenderableDefinition.builder().setVertices(vertices).setSubmeshes(submeshes).build();
CompletableFuture future = ModelRenderable.builder().setSource(renderableDefinition).build();

ModelRenderable result = (ModelRenderable) future.get();

这是我创建多维数据集的代码。它与ShapeFactory.makeCube基本相同。

    public SubCube makeCube(Vector3 size, Vector3 center, Material material) {
        AndroidPreconditions.checkMinAndroidApiLevel();
        Vector3 extents = size.scaled(0.5F);
        Vector3 p0 = Vector3.add(center, new Vector3(-extents.x, -extents.y, extents.z));
        Vector3 p1 = Vector3.add(center, new Vector3(extents.x, -extents.y, extents.z));
        Vector3 p2 = Vector3.add(center, new Vector3(extents.x, -extents.y, -extents.z));
        Vector3 p3 = Vector3.add(center, new Vector3(-extents.x, -extents.y, -extents.z));
        Vector3 p4 = Vector3.add(center, new Vector3(-extents.x, extents.y, extents.z));
        Vector3 p5 = Vector3.add(center, new Vector3(extents.x, extents.y, extents.z));
        Vector3 p6 = Vector3.add(center, new Vector3(extents.x, extents.y, -extents.z));
        Vector3 p7 = Vector3.add(center, new Vector3(-extents.x, extents.y, -extents.z));
        Vector3 up = Vector3.up();
        Vector3 down = Vector3.down();
        Vector3 front = Vector3.forward();
        Vector3 back = Vector3.back();
        Vector3 left = Vector3.left();
        Vector3 right = Vector3.right();
        Vertex.UvCoordinate uv00 = new Vertex.UvCoordinate(0.0F, 0.0F);
        Vertex.UvCoordinate uv10 = new Vertex.UvCoordinate(1.0F, 0.0F);
        Vertex.UvCoordinate uv01 = new Vertex.UvCoordinate(0.0F, 1.0F);
        Vertex.UvCoordinate uv11 = new Vertex.UvCoordinate(1.0F, 1.0F);
        List<Vertex> vertices = Arrays.asList(
                Vertex.builder().setPosition(p0).setNormal(down).setUvCoordinate(uv01).build(),
                Vertex.builder().setPosition(p1).setNormal(down).setUvCoordinate(uv11).build(),
                Vertex.builder().setPosition(p2).setNormal(down).setUvCoordinate(uv10).build(),
                Vertex.builder().setPosition(p3).setNormal(down).setUvCoordinate(uv00).build(),
                Vertex.builder().setPosition(p7).setNormal(left).setUvCoordinate(uv01).build(),
                Vertex.builder().setPosition(p4).setNormal(left).setUvCoordinate(uv11).build(),
                Vertex.builder().setPosition(p0).setNormal(left).setUvCoordinate(uv10).build(),
                Vertex.builder().setPosition(p3).setNormal(left).setUvCoordinate(uv00).build(),
                Vertex.builder().setPosition(p4).setNormal(front).setUvCoordinate(uv01).build(),
                Vertex.builder().setPosition(p5).setNormal(front).setUvCoordinate(uv11).build(),
                Vertex.builder().setPosition(p1).setNormal(front).setUvCoordinate(uv10).build(),
                Vertex.builder().setPosition(p0).setNormal(front).setUvCoordinate(uv00).build(),
                Vertex.builder().setPosition(p6).setNormal(back).setUvCoordinate(uv01).build(),
                Vertex.builder().setPosition(p7).setNormal(back).setUvCoordinate(uv11).build(),
                Vertex.builder().setPosition(p3).setNormal(back).setUvCoordinate(uv10).build(),
                Vertex.builder().setPosition(p2).setNormal(back).setUvCoordinate(uv00).build(),
                Vertex.builder().setPosition(p5).setNormal(right).setUvCoordinate(uv01).build(),
                Vertex.builder().setPosition(p6).setNormal(right).setUvCoordinate(uv11).build(),
                Vertex.builder().setPosition(p2).setNormal(right).setUvCoordinate(uv10).build(),
                Vertex.builder().setPosition(p1).setNormal(right).setUvCoordinate(uv00).build(),
                Vertex.builder().setPosition(p7).setNormal(up).setUvCoordinate(uv01).build(),
                Vertex.builder().setPosition(p6).setNormal(up).setUvCoordinate(uv11).build(),
                Vertex.builder().setPosition(p5).setNormal(up).setUvCoordinate(uv10).build(),
                Vertex.builder().setPosition(p4).setNormal(up).setUvCoordinate(uv00).build());

        ArrayList<Integer> triangleIndices = new ArrayList(36);

        for(int i = 0; i < 6; ++i) {
            triangleIndices.add(3 + 4 * i);
            triangleIndices.add(1 + 4 * i);
            triangleIndices.add(0 + 4 * i);
            triangleIndices.add(3 + 4 * i);
            triangleIndices.add(2 + 4 * i);
            triangleIndices.add(1 + 4 * i);
        }

        RenderableDefinition.Submesh submesh = RenderableDefinition.Submesh.builder().setTriangleIndices(triangleIndices).setMaterial(material).build();
        return new SubCube(submesh, vertices);
    }

我没有收到错误消息或其他任何消息。我知道makeCube的传递位置是不同的,所以这不是问题。预期的行为是,我能够在一个ModelRenderable中渲染多个立方体。

1 个答案:

答案 0 :(得分:1)

在将所有顶点合并到最终数组(名为vertices)中时,三角形索引应在每个子立方体中偏移。

  • 对于第一个多维数据集,索引值从0到23(因为每个多维数据集有24个顶点)
  • 对于第二个多维数据集,索引值从24到47
  • 对于第i个 多维数据集,索引值从(i-1)* 24变为i * 24-1

否则,通过仅使用一个可渲染但位置不同的子节点创建一个多维数据集几何图形和一个节点层次结构,即可达到相同的结果。

相关问题