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

(36)VTK C++开发示例 ---纹理贴图四边形

文章目录

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


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

1. 概述

此示例定义 4 个点(共面)并使用输入图像对它们进行纹理处理。

主要实现了以下功能:

  1. 创建几何形状
    • 定义了一个四边形的顶点(vtkPoints)和多边形(vtkPolygon)。
    • 使用 vtkCellArray 将顶点连接成一个多边形。
    • 将顶点和多边形数据存储到 vtkPolyData 中。
  2. 设置纹理坐标
    • 定义了纹理坐标(vtkFloatArray),并将其与多边形数据关联,用于纹理映射。
  3. 加载纹理
    • 使用 vtkJPEGReader 加载了一张 JPEG 图片作为纹理。
    • 将纹理数据传递给 vtkTexture。
  4. 创建渲染管线
    • 使用 vtkPolyDataMapper 将几何数据映射为图形数据。
    • 创建了一个 vtkActor,将几何数据和纹理绑定到演员对象。
    • 设置了演员的颜色和纹理。
  5. 设置渲染环境
    • 创建了一个 vtkRenderer,将演员添加到渲染器中,并设置背景颜色。
    • 创建了一个 vtkRenderWindow,将渲染器添加到窗口中,并设置窗口大小。
    • 创建了一个 vtkRenderWindowInteractor,用于处理用户交互。
  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
CommonDataModel
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 20:31:57
* 开发者:   MHF
* 邮箱:     1603291350@qq.com
* 功能:     
*********************************************************************************/
#include <string>
#include <vtkCellArray.h>
#include <vtkFloatArray.h>
#include <vtkImageData.h>
#include <vtkJPEGReader.h>
#include <vtkNamedColors.h>
#include <vtkNew.h>
#include <vtkPointData.h>
#include <vtkPolyData.h>
#include <vtkPolyDataMapper.h>
#include <vtkPolygon.h>
#include <vtkProperty.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkTexture.h>using namespace std;int main()
{// 创建一个4边形4个顶点vtkNew<vtkPoints> points; //创建点points->InsertNextPoint(0, 0, 0); //插入点points->InsertNextPoint(1, 0, 0); //插入点points->InsertNextPoint(1, 1, 0); //插入点points->InsertNextPoint(0, 2, 0); //插入点vtkNew<vtkPolygon> polygon; //创建多边形polygon->GetPointIds()->SetNumberOfIds(4); //设置多边形的顶点数polygon->GetPointIds()->SetId(0, 0);polygon->GetPointIds()->SetId(1, 1);polygon->GetPointIds()->SetId(2, 2);polygon->GetPointIds()->SetId(3, 3);vtkNew<vtkCellArray> polys; // 用于定义顶点如何连接形成基本图元(如多边形、线段等polys->InsertNextCell(polygon); //插入多边形vtkNew<vtkPolyData> polydata; //创建多边形数据polydata->SetPoints(points); //设置点polydata->SetPolys(polys); //设置多边形vtkNew<vtkFloatArray> tcoords; //创建纹理坐标tcoords->SetNumberOfComponents(2); //设置纹理坐标的组件数tcoords->SetName("TextureCoordinates"); //设置纹理坐标的名称,用于查找纹理坐标数组float tuple[2] = {0.0, 0.0}; //设置纹理坐标tcoords->InsertNextTuple(tuple); //插入纹理坐标tuple[0] = 1.0;  tuple[1] = 0.0;tcoords->InsertNextTuple(tuple);tuple[0] = 1.0;tuple[1] = 1.0;tcoords->InsertNextTuple(tuple);tuple[0] = 0.0;tuple[1] = 2.0;tcoords->InsertNextTuple(tuple);polydata->GetPointData()->SetTCoords(tcoords); //设置纹理坐标vtkNew<vtkNamedColors> colors;string filename = "e:/lib/VTK/vtk-data/Data/wintersun.jpg";vtkNew<vtkJPEGReader> jpegReader; //读取jpg文件jpegReader->SetFileName(filename.c_str());vtkNew<vtkTexture> texture; //创建纹理texture->SetInputConnection(jpegReader->GetOutputPort()); //设置纹理的输入/******************** 开始绘制********************/vtkNew<vtkPolyDataMapper> mapper; //创建映射器mapper->SetInputData(polydata); //设置输入数据vtkNew<vtkActor> actor; //创建演员actor->SetMapper(mapper); //设置映射器actor->SetTexture(texture); //设置纹理actor->GetProperty()->SetColor(colors->GetColor3d("White").GetData()); //设置颜色vtkNew<vtkRenderer> renderer; //创建渲染器renderer->AddActor(actor); //添加演员renderer->SetBackground(colors->GetColor3d("SlateGray").GetData()); //设置背景颜色renderer->ResetCamera(); //重置相机vtkNew<vtkRenderWindow> renderWindow; //创建渲染窗口renderWindow->AddRenderer(renderer); //添加渲染器renderWindow->SetSize(600, 600); //设置窗口大小vtkNew<vtkRenderWindowInteractor> renderWindowInteractor; //创建交互器renderWindowInteractor->SetRenderWindow(renderWindow); //设置渲染窗口renderWindow->Render(); //渲染renderWindowInteractor->Start(); //开始交互return 0;
}

4. 演示效果

在这里插入图片描述



相关文章:

  • 【大模型实战篇】对Qwen3提到的thinking和no thinking混合思考模式的讨论
  • Manus AI多语言手写识别技术解析
  • PostgreSQL 的 VACUUM 与 VACUUM FULL 详解
  • 【git】获取特定分支和所有分支
  • 【Linux深入浅出】之全连接队列及抓包介绍
  • 阿里云服务器防御是怎么做出来的?服务器攻击方式有几种?
  • Java文件上传
  • 【算法基础】选择排序算法 - JAVA
  • ARM 指令集(ubuntu环境学习)第六章:ARM 编程技巧与优化策略
  • 供应链算法整理(一)--- 销量预估
  • 如何掌握 Lustre/Scade 同步数据流语言
  • 基于建造者模式的信号量与理解建造者模式
  • 每日算法-250502
  • Python爬虫实战:获取好大夫在线各专业全国医院排行榜数据并分析,为患者就医做参考
  • 传统银行服务和 区块链支付无缝融合的一种解决方案
  • 【AI面试准备】数据治理与GDPR脱敏机制构建
  • 4.Java中的注释
  • VBA宏即根据第一列的内容和第二列的数字,按照数字数量生成对应内容并依次放在第三列、第四列等
  • c++环境和vscode常用的一些有用插件
  • Qt C++简单图形界面与绘图实验
  • 抢抓消费旺季:五一假期,多地党政主官调研外贸优品展销活动
  • 体坛联播|曼联一只脚迈进欧联杯决赛,赵心童4比4奥沙利文
  • 北部艳阳高照、南部下冰雹,五一长假首日上海天气很“热闹”
  • 沈晓萍︱严金清:比斯坦因更早获得敦煌文物的无锡名士
  • 美国第一季度经济环比萎缩0.3%,特朗普:怪拜登,与关税无关
  • 新能源车盈利拐点:8家上市车企去年合计净利854亿元,多家扭亏