VTK-vtkBandedPolyDataContourFilter学习

news2024/9/20 18:32:38

官网有一个例子,看完之后仍然不太明白。经过一点点的探索,记录一下收获。

1.建立一个六边形的点集

Create(vtkPoints, points);
    points->InsertNextPoint(-5, 0, 0);
    points->InsertNextPoint(-2.5, -4.33, 0);
    points->InsertNextPoint(2.5, -4.33, 0);
    points->InsertNextPoint(5, 0, 0);
    points->InsertNextPoint(2.5, 4.33, 0);
    points->InsertNextPoint(-2.5, 4.33, 0);

2.创建单元结构

Create(vtkCellArray, cells);
    cells->InsertNextCell(6);
    cells->InsertCellPoint(0);
    cells->InsertCellPoint(1);
    cells->InsertCellPoint(2);
    cells->InsertCellPoint(3);
    cells->InsertCellPoint(4);
    cells->InsertCellPoint(5);

3.分配一个标量数据

Create(vtkFloatArray, scalars);
    scalars->InsertNextValue(50);
    scalars->InsertNextValue(50);
    scalars->InsertNextValue(150);
    scalars->InsertNextValue(200);
    scalars->InsertNextValue(200);
    scalars->InsertNextValue(150);

顶点上的标量数据如图所示。为了帮助理解,所以数据分配的比较整齐。

4.用上面的数据创建Polydata

Create(vtkPolyData, polydata);
    polydata->SetPoints(points);
    polydata->SetPolys(cells);
    polydata->GetPointData()->SetScalars(scalars);

 5.vtkBandedPolyDataContourFilter等值线

Create(vtkBandedPolyDataContourFilter, bandeds);
    bandeds->SetInputData(polydata);
    bandeds->GenerateValues(5, 75, 175);
    bandeds->Update();

这里的作用是将点标量数据重新划分,生成等值线。

GenerateValues(5, 75, 175)这句话将75-175这个范围划分成4段(5点),会生成下面的等值:

75,100,125,150,175

这样一看非常清晰,这个过滤器从点标量数据生成单元标量数据。 

6.显示条带

Create(vtkPolyDataMapper, mapper);
    mapper->SetInputConnection(bandeds->GetOutputPort());
    mapper->SetScalarModeToUseCellData();
    mapper->SetScalarRange(bandeds->GetOutput()->GetCellData()->GetScalars()->GetRange());

标量模式一定要是cellData,而且标量范围是上面的过滤生成的单元标量范围,也可以手动输入范围,范围外的标量数据就自动取极值了。

7.完整代码

#include<vtkBandedPolyDataContourFilter.h>

#include"vtkFloatArray.h"

#include"vtkModelInit.h"
#include"vtkGloble.h"


int main()
{
    Create(vtkPoints, points);
    points->InsertNextPoint(-5, 0, 0);
    points->InsertNextPoint(-2.5, -4.33, 0);
    points->InsertNextPoint(2.5, -4.33, 0);
    points->InsertNextPoint(5, 0, 0);
    points->InsertNextPoint(2.5, 4.33, 0);
    points->InsertNextPoint(-2.5, 4.33, 0);


    Create(vtkCellArray, cells);
    cells->InsertNextCell(6);
    cells->InsertCellPoint(0);
    cells->InsertCellPoint(1);
    cells->InsertCellPoint(2);
    cells->InsertCellPoint(3);
    cells->InsertCellPoint(4);
    cells->InsertCellPoint(5);

    Create(vtkFloatArray, scalars);
    scalars->InsertNextValue(50);
    scalars->InsertNextValue(50);
    scalars->InsertNextValue(150);
    scalars->InsertNextValue(200);
    scalars->InsertNextValue(200);
    scalars->InsertNextValue(150);

    Create(vtkPolyData, polydata);
    polydata->SetPoints(points);
    polydata->SetPolys(cells);
    polydata->GetPointData()->SetScalars(scalars);


    Create(vtkBandedPolyDataContourFilter, bandeds);
    bandeds->SetInputData(polydata);
    bandeds->GenerateValues(5, 75, 175);
    bandeds->Update();

    Create(vtkPolyDataMapper, mapper);
    mapper->SetInputConnection(bandeds->GetOutputPort());
    mapper->SetScalarModeToUseCellData();
    mapper->SetScalarRange(bandeds->GetOutput()->GetCellData()->GetScalars()->GetRange());


    Create(vtkActor, actor);
    actor->SetMapper(mapper);
    Create(vtkRenderer, render);
    render->AddActor(actor);
    Create(vtkRenderWindow, window);
    window->AddRenderer(render);
    Create(vtkRenderWindowInteractor, inter);
    inter->SetRenderWindow(window);


    inter->Start();
    return 0;
}

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

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

