(14)VTK C++开发示例 --- 将点投影到平面上

发布于:2025-05-01 ⋅ 阅读:(27) ⋅ 点赞:(0)


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

1. 概述

计算一个点在一个平面上的投影。

vtkPlane 是 VTK(Visualization Toolkit)库中的一个类,用于表示和操作三维空间中的平面。它继承自 vtkImplicitFunction 抽象类,提供了各种平面计算方法。这些包括将点投影到平面上、计算平面方程式和返回平面法线。

模块:CommonDataModel

环境 说明
系统 ubuntu22.04、windows11
cmake 3.22、3.25
Qt 5.14.2
编译器 g++11.4、msvc2017
VTK 9.4.1

2. CMake链接VTK

cmake_minimum_required(VERSION 3.20 FATAL_ERROR) # 设置CMake最低版本
project(vtk2) # 设置项目名称
# 查找VTK库
find_package(VTK COMPONENTS
CommonCore
CommonDataModel
) 
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-13 20:56:32
* 开发者:   MHF
* 邮箱:     1603291350@qq.com
* 功能:     
*********************************************************************************/
#include<iostream>
#include<vtkPlane.h>
#include<vtkNew.h>
using namespace std;

int main()
{
  vtkNew<vtkPlane> plane; //创建一个平面
  plane->SetOrigin(0, 0, 0); //设置平面的原点
  plane->SetNormal(0, 0, 1); //设置平面的法向量

  double p[3] = {23.1, 54.6, 9.2}; //定义一个点
  double origin[3] = {0, 0, 0}; //定义原点
  double normal[3] = {0, 0, 1}; //定义法向量
  double projected[3]; // 定义投影点

  plane->ProjectPoint(p, origin, normal, projected); //计算点p在平面上的投影点
  cout << "投影点坐标为:" << projected[0] << ", " << projected[1] << ", " << projected[2] << endl; //输出投影点的坐标
  return 0;
}

4. 演示效果

PS E:\Code\C++\vtk1\build\Debug> ."E:/Code/C++/vtk1/build/Debug/vtk2.exe"
投影点坐标为:23.1, 54.6, 0



网站公告

今日签到

点亮在社区的每一天
去签到