VTK- vtkStripper

news2024/11/26 9:32:16

前言:本博文主要研究接口vtkStripper的实现原理及主要的应用场景,希望对各位小伙伴有所帮助。

描述:vtkStripper是一个过滤器,用于从输入多边形、三角形带和线中生成三角形带和/或折线。输入多边形仅当它们是三角形时才被组装成三角形条;其他类型的多边形被传递到输出,而不是剥离。(如果需要剥离所有数据,在运行此过滤器之前使用vtkTriangleFilter对非三角形多边形进行三角化。)如果顶点出现在输入polydata中,过滤器将通过(到输出)顶点。还要注意,如果在输入中定义了三角形条或折线,它们将被传递,而不是连接或扩展。(如果你希望剥离这些,在运行vtkStripper之前,使用vtkTriangleFilter将输入分割成三角形和行。)

变量MaximumLength可以用来控制三角形带和折线的最大允许长度。

默认情况下,此筛选器会丢弃与输入相关的任何单元格数据。

这是因为单元格结构发生了变化,并且旧的单元格数据不再有效。当设置了PassCellDataAsFieldData标志时,单元格数据将通过以下规则作为FieldData传递到输出:

1)对于输出中每个不是三角形带的单元格,在输出字段数据中每个单元格插入一次单元格数据。

2)对于输出中的每个三角形条形单元:

Ii)条带中每个点(j|j>=2)插入1个元组。

这是输入中(j-2, j-1, j)形成的单元格的单元格数据。

字段数据的顺序与单元格数据相同,即(vert,line, polyys,tsrips)。

如果输入数据中存在三角形条或折线,它们将被传递到输出数据。如果三角形多边形可用,这个过滤器只会构造三角形条带;并且只在线可用时构造折线。

实例:

1. 针对PolyData数据,通过 vtkFeatureEdges获取边线,得到edges对应的PolyData数据。

vtkIdType numPts   = edges->GetOutput()->GetNumberOfPoints();
vtkIdType numLines = edges->GetOutput()->GetNumberOfLines();
vtkIdType numCells = edges->GetOutput()->GetNumberOfCells();
分别为:526,530,530

2. edges通过Stripper进行整合,得到stripper对应的PolyData数据。

vtkIdType snumPts   = stripper->GetOutput()->GetNumberOfPoints();
vtkIdType snumLines = stripper->GetOutput()->GetNumberOfLines();
vtkIdType snumCells = stripper->GetOutput()->GetNumberOfCells();
分别为:526,6,6

vtkStripper将分散的线连接为折线。

相关代码为:

vtkFeatureEdges* edges = vtkFeatureEdges::New();
edges->SetInputData(m_selectObject->GetPolyData());
edges->BoundaryEdgesOff();
edges->FeatureEdgesOn();
edges->ManifoldEdgesOff();
edges->NonManifoldEdgesOff();
edges->Update();
if (nullptr == edges->GetOutput())
{
    edges->Delete();
    edges = nullptr;
    return;
}
vtkIdType numPts   = edges->GetOutput()->GetNumberOfPoints();
vtkIdType numLines = edges->GetOutput()->GetNumberOfLines();
vtkIdType numCells = edges->GetOutput()->GetNumberOfCells();

vtkStripper* stripper = vtkStripper::New();
stripper->SetInputData(edges->GetOutput());
stripper->Update();
if (nullptr == stripper->GetOutput())
{
    edges->Delete();
    edges = nullptr;
    stripper->Delete();
    stripper = nullptr;
    return;
}
vtkIdType snumPts   = stripper->GetOutput()->GetNumberOfPoints();
vtkIdType snumLines = stripper->GetOutput()->GetNumberOfLines();
vtkIdType snumCells = stripper->GetOutput()->GetNumberOfCells();

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/345489.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux】-- 进程信号(处理、内核)

上篇:【Linux】-- 进程信号(认识、应用)_川入的博客-CSDN博客 目录 信号其他相关常见概念 pending handler block 信号处理的过程 sigset_t sigset_t使用 系统接口 sigpending sigprocmask 捕捉方法 sigaction struct sigactio …

小白入门模拟IC设计,如何快速学习?

众所周知,模拟电路很难学。以最普遍的晶体管来说,我们分析它的时候必须首先分析直流偏置,其次在分析交流输出电压。可以说,确定工作点就是一项相当麻烦的工作(实际中来说),晶体管的参数多、参数…

JavaScript 计时事件

JavaScript 计时事件 通过使用 JavaScript,我们有能力做到在一个设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行。我们称之为计时事件。 在 JavaScript 中使用计时事件是很容易的,两个关键方法是: setInterval() - 间隔指定的…

【CNN记录】tensorflow中depth_to_space

功能把depth维的数据移到space上,与spacetodepth刚好是相反的操作,depth对应channel,space对应height和width,而该操作是把depth上的数据分给height和width上,所以对应有一个参数block_size,要求原tensor的…

CSDN竞赛28期参赛体验

1、小Q的鲜榨柠檬汁 1、题目名称:小Q的鲜榨柠檬汁 团建活动是大家所想要的。 小Q给大家准备了鲜橙汁。 现在有n个朋友买回了k瓶饮料,每瓶有l毫升的饮料,同时还买回 了c个柠檬, 每个柠檬可以切成d片,p克盐。 已知每个朋…