相关文章

网络安全-dom破坏结合jq漏洞以及框架漏洞造成的xss-World War 3

一、环境 XSS Game - Learning XSS Made Simple! | Created by PwnFunction 二、开始介绍 如果notify为真的话那么html是 <div class"alert alert-warning" role"alert"><b>Meme</b> created from ${DOMPurify.sanitize(text)}</d…

DevOps实现CI/CD实战(七)- Jenkins集成k8s实现自动化CI

自动化CI操作 1. 安装gitlab plugin 工具 ##### 2. 配置流水线任务的构建触发器&#xff0c;复制URL&#xff1a;http://192.168.201.111:8080/project/pipeline 3. Gitlab配置Webhooks&#xff0c;将上面的url&#xff1a;http://192.168.201.111:8080/project/pipeline粘…

基于微信小程序+Java+SpringBoot+Vue+MySQL的网上花店/鲜花销售小程序

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 基于微信小程序JavaSpringBootVueMySQL的网上花店/鲜花销售…

AI绘画stable diffussion :Lora大模型微调的利器

前言 LoRA模型是小型的Stable Diffusion模型&#xff0c;它们对checkpoint模型进行微小的调整。它们的体积通常是检查点模型的10到100分之一。因为体积小&#xff0c;效果好&#xff0c;所以lora模型的使用程度比较高。 这是一篇面向从未使用过LoRA模型的初学者的教程。你将了…

使用tesseract.js插件实现前端js识别提取图片的文字

<!DOCTYPE html> <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>图像OCR Tesseract.js 测试…

给豆包MarsCode 编程插件点赞

本文正在参加豆包MarsCode测评官征文活动 首先MarsCode 拉新福利还是蛮高的有E卡、周边T恤、肯德基代金券显卡等hahaha…… 略微炫耀一下100京东E卡&#xff0c;真香&#xff01; 活动入口&#xff1a;https://www.marscode.cn/events/s/ihx7hkNY/ 顺手帮忙助个力谢谢~ 2…

人工智能 | 搭建企业内部的大语言模型系统

大纲 开源大语言模型大语言模型管理私有大语言模型服务部署方案 开源大语言模型 担心安全与隐私&#xff1f;可私有部署的开源大模型 商业大模型&#xff0c;不支持私有部署 ChatGPTClaudeGoogle Gemini百度问心一言 开源大模型&#xff0c;支持私有部署 MistralMeta Llama…

ssl 协议工作过程

ssl 协议工作过程 ChatGPT 说&#xff1a; ChatGPT SSL&#xff08;Secure Sockets Layer&#xff09;协议是用来确保网络通信安全的加密协议&#xff0c;已被TLS&#xff08;Transport Layer Security&#xff09;取代&#xff0c;但它的工作过程仍然是理解现代加密协议的重…

【视频教程】GEE-PIE遥感大数据处理与典型案例实践

随着航空、航天、近地空间等多个遥感平台的不断发展&#xff0c;近年来遥感技术突飞猛进。由此&#xff0c;遥感数据的空间、时间、光谱分辨率不断提高&#xff0c;数据量也大幅增长&#xff0c;使其越来越具有大数据特征。对于相关研究而言&#xff0c;遥感大数据的出现为其提…

《开发环境使用HTTPS调试》

&#x1f916; 作者简介&#xff1a;水煮白菜王 &#xff0c;一位资深前端劝退师 &#x1f47b; &#x1f440; 文章专栏&#xff1a; 前端专栏 &#xff0c;记录一下平时在博客写作中&#xff0c;总结出的一些开发技巧✍。 感谢支持&#x1f495;&#x1f495;&#x1f495; 近…

CoreDownload - WordPress文章下载增强插件v1.0.6

