首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在vtk.js中将法线设置为多边形数据时的TubeFilter问题

在vtk.js中将法线设置为多边形数据时的TubeFilter问题
EN

Stack Overflow用户
提问于 2019-11-01 17:20:04
回答 1查看 183关注 0票数 0

我可以在vtk.js中将自己的法线设置为多维数据(线条),它工作得很好。但是当我尝试对上述多数据使用TubeFilter时,它不起作用;我只能在不设置法线的情况下生成管状体。在调用tubeFilter.update()之后,程序不会运行任何代码。

我这样创建我的法线:

代码语言:javascript
复制
  const numSegments  = 1;
  const normals = new Float32Array(3 * (numSegments + 1));
  const normalArray = vtkDataArray.newInstance({
    name: 'Normals',
    values: normals,
    numberOfComponents: 3,
  });

  for(let i=0; i<numSegments + 1; i++) {
    normals[i*3+0] = 0;
    normals[i*3+1] = 0;
    normals[i*3+2] = 1;
  }

并将其设置为polydata,如下所示:

polyData.getPointData().setNormals(normalArray);

我按如下方式创建管过滤器:

代码语言:javascript
复制
const tubeFilter = vtkTubeFilter.newInstance();
tubeFilter.setCapping(false);
tubeFilter.setNumberOfSides(50);
tubeFilter.setRadius(0.1);
tubeFilter.setInputData(polyData);
tubeFilter.setInputArrayToProcess(0, 'Scalars', 'PointData', 'Scalars');
tubeFilter.update(); // Program stops here

为什么它不起作用?我做错了什么?我必须做什么才能用我自己的法线生成一个管?下面是完整的代码:index.js;它是this example的简化版本。

未设置法线时生成的管线线的Here's an image (左),仅设置法线时生成的线(右),因为代码在尝试生成管线管后停止。

EN

回答 1

Stack Overflow用户

发布于 2019-11-10 01:39:41

您可以使用vtkTubeFilter类的SetDefaultNormal函数。就像这样使用它,忽略创建向量法线,然后将它们放入行中:

代码语言:javascript
复制
const tubeFilter = vtkTubeFilter.newInstance();
tubeFilter.setCapping(false);
tubeFilter.setNumberOfSides(50);
tubeFilter.setRadius(0.1);
tubeFilter.setInputData(polyData);
tubeFilter.useDefaultNormalOn();
tubeFilter.setDefaultNormal(0,0,1);
tubeFilter.setInputArrayToProcess(0, 'Scalars', 'PointData', 'Scalars');
tubeFilter.update(); // Program stops here
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58656759

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档