当前位置: 首页 > news >正文

(37)VTK C++开发示例 ---纹理地球

文章目录

    • 1. 概述
    • 2. CMake链接VTK
    • 3. main.cpp文件
    • 4. 演示效果


更多精彩内容
👉内容导航 👈
👉VTK开发 👈

1. 概述

将图片纹理贴到球体上,实现3D地球的效果。

该代码使用了 VTK (Visualization Toolkit) 库来创建一个纹理化的球体,并将其渲染到窗口中。以下是代码的主要功能概述:

  1. 加载纹理图像
    • 通过 vtkImageReader2Factory 和 vtkImageReader2 加载指定路径的纹理图像文件(如 earthmap2k.jpg)。
    • 将图像数据传递给 vtkTexture 对象,用于生成纹理。
  2. 创建球体几何体
    • 使用 vtkTexturedSphereSource 创建一个球体几何体。
    • 设置球体的纬度和经度分辨率(SetPhiResolutionSetThetaResolution)。
  3. 纹理映射
    • 使用 vtkTransformTextureCoords 对球体的纹理坐标进行变换(目前未启用平移功能)。
    • 将纹理映射到球体表面。
  4. 渲染设置
    • 创建 vtkPolyDataMapper 将几何体数据映射为图形数据。
    • 创建 vtkActor,将纹理和几何体绑定到一起。
    • 创建 vtkRenderer,将演员(Actor)添加到渲染器中,并设置背景颜色为黑色。
  5. 窗口和交互
    • 创建 vtkRenderWindow,用于显示渲染结果。
    • 创建 vtkRenderWindowInteractor,允许用户与渲染窗口进行交互。
    • 设置窗口大小为 600x600,并命名为 “TexturedSphere”。
  6. 渲染与交互
    • 调用 Render() 方法渲染场景。
    • 调用 Start() 方法启动交互模式,允许用户旋转、缩放和移动视图。

演示文件下载地址

环境说明
系统ubuntu22.04、windows11
cmake3.22、3.25
Qt5.14.2
编译器g++11.4、msvc2017
VTK9.4.1

纹理图片:
在这里插入图片描述

2. CMake链接VTK

cmake_minimum_required(VERSION 3.20 FATAL_ERROR) # 设置CMake最低版本
project(vtk2) # 设置项目名称
# 查找VTK库
find_package(VTK COMPONENTS 
CommonColor
CommonCore
FiltersSources
FiltersTexture
IOImage
InteractionStyle
RenderingContextOpenGL2
RenderingCore
RenderingFreeType
RenderingGL2PSOpenGL2
RenderingOpenGL2
)
if(NOT VTK_FOUND)
message("VTK not found")
return()
endif()add_executable(vtk2 main.cpp) # 添加可执行文件target_link_libraries(vtk2 PRIVATE ${VTK_LIBRARIES}) # 链接VTK库
vtk_module_autoinit(TARGETS vtk2 MODULES ${VTK_LIBRARIES}) # 初始化VTK模块

3. main.cpp文件