文章内下载效果 后台编辑页面 CoreDownload 是一款高级WordPress 下载增强插件&#xff0c;支持几乎所有网盘&#xff0c;为WordPress增加任意下载功能 安装插件后&#xff0c;在设置中全局开启。然后编辑文章&#xff0c;可以在下面找到CoreDownload下载增强功能。 插件下载 …

以太网和WIFI之间的网络切换脚本(Window环境)

网络切换脚本 在本地创建Window的批处理脚本【网络切换脚本.bat】&#xff0c;填入以下内容&#xff0c;然后以管理员身份运行&#xff0c;即可实现以太网和WIFI之间的切换。 echo off netsh interface show interface "WLAN" | find "管理状态: 已启用"…

SLM21814系列SiLM21814CJ-AQ能提供独立的高边、低边输出驱动信号 一款高压、高速的功率MOSFET和IGBT驱动器

SLM21814系列SiLM21814CJ-AQ是一款高压、高速的功率MOSFET和IGBT驱动器&#xff0c;它提供独立的高边、低边输出驱动信号。采用专有的高压集成电路和锁存免疫CMOS技术&#xff0c;提供可靠的单芯片驱动方案。逻辑输入电平与标准CMOS或LSTTL输出兼容&#xff0c;最低支持3.3V逻辑…

家常菜才最适合减肥!最新研究发现,减少外出就餐次数可减少儿童肥胖

虽然老人们都喜欢孩子能“白白胖胖”&#xff0c;但随着生活水平的提高&#xff0c;儿童肥胖已成为一个不可忽视的健康问题。据报道&#xff0c;我国6-17岁儿童青少年超重率和肥胖率分别是11.1%和7.9%&#xff0c;也就是说&#xff0c;几乎每5个中小学生中就有一个小胖墩儿。 有…

如何在算家云搭建Open-Sora1.1(视频生成)

一、Open-Sora1.1简介 Open-Sora 1.1 项目是 Colossal AI 团队开发的一个完全开源的视频生成项目&#xff0c;该项目致力于高效制作高质量视频&#xff0c;并通过开源原则实现先进视频生成技术的低成本普及。 1. 项目背景与目标 Open-Sora 项目旨在通过提供开源的模型、工具…

【Python】数据可视化之核密度

KDEPlot&#xff08;Kernel Density Estimate Plot&#xff0c;核密度估计图&#xff09;是seaborn库中一个用于数据可视化的函数&#xff0c;它基于核密度估计&#xff08;KDE&#xff09;这一非参数统计方法来估计数据的概率密度函数。KDEPlot能够直观地展示数据的分布特征&a…

定点荧光标记蛋白:轻松搞定CAR-T阳性率检测

CAR-T细胞疗法在8月份提前进入“丰收季”。8月27日NMPA官网公示&#xff0c;**国内第五款CAR-T细胞疗法——来自传奇生物的西达基奥仑赛注射液获批上市。**这款靶向BCMA的细胞疗法用于治疗复发或难治性多发性骨髓瘤&#xff08;R/R MM&#xff09;成人患者。同一天&#xff0c;…

NDP协议是怎样帮助IPv6实现网络安全运行的?

在复杂多变的网络环境中&#xff0c;确保各节点之间能够高效、准确地发现与通信&#xff0c;是构建稳定、可扩展网络架构的基石。那么IPv6是依靠什么实现网络安全运行的呢&#xff1f;今天我将就IPv6中的一个重要协议——NDP协议的基本概念及工作原理展开深入分析。 NDP协议的基…

体育馆管理系统|基于SpingBoot+vue的体育馆管理系统(源码+数据库+文档)

体育馆管理系统 目录 基于SpingBootvue的体育馆管理系统 一、前言 二、系统设计 三、系统功能设计 系统功能实现 1登录 2学生管理页面 3系统主界面模块的实现 4器材管理模块的实现 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源…

ICM20948 DMP代码详解(11)

接前一篇文章&#xff1a;ICM20948 DMP代码详解&#xff08;10&#xff09; 上一回讲解完了icm20948_sensor_setup函数的第1段代码&#xff0c;本回继续往下解析。为了便于理解和回顾&#xff0c;再次贴出icm20948_sensor_setup函数源码&#xff0c;在EMD-App\src\ICM20948\sen…