Python基础学习笔记 —— 数据结构与算法

数据结构与算法1 数据结构基础1.1 数组1.2 链表1.3 队列1.4 栈1.5 二叉树2 排序算法2.1 冒泡排序2.2 快速排序2.3 (简单)选择排序2.4 堆排序2.5 (直接)插入排序3 查找3.1 二分查找1 数据结构基础 本章所需相关基础知识&#xff1a…

第七届蓝桥杯省赛——1有奖猜谜

题目: 小明很喜欢猜谜语。 最近,他被邀请参加了X星球的猜谜活动。 每位选手开始的时候都被发给777个电子币。 规则是:猜对了,手里的电子币数目翻倍, 猜错了,扣除555个电子币, 扣完为止。 小明一共猜了15…

入门深度学习——基于全连接神经网络的手写数字识别案例(python代码实现)

入门深度学习——基于全连接神经网络的手写数字识别案例(python代码实现) 一、网络构建 1.1 问题导入 如图所示,数字五的图片作为输入,layer01层为输入层,layer02层为隐藏层,找出每列最大值对应索引为输…

云原生周刊 | 开源领导者应该如何应对碎片化挑战?

Linux Fundation 发布了一份关于开源开发中的碎片化问题的报告《实现全球协作:开源领导者如何应对碎片化挑战》,该报告由华为在美国的研发部门 Futurewei 赞助。报告指出,虽然开源社区越来越国际化,但美国对开源共享和开发进行了过…

源码项目中常见设计模式及实现

原文https://mp.weixin.qq.com/s/K8yesHkTCerRhS0HfB0LeA 单例模式 单例模式是指一个类在一个进程中只有一个实例对象(但也不一定,比如Spring中的Bean的单例是指在一个容器中是单例的) 单例模式创建分为饿汉式和懒汉式,总共大概…

Linux内核驱动开发(一)

Linux内核初探 linux操作系统历史 开发模式 git 分布式管理git clone 获取git push 提交git pull 更新 邮件组 mailing list patch 内核代码组成 Makfile arch 体系系统架构相关 block 块设备 crypto 加密算法 drivers 驱动(85%) atm 通信bluet…

MAC文件误删怎么办?mac数据恢复,亲测很好用的方法

电脑文件误删,应该很多人都经历过。之前分享了很多关于Windows电脑文件误删如何恢复的方法,那么MAC电脑文件误删该怎么办?有什么好方法可以使得mac数据恢复回来吗?下面就给大家分享一些亲测好用的方法! 一、MAC电脑的文…

使用Proxifier+burp抓包总结

一、微信小程序&网页抓包 1. Proxifier简介 Proxifier是一款功能非常强大的socks5客户端,可以让不支持通过代理服务器工作的网络程序能通过HTTPS或SOCKS代理或代理链。 2. 使用Proxifier代理抓包 原理:让微信相关流量先走127.0.0.1:80到burp。具体…

Final Cut Pro 10.6.5

软件介绍Final Cut Pro 10.6.5 已通过小编安装运行测试 100%可以使用。Final Cut Pro 10.6.5 破解版启用了全新的矩形图标,与最新的macOS Ventura设计风格统一,支持最新的macOS 13 文图拉系统,支持Apple M1/M2芯片。经过完整而彻底的重新设计…

数据结构之单链表

一、链表的组成 链表是由一个一个的节点组成的,节点又是一个一个的对象, 相邻的节点之间产生联系,形成一条链表。 例子:假如现在有两个人,A和B,A保存了B的联系方式,这俩人之间就有了联系。 A和…

HashMap底层实现原理概述

原文https://blog.csdn.net/fedorafrog/article/details/115478407 hashMap结构 常见问题 在理解了HashMap的整体架构的基础上,我们可以试着回答一下下面的几个问题,如果对其中的某几个问题还有疑惑,那就说明我们还需要深入代码&#xff0c…

ubuntu 20.04 安装 flameshot截图工具

ubuntu 20.04 安装 flameshot截图工具安装命令使用命令设置快捷键效果图安装命令 sudo apt-get install flameshot安装日志 $ sudo apt-get install flameshot [sudo] password for huifeimao: Reading package lists… Done Building dependency tree Reading state informat…

【零基础入门前端系列】—表格(五)

【零基础入门前端系列】—表格(五) 一、表格 表格在数据展示方面非常简单,并且表现优秀,通过与CSS的结合,可以让数据变得更加美观和整齐。 单元格的特点:同行等高、同列等宽。 表格的基本语法&#xff1…

性能测试之tomcat+nginx负载均衡

nginx tomcat 配置准备工作:两个tomcat 执行命令 cp -r apache-tomcat-8.5.56 apache-tomcat-8.5.56_2修改被复制的tomcat2下conf的server.xml 的端口号,不能与tomcat1的端口号重复,不然会启动报错 ,一台电脑上想要启动多个tomcat&#xff0c…

自定义bean 加载到spring IOC容器中

自定义bean加载到spring容器中的两种方式: 1.在类上添加注解Controller、RestController(本质是Controller)、Service、Repository、Component2.使用Configuration和Bean 这篇文章主要介绍第二种方式原理(因为在实际使用中&#…