第01章 20 使用vtkSphereSource和vtkPolyData逐级构建球体表面数据

使用 vtkPolyData 构建球体表面

cpp 复制代码
#include <vtkSmartPointer.h>
#include <vtkSphereSource.h>
#include <vtkPolyDataMapper.h>
#include <vtkActor.h>
#include <vtkRenderer.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkProperty.h>

int main() {
    // 创建一个球体源
    vtkSmartPointer<vtkSphereSource> sphereSource = vtkSmartPointer<vtkSphereSource>::New();
    sphereSource->SetRadius(50.0);  // 设置球体半径为50
    sphereSource->SetThetaResolution(50);  // 设置经度方向的分辨率
    sphereSource->SetPhiResolution(50);    // 设置纬度方向的分辨率
    sphereSource->Update();

    // 创建Mapper
    vtkSmartPointer<vtkPolyDataMapper> mapper = vtkSmartPointer<vtkPolyDataMapper>::New();
    mapper->SetInputConnection(sphereSource->GetOutputPort());

    // 创建Actor
    vtkSmartPointer<vtkActor> actor = vtkSmartPointer<vtkActor>::New();
    actor->SetMapper(mapper);
    actor->GetProperty()->SetColor(0.0, 0.0, 1.0);  // 设置颜色为蓝色

    // 创建Renderer和RenderWindow
    vtkSmartPointer<vtkRenderer> renderer = vtkSmartPointer<vtkRenderer>::New();
    vtkSmartPointer<vtkRenderWindow> renderWindow = vtkSmartPointer<vtkRenderWindow>::New();
    renderWindow->AddRenderer(renderer);

    // 创建RenderWindowInteractor
    vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor = vtkSmartPointer<vtkRenderWindowInteractor>::New();
    renderWindowInteractor->SetRenderWindow(renderWindow);

    // 将Actor添加到Renderer
    renderer->AddActor(actor);
    renderer->SetBackground(0.1, 0.2, 0.3);  // 设置背景颜色

    // 渲染和交互
    renderWindow->Render();
    renderWindowInteractor->Start();

    return 0;
}

代码说明:

  1. vtkSphereSource :用于生成球体的几何数据。
    • SetRadius(50.0):设置球体的半径为50。
    • SetThetaResolutionSetPhiResolution:设置球体的分辨率(即细分程度)。
  2. vtkPolyDataMapper:将几何数据映射为可渲染的对象。
  3. vtkActor:表示场景中的对象,设置颜色为蓝色。
  4. vtkRenderervtkRenderWindow:用于渲染和显示场景。
  5. vtkRenderWindowInteractor:提供交互功能(如旋转、缩放)。
相关推荐
明洞日记4 天前
【VTK手册036】网格拓扑简化工具:vtkCleanPolyData 使用指南
c++·图像处理·ai·vtk·图形渲染
明洞日记9 天前
【VTK手册034】 vtkGeometryFilter 深度解析:高性能几何提取与转换专家
c++·图像处理·算法·ai·vtk·图形渲染
BoBoZz199 天前
BillboardTextActor3D 3D字体随镜头旋转
python·vtk·图形渲染·图形处理
BoBoZz199 天前
Tutorial_Step6 vtkBoxWidget的交互与控制
python·vtk·图形渲染·图形处理
BoBoZz1910 天前
AnatomicalOrientation 3D人体模型及三个人体标准解剖学平面展示
python·vtk·图形渲染·图形处理
BoBoZz1910 天前
TextureCutQuadric 利用3D隐式函数(Quadrics)来生成2D纹理坐标
python·vtk·图形渲染·图形处理
Dave.B11 天前
VTK核心数据结构:vtkCellLinks 点-单元拓扑关系管理详解
vtk
BoBoZz1912 天前
VTKWithNumpy使用 NumPy 数组来创建3D体渲染所需要的数据
python·vtk·图形渲染·图形处理
明洞日记12 天前
【VTK手册032】vtkImageConstantPad:医学图像边界填充与尺寸对齐
c++·图像处理·vtk·图形渲染
BoBoZz1913 天前
RescaleReverseLUT 演示和比较颜色查找表的重标定和反转
python·vtk·图形渲染·图形处理