VTK对点进行采样

22 篇文章 18 订阅

在VTK中对三维点进行采样,并保存采样后的结果,在同一个窗口显示采样前与采样后的点,采样前的点以红色显示,采样后的点以绿色显示

如果是二维点,则读取二维点坐标就是了

 

#include <iostream>
#include <vtkRenderer.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkPoints.h>
#include <vtkPolyData.h>
#include <vtkSmartPointer.h>
#include <vtkPolyDataMapper.h>
#include <vtkCleanPolyData.h>
#include <vtkPolyDataWriter.h>
#include <vtkActor.h>
#include <vtkProperty.h>
#include <vtkCellArray.h>
#include <vtkInteractorStyleTrackball.h>
void main()
{
	vtkSmartPointer<vtkPoints>m_points=vtkSmartPointer<vtkPoints>::New();
	vtkSmartPointer<vtkCellArray>m_vertices=vtkSmartPointer<vtkCellArray>::New();
	vtkSmartPointer<vtkRenderer>ren1=vtkSmartPointer<vtkRenderer>::New();
	vtkSmartPointer<vtkRenderWindow>renWin=vtkSmartPointer<vtkRenderWindow>::New();
	vtkSmartPointer<vtkRenderWindowInteractor>iren=vtkSmartPointer<vtkRenderWindowInteractor>::New();
	FILE *fp=NULL;
	fp=fopen("右心室浮点型.txt","r");
	if (!fp)
	{
		cout<<"打开文件失败"<<endl;
	}
	double x=0,y=0,z=0;
	int i=0;
	while(!feof(fp))
	{
		fscanf(fp,"%lf	%lf	%lf",&x,&y,&z);
		m_points->InsertPoint(i,x,y,z);
		m_vertices->InsertNextCell(1);
		m_vertices->InsertCellPoint(i);
		i++;
	}
	fclose(fp);
	vtkSmartPointer<vtkPolyData>m_polydata=vtkSmartPointer<vtkPolyData>::New();
	m_polydata->SetPoints(m_points);
	m_polydata->SetVerts(m_vertices);

	vtkSmartPointer<vtkCleanPolyData>m_cleanpoint=vtkSmartPointer<vtkCleanPolyData>::New();
	m_cleanpoint->SetInput(m_polydata);
	m_cleanpoint->SetTolerance(0.05);        //设置采样度
	m_cleanpoint->Update();

	vtkSmartPointer<vtkPolyDataWriter>pointcaiyang=vtkSmartPointer<vtkPolyDataWriter>::New();
	pointcaiyang->SetFileName("采样后的点.vtp");    //保存采样后的结果
	pointcaiyang->SetInput(m_cleanpoint->GetOutput());
	pointcaiyang->Write();

	vtkSmartPointer<vtkPolyDataMapper>caiyangqian=vtkSmartPointer<vtkPolyDataMapper>::New();
	caiyangqian->SetInputConnection(m_polydata->GetProducerPort());

	vtkSmartPointer<vtkPolyDataMapper>caiyanghou=vtkSmartPointer<vtkPolyDataMapper>::New();
	caiyanghou->SetInputConnection(m_cleanpoint->GetOutputPort());

	vtkSmartPointer<vtkActor>actor_qian=vtkSmartPointer<vtkActor>::New();
	actor_qian->SetMapper(caiyangqian);
	actor_qian->GetProperty()->SetColor(1,0,0);
//	actor_qian->GetProperty()->SetPointSize(2);

	vtkSmartPointer<vtkActor>actor_hou=vtkSmartPointer<vtkActor>::New();
	actor_hou->SetMapper(caiyanghou);
	actor_hou->GetProperty()->SetColor(0,1,0);
	actor_hou->GetProperty()->SetPointSize(4);

	ren1->AddActor(actor_qian);
	ren1->AddActor(actor_hou);

	ren1->SetBackground(1,1,1);
	renWin->AddRenderer(ren1);
	renWin->SetSize(600,600);
	iren->SetRenderWindow(renWin);
	renWin->Render();
	renWin->Start();
	getchar();
}


 

如果您觉得这篇博文有用,请访问我的个人站:http://www.stubbornhuang.com,更多博文干货等着您。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HW140701

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值