博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
VTK初学一,b_PolyVertex多个图形点的绘制
阅读量:5011 次
发布时间:2019-06-12

本文共 3300 字,大约阅读时间需要 11 分钟。

#ifndef INITIAL_OPENGL
#define INITIAL_OPENGL
#include 
VTK_MODULE_INIT(vtkRenderingOpenGL)
VTK_MODULE_INIT(vtkInteractionStyle)
#endif
 
#include 
using namespace std;
#include "vtkPolyDataMapper.h"
#include "vtkWin32OpenGLRenderWindow.h"
#include "vtkRenderWindow.h"
#include "vtkRenderWindowInteractor.h"
#include "vtkRenderer.h"
#include "vtkPoints.h"
#include "vtkWin32RenderWindowInteractor.h"
#include "vtkProperty.h"
#include "vtkFloatArray.h"
#include "vtkPolyData.h"
#include "vtkDataSetMapper.h"
#include "vtkActor2D.h"
#include "vtkContourFilter.h"
#include "vtkContourValues.h"
#include "vtkUnstructuredGrid.h"
#include "vtkPointData.h"
#include "vtkVertex.h"
#include "vtkPolyVertex.h"
#include "vtkInteractorStyleTrackballCamera.h"
 
void myShow(vtkSmartPointer
aGrid);
 
int main()
{
//几何数据
vtkSmartPointer
points=vtkSmartPointer
::New();
//    points->SetNumberOfPoints(5);//此行可有可无
points->InsertPoint(0,0,0,0);
points->InsertPoint(1,0.5,0.5,0);
points->InsertPoint(2,-0.3,-0.2,0);
points->InsertPoint(3,0.8,-0.5,0);
points->InsertPoint(4,1,0.5,0.3);
//拓扑数据
vtkSmartPointer
polyVertex=vtkSmartPointer
::New();
polyVertex->GetPointIds()->SetNumberOfIds(5);//必须设置Id个数,否则可以编译,不能运行
polyVertex->GetPointIds()->SetId(0,0);//第一个参数是几何point的ID号,第2个参数是拓扑中的Id号
polyVertex->GetPointIds()->SetId(1,1);
polyVertex->GetPointIds()->SetId(2,2);
polyVertex->GetPointIds()->SetId(3,3);
polyVertex->GetPointIds()->SetId(4,4);
//属性数据
vtkSmartPointer
pointsScalars=vtkSmartPointer
::New();
pointsScalars->SetNumberOfTuples(5);//此行可有可无
pointsScalars->InsertValue(0,0);//第1个参数是points点的Id,第2个参数是该点的属性值
pointsScalars->InsertValue(1,0);//第1个参数是points点的Id,第2个参数是该点的属性值
pointsScalars->InsertValue(2,0);//第1个参数是points点的Id,第2个参数是该点的属性值
pointsScalars->InsertValue(3,0);//第1个参数是points点的Id,第2个参数是该点的属性值
pointsScalars->InsertValue(4,0);//第1个参数是points点的Id,第2个参数是该点的属性值
//将以上三部分数据组合成一个结构vtkUnstructureGrid
vtkSmartPointer
aGrid=vtkSmartPointer
::New();
aGrid->Allocate(1,1);
aGrid->SetPoints(points);
aGrid->GetPointData()->SetScalars(pointsScalars);
aGrid->InsertNextCell(polyVertex->GetCellType(),polyVertex->GetPointIds());
//在窗口中显示多个Vertex
myShow(aGrid);
return 0;
}
 
void myShow(vtkSmartPointer
aGrid)
{
//设置映射器
vtkSmartPointer
aMapper=vtkSmartPointer
::New();
aMapper->SetInputData(aGrid);
aMapper->ScalarVisibilityOn();
 
vtkSmartPointer
anActor=vtkSmartPointer
::New();
anActor->SetMapper(aMapper);
anActor->GetProperty()->SetRepresentationToPoints();
 
anActor->GetProperty()->SetDiffuseColor(1,0,0);
anActor->GetProperty()->SetPointSize(10);
//创建显示窗口
vtkSmartPointer
ren1=vtkSmartPointer
::New();
vtkSmartPointer
renWin=vtkSmartPointer
::New();
ren1->AddActor(anActor);
renWin->AddRenderer(ren1);
 
vtkSmartPointer
iren=vtkSmartPointer
::New();
vtkSmartPointer
style=vtkSmartPointer
::New();
iren->SetInteractorStyle(style);
iren->SetRenderWindow(renWin);
 
renWin->SetSize(700,700);
ren1->ResetCamera();
renWin->Render();
iren->Start();
}

 

 

转载于:https://www.cnblogs.com/phoenixdsg/p/6116428.html

你可能感兴趣的文章
【题目】英文字符进行频率的统计,直方图输出
查看>>
LeetCode-Binary Tree Level Order Traversal
查看>>
COM组件开发实践
查看>>
yii2 源码分析1从入口开始
查看>>
浅谈网站推广
查看>>
Away3D基础之摄像机
查看>>
Leetcode 128. Longest Consecutive Sequence
查看>>
程序员必须知道的几个Git代码托管平台
查看>>
导电塑料入梦来
查看>>
C# 线程手册 第五章 扩展多线程应用程序 - 什么是线程池
查看>>
笔记1126ASP.NET面试题(转)
查看>>
考研路茫茫--单词情结 - HDU 2243(AC自动机+矩阵乘法)
查看>>
HTTP运行期与页面执行模型
查看>>
tableView优化方案
查看>>
近期思考(2019.07.20)
查看>>
Apache2.4使用require指令进行访问控制
查看>>
冗余关系_并查集
查看>>
做最好的自己(Be Your Personal Best)
查看>>
如何搭建github+hexo博客-转
查看>>
HW2.2
查看>>