技术标签: VTK
在VTK中连通区域分析常用到的类是:vtkPolyDataConnectivityFilter。从名字可以看出来其输入类型为vtkPolyData;了解VTK的人都知道这是图形的基本数据结构保存了图形的几何结构和拓扑结构。如果你要进行连通分析的对象是图形那自然就没问题。但如果需要对图像进行连通区域分析,那该类就不能直接用了,要先进行一步数据类型转换。根据参考文1,我们可以以一种非严谨方式将VTK数据处理算子(Filter)分为一下几类:
1、图像处理 其输入为vtkImageData(图像基本数据类型),输出也为vtkImageData
2、几何提取 其输入为vtkImageData,输出为vtkPolyData
3、图形处理 其输入为vtkPolyData,输出也为vtkPolyData,例如前面的vtkPolyDataConnectivityFilter
4、渲染 如Mapper和Actor 来完成图形图像的显示
为了实现vtkImageData==>vtkPolyData 我们需要使用一种几何提取处理器,参考文献一提到了一种vtkContourFilter(轮廓提取)来完成。vtkContourFilter使用较为简单,只需要设置一个参数等值线,其可以通过函数SetValue或GenerateVale()来完成设置,其具体的不同见参考文献2.
完成数据类型转换我们就可以使用vtkPolyDataConnectivityFilter来提取连通区域。该类在提取连通区域时候有如下6中模式:
1)提取数据集中的最大(最多点)连接区域:SetExtractionModeToLargestRegion();
2)提取指定区域号:SetExtractionModeToSpecifiedRegions();
3)提取共享指定点ids的所有区域:SetExtractionModeToPointSeededRegions();
4)提取共享指定单元ID的所有区域:SetExtractionModeToCellSeededRegions();
5)提取最靠近指定点的区域:SetExtractionModeToClosestPointRegion();
6)提取所有区域(用于着色区域):SetExtractionModeToAllRegions()
区域标记号被以点的标量属性数据来保存。为了标记所有区域还必须配合函数ColorRegionOn()
下面演示代码: 模式为SetExtractionModeToAllRegions() 获取连通区域后 遍历所有点来查看其所属于的连通区域号
//[1] --read image
QString str="F:/lunkuo5.jpg";
QByteArray ba=str.toLocal8Bit();
const char *fileName=ba.data();
vtkSmartPointer<vtkJPEGReader> reader
=vtkSmartPointer<vtkJPEGReader>::New();
reader->SetFileName(fileName);
reader->Update();
//[1]
//[2] --灰度化
vtkSmartPointer<vtkImageLuminance> luninanceFilter=
vtkSmartPointer<vtkImageLuminance>::New();
luninanceFilter->SetInputConnection(reader->GetOutputPort());
luninanceFilter->Update();
//[2]
//[3] --图像二值化
vtkSmartPointer<vtkImageThreshold> thresholdFilter=
vtkSmartPointer<vtkImageThreshold>::New();
thresholdFilter->SetInputConnection(luninanceFilter->GetOutputPort());
thresholdFilter->ThresholdByUpper(100);//大于该灰度范围的区间为有效范围
thresholdFilter->SetInValue(255);//有效范围内的输出值
thresholdFilter->SetOutValue(0);//无效范围的输出值
thresholdFilter->UpdateDataObject();
thresholdFilter->UpdateInformation();
thresholdFilter->Update();
//[3]
//[4] --exactor contour
vtkSmartPointer<vtkContourFilter> contourFilter=
vtkSmartPointer<vtkContourFilter>::New();
contourFilter->SetInputConnection(thresholdFilter->GetOutputPort());
contourFilter->ComputeNormalsOn();
contourFilter->SetValue(0,100);
contourFilter->Update();
//[4]
//[4] --连通区域分析
vtkSmartPointer<vtkPolyDataConnectivityFilter> connectFilter1=
vtkSmartPointer<vtkPolyDataConnectivityFilter>::New();
connectFilter1->SetInputConnection(contourFilter->GetOutputPort());
connectFilter1->SetExtractionModeToAllRegions();
connectFilter1->ColorRegionsOn();
connectFilter1->MarkVisitedPointIdsOn();
connectFilter1->Update();
int regionNum=connectFilter1->GetNumberOfExtractedRegions();
qDebug()<<"regionNum:"<<regionNum;
//[4]
for(int i=0;i<connectFilter1->GetOutput()->GetNumberOfPoints();++i)
{
int regionId=connectFilter1->GetOutput()->GetPointData()->GetScalars()->GetTuple1(i);
double *xyz=connectFilter1->GetOutput()->GetPoint(i);
}
//声明:用于打开指定的进程对象。{返回进程的句柄}OpenProcess( dwDesiredAccess: DWORD; {访问选项} bInheritHandle: BOOL; {能否继承; True 表示能用 CreateProcess 继承句柄创建新进程} dwProcessId: DWORD {指定进程 ID}): THandle
本地仓库用于存放项目中常用的jar包,默认会存放在系统盘,对于计算机来说系统盘是十分宝贵的,因此我们可以自定义本地仓库的存放位置,一来可以方便查找管理,而来节约系统盘空间。1.在本地计算机中打开“settings.xml”文件找到localRepository一栏字样。2.在localRepository结束的位置添加一行内容用于指定本地仓库的位置。...
芯海科技2022数字芯片时间2021.8.25一、单选题(共20题,每题3分,共60分)1. D触发器:Tsetup=3ns,Thold=1ns,Tck2q=1ns,该D触发器最大可运行时钟频率是( )A、1GHZB、500MHZC、250MHZD、200MHZ2.下列电路属于时序电路的是( )A、编码器B、译码器C、数据选择器D、计数器3.以下不能提高验证环境的可重用性的是A、使用宏定义B、使用绝对路径索引文件C、使用fa..
《UnityAPI.Joint关节》 版本 作者 参与者 完成日期 备注 UnityAPI_Joint_V01_1.0 严立钻 2020.06.15 ...
已经配置了环境变量了,为什么还是找不到ls指令?10B331 | 浏览 19827 次 2013-08-13 14:452015-05-01 10:09ls命令基本每个linux shell都会存在,因为这是基本的应用命令。就好比,手机接打电话、短信内容一样,这是最基本的,所以不可能是没有这个命令。1、你可以先用whereis或者
使用ps做网页(作者:翟正兴,撰写时间:2019年4月4日)首先打开ps创建一个新图层,创建好了之后在里面用矩形工具画一条出来给它换上颜色#ffdaad弄好了之后就用横排文字工具在上面打上这些字首页,产品专区,热卖专区,网络商店,联系我们,字体为微软雅黑,字体大小为15px做好之后就去网上搜几张面包图片,弄好了之后摆一张上去像这样然后在这图片下面用矩形工具画五条小矩形出来最右边四条...
一、开发环境说明操作系统:windows开发软件:Visual Studio 2017编程语言:基于控制台下的opengl用到的库: glutopengl环境配置可参照上一篇博客:控制台+OPENGL配置说明[GLUT篇]二、内容说明1 功能导入的obj飞机模型实现光照效果:实现飞机模型的光照实现天空盒:有6张图封闭成一个天空盒子实现地形:根据地形图片,提取高度,实...
css选择器文章目录css选择器选择器类型css选择器权重值权重计算方法案例选择器类型ID #idclass .class标签 p通用 *属性 [type=“text”]伪类 :hover伪元素 ::first-line子选择器、相邻选择器css选择器权重值选择器权重!important权重!...
需要POI的jar包支持调用方式:ReadExcelTest excelTest = new ReadExcelTest();excelTest.readExcel("D:\\data1.xlsx");package com.util;import java.io.File;import java.io.FileInputStream;import java.
unity3D第一人称射击游戏(下载链接在文末)游戏演示动态图如下:
原标题:如何判断M.2接口能否安装NVMe固态硬盘?M.2 NVMe固态硬盘安装没什么难的,一打开机箱我就找到了好多接口,随便选一个就连好了。 请勿模仿!请勿模仿!请勿模仿!图中是SATA电源插头,并非M.2插槽!!!这样连接不但不能让电脑识别到NVMe固态硬盘,其12V电压还可能会损坏3.3V供电的NVMe固态硬盘!关于M.2固态硬盘的安装,很多朋友一直有疑惑。特别是M.2插槽分为SATA与NV...