3D数据过滤为2D数据集并渲染

news/2024/10/31 1:23:36/

开发环境

  1. Windows 11 家庭中文版
  2. Microsoft Visual Studio Community 2019
  3. VTK-9.3.0.rc0
  4. vtk-example
  5. 参考代码

代码逻辑:初始化数据集points -> 添加数据集到polydata -> 通过vtkVertexGlyphFilter过滤(带顶点、单元数据)polydata为顶点数据 -> 添加过滤后2D数据到vtkPolyDataMapper2D -> 添加到vtkActor2D


Actor2D:

#include <vtkActor2D.h>
#include <vtkNamedColors.h>
#include <vtkNew.h>
#include <vtkPoints.h>
#include <vtkPolyData.h>
#include <vtkPolyDataMapper2D.h>
#include <vtkProperty2D.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkVertexGlyphFilter.h>int main(int, char*[])
{vtkNew<vtkNamedColors> colors;vtkNew<vtkPoints> points;points->InsertNextPoint(10, 10, 0);points->InsertNextPoint(100, 100, 0);points->InsertNextPoint(200, 200, 0);/*VtkPolyData 是一个数据对象,它是 vtkDataSet 的具体实现。VtkPolyData 表示由顶点、直线、多边形和/或三角形条组成的几何结构。点和单元属性值(例如,标量、向量等)也被表示。*/vtkNew<vtkPolyData> polydata;polydata->SetPoints(points);std::cout << "NumberOfCells: " << polydata->GetNumberOfCells() << std::endl;//0 此时还没有指定cellstd::cout << "NumberOfPoints: " << polydata->GetNumberOfPoints() << std::endl;//3/*这个过滤器丢弃输入中的所有单元格,并在每个点上用一个顶点替换它们。这个过滤器的预期用途大致相当于 vtkGlyph3D 过滤器,只不过这个过滤器是专门针对具有许多顶点的数据的,这使得渲染结果比字形过滤器更快,更少混乱。这个过滤器可以采用图形或点集作为输入。*/vtkNew<vtkVertexGlyphFilter> glyphFilter;glyphFilter->SetInputData(polydata);//vtkDataObject->vtkPolyDataglyphFilter->Update();/*VtkPolyDataMapper 是一个将多边形数据(即 vtkPolyData)映射到图形原语的类。VtkPolyDataMapper 作为特定于设备的多边形数据映射器的超类,它实际上执行到渲染/图形硬件/软件的映射。vtkPolyDataMapper用来把输入的数据进行转换为几何图元(点、线、多边形)进行渲染VtkPolyDataMapper2D 是一个映射器,它将3D 多边形数据(vtkPolyData)渲染到2D图像平面(即渲染器的 viewport)上。默认情况下,通过忽略 vtkPolyData 中3D 点的 z坐标,并将 x-y 值作为本地显示值(即像素坐标) ,将3D 数据转换为2D 数据。*/vtkNew<vtkPolyDataMapper2D> mapper;mapper->SetInputConnection(glyphFilter->GetOutputPort());mapper->Update();//VtkActor2D 与 vtkActor 类似,但是它用于二维图像和注释。vtkNew<vtkActor2D> actor;actor->SetMapper(mapper);actor->GetProperty()->SetColor(colors->GetColor3d("Gold").GetData());actor->GetProperty()->SetPointSize(8);// Create a renderer, render window, and interactor.vtkNew<vtkRenderer> renderer;vtkNew<vtkRenderWindow> renderWindow;renderWindow->AddRenderer(renderer);vtkNew<vtkRenderWindowInteractor> renderWindowInteractor;renderWindowInteractor->SetRenderWindow(renderWindow);// Add the actor to the scenerenderer->AddActor(actor);renderer->SetBackground(colors->GetColor3d("DarkSlateGray").GetData());renderWindow->SetSize(300, 300);renderWindow->SetWindowName("Actor2D");// Render and interactrenderWindow->Render();renderWindowInteractor->Start();return EXIT_SUCCESS;
}

http://www.ppmy.cn/news/1195325.html

相关文章

2023面试知识点三

1、强软弱虚引用 强引用 当内存不足的时候&#xff0c;JVM开始垃圾回收&#xff0c;对于强引用的对象&#xff0c;就算是出现了OOM也不会对该对象进行回收&#xff0c;打死也不回收~&#xff01; 强引用是我们最常见的普通对象引用&#xff0c;只要还有一个强引用指向一个对象…

C语言:选择+编程(每日一练Day9)

目录 选择题&#xff1a; 题一&#xff1a; 题二&#xff1a; 题三&#xff1a; 题四&#xff1a; 题五&#xff1a; 编程题&#xff1a; 题一&#xff1a;自除数 思路一&#xff1a; 题二&#xff1a;除自身以外数组的乘积 思路二&#xff1a; 本人实力有限可能对…

c语言作业2

7-1 判断成绩等级&#xff0c;输入3个科目的成绩&#xff0c;如果三门成绩都大于等于80则为优秀&#xff0c;输出等级为A&#xff1b;其余情况为一般&#xff0c;输出等级为B&#xff1b; 输入格式: 输入在一行中给出3个整数取值在[0,100]&#xff0c;其间以空格分隔。 输出格…

全国首批!中国儿童青少年戏剧艺术普及推广中心——福建省艺术馆、福州市文化馆推广中心授牌仪式在福州举办

2023年11月1日&#xff0c;由中国儿童艺术剧院、文化和旅游部全国公共文化发展中心主办&#xff0c;福建省文化和旅游厅支持&#xff0c;福建省艺术馆、福州市文化和旅游局承办&#xff0c;福州市文化馆协办的“中国儿童青少年戏剧艺术普及推广中心——福建省艺术馆、福州市文化…

UI自动化测试:会消失的弹窗(Toast)如何定位?

前言 看到标题可能有的小伙伴们懵了&#xff0c;什么是Toast&#xff0c;其实Toast大家都见过&#xff0c;就是一般在我们页面中停留大概2~3秒的时间后自动消失的弹框&#xff0c;那么既然要做自动化&#xff0c;可能Toast也需要大家进行测试&#xff0c;那么小编今天就来介绍…

VLAN与配置

VLAN与配置 什么是VLAN 以最简单的形式为例。如下图&#xff0c;此时有4台主机处于同一局域网中&#xff0c;很明显这4台主机是能够直接通讯。但此时我需要让处于同一局域网中的PC3和PC4能通讯&#xff0c;PC5和PC6能通讯&#xff0c;并且PC3和PC4不能与PC5和PC6通讯。 为了实…

搭建Radius认证服务器 安当加密

搭建Radius认证服务器需要完成以下步骤&#xff1a; 安装Radius服务器软件。可以选择使用FreeRadius、Radiusd或WinRadius等开源软件&#xff0c;也可以选择使用商业软件如Cisco或安当ASP等。配置认证数据库。在Radius服务器上配置认证数据库&#xff0c;用于存储用户信息和认…

【JMeter】插件管理工具

1. 官方下载地址 Documentation :: JMeter-Plugins.org 2.安装 将该插件的jar包移动到lib/ext下 3.重启JMeter就可以看到插件管理器 4. 安装&#xff0c;更新&#xff0c;删除插件 安装插件 删除插件 更新插件