/********************************************************************************
* 文件名:   main.cpp
* 创建时间: 2025-03-22 22:05:38
* 开发者:   MHF
* 邮箱:     1603291350@qq.com
* 功能:     
*********************************************************************************/
#include<iostream>
#include <vtkActor.h>
#include <vtkCamera.h>
#include <vtkImageReader.h>
#include <vtkImageReader2Factory.h>
#include <vtkNamedColors.h>
#include <vtkNew.h>
#include <vtkPolyDataMapper.h>
#include <vtkProperty.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkSmartPointer.h>
#include <vtkTexture.h>
#include <vtkTextureMapToSphere.h>
#include <vtkTexturedSphereSource.h>
#include <vtkTransformTextureCoords.h>
using namespace std;int main()
{// string fileName = "e:/lib/VTK/vtk-data/Data/earth.ppm";string fileName = "e:/lib/VTK/vtk-data/Data/earthmap2k.jpg";// string fileName = "e:/lib/VTK/vtk-data/Data/mercurymap.jpg";vtkNew<vtkTexturedSphereSource> sphere; //创建一个球体sphere->SetPhiResolution(100); //设置球体的纬度分辨率sphere->SetThetaResolution(100); //设置球体的经度分辨率vtkNew<vtkImageReader2Factory> readerFactory; //创建一个图像读取器工厂vtkSmartPointer<vtkImageReader2> reader; //创建一个图像读取器reader = readerFactory->CreateImageReader2(fileName.c_str()); //创建一个图像读取器reader->SetFileName(fileName.c_str()); //设置图像文件名vtkNew<vtkTexture> texture; //创建一个纹理texture->SetInputConnection(reader->GetOutputPort()); //设置纹理的输入连接texture->InterpolateOn(); //开启纹理插值vtkNew<vtkTransformTextureCoords> transformTexture; //创建一个纹理坐标变换器transformTexture->SetInputConnection(sphere->GetOutputPort()); //设置输入连接
#if 0// 设置纹理坐标在 U/V/W 三个方向上的平移量double translate[3] = {0, 0, 0.0};transformTexture->SetPosition(translate); //设置位置
#endifvtkNew<vtkPolyDataMapper>  mapper; //创建一个多边形数据映射器mapper->SetInputConnection(transformTexture->GetOutputPort()); //设置输入连接vtkNew<vtkActor> actor; //创建一个演员actor->SetMapper(mapper); //设置映射器actor->SetTexture(texture); //设置纹理vtkNew<vtkNamedColors> colors; //创建一个颜色vtkNew<vtkRenderer> renderer; //创建一个渲染器renderer->AddActor(actor); //添加演员renderer->SetBackground(colors->GetColor3d("Black").GetData()); //设置背景颜色vtkNew<vtkRenderWindow> renderWindow; //创建一个渲染窗口renderWindow->AddRenderer(renderer); //添加渲染器renderWindow->SetWindowName("TexturedSphere"); //设置窗口名称renderWindow->SetSize(600, 600);vtkNew<vtkRenderWindowInteractor> renderWindowInteractor; //创建一个渲染窗口交互器renderWindowInteractor->SetRenderWindow(renderWindow); //设置渲染窗口renderWindow->Render(); //渲染renderWindowInteractor->Start(); //开始交互return 0;
}

4. 演示效果

在这里插入图片描述



http://www.xdnf.cn/news/262729.html

相关文章:

  • 多协议 Tracker 系统架构与传感融合实战 第五章 卡尔曼滤波定位算法实战
  • Linux《进程概念(下)》
  • 【Linux】Petalinux驱动开发基础
  • 物联网智能项目之——智能家居项目的实现!
  • 基于PyTorch的食物图像分类实战:从数据处理到模型训练
  • AAA GitOps详解
  • n8n工作流自动化平台的实操:本地化高级部署
  • 浙大:优化视觉模型的过度思考
  • 【Godot】生命周期详解:从节点诞生到销毁的全流程解析
  • 软件工程实践
  • sonar-scanner在扫描JAVA项目时为什么需要感知.class文件
  • Redis持久化:
  • 栈系列一>基本计算器II
  • 数据库介绍以及windows下mysql安装
  • day 11 超参数调整
  • react18基础速成
  • AIGC时代——语义化AI驱动器:提示词的未来图景与技术深潜
  • Elasticsearch:RAG 和 grounding 的价值
  • 机器人--MCU
  • 【React】Hooks useReducer 详解,让状态管理更可预测、更高效
  • 提升办公效率的PDF转图片实用工具
  • Python面向对象编程实战:从类定义到高级特性的进阶之旅(2/10)
  • 参数包展开到初始化列表
  • WGDI-分析WGD及祖先核型演化的集成工具-文献精读126
  • 【中间件】brpc_基础_execution_queue
  • OpenharmonyOS+RK3568,【编译烧录】
  • Ubuntu 24.04 通过 update-alternatives 切换GCC版本
  • 什么是多租户系统
  • Maven 实现多模块项目依赖管理
  • WITH在MYSQL中的用法