当前位置:网站首页>vtk体绘制代码报错的解决办法(代码在vtk7,8,9中都能运行),以及VTK数据集网站
vtk体绘制代码报错的解决办法(代码在vtk7,8,9中都能运行),以及VTK数据集网站
2022-08-01 18:56:00 【宗浩多捞】
链接:vtk7.1.1官方文档
链接:官方示例代码
链接:VTK资源网站(需要什么资源搜索就行,官网示例中的数据集、资源基本都有)
体绘制代码运行不了,一直报错的解决方案
- 大家应该都看过VTK图形图像进阶那本书了,那本书的VTK版本为5.10.1,随书代码中体绘制部分在VTK7 8 9版本中是不能运行的,需要稍微改一些东西(没有《VTK图形图像进阶》这本书和随书代码的可以找我私聊,我可以发百度网盘)
- 还需要注意添加:
VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2);否则会报错
#include<vtkAutoInit.h>
VTK_MODULE_INIT(vtkRenderingOpenGL2)
VTK_MODULE_INIT(vtkInteractionStyle);
VTK_MODULE_INIT(vtkRenderingFreeType);
VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2);
#include <vtkSmartPointer.h>
#include <vtkImageData.h>
#include <vtkStructuredPoints.h>
#include <vtkStructuredPointsReader.h>
#include <vtkVolumeRayCastCompositeFunction.h>
#include <vtkGPUVolumeRayCastMapper.h>
#include <vtkVolumeRayCastMapper.h>
#include <vtkColorTransferFunction.h>
#include <vtkPiecewiseFunction.h>
#include <vtkRenderer.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkVolumeProperty.h>
#include <vtkAxesActor.h>
#include <vtkImageShiftScale.h>
#include <vtkImageCast.h>
#include <vtkFixedPointVolumeRayCastMapper.h>
// ../data/mummy.128.vtk
int main(int argc, char *argv[])
{
vtkSmartPointer<vtkStructuredPointsReader> reader =
vtkSmartPointer<vtkStructuredPointsReader>::New();
reader->SetFileName(../data/mummy.128.vtk);
reader->Update();
//vtkSmartPointer<vtkVolumeRayCastCompositeFunction> rayCastFun = vtkSmartPointer<vtkVolumeRayCastCompositeFunction>::New(); // 舍弃了
vtkSmartPointer<vtkFixedPointVolumeRayCastMapper> volumeMapper = vtkSmartPointer<vtkFixedPointVolumeRayCastMapper>::New();
volumeMapper->SetInputDataObject(reader->GetOutput());
//volumeMapper->SetVolumeRayCastFunction(rayCastFun); // 舍弃了
vtkSmartPointer<vtkVolumeProperty> volumeProperty = vtkSmartPointer<vtkVolumeProperty>::New();
volumeProperty->SetInterpolationTypeToLinear();
volumeProperty->ShadeOn(); //打开或者关闭光照着色
volumeProperty->SetAmbient(0.4);
volumeProperty->SetDiffuse(0.6);
volumeProperty->SetSpecular(0.2);
vtkSmartPointer<vtkPiecewiseFunction> compositeOpacity = vtkSmartPointer<vtkPiecewiseFunction>::New();
compositeOpacity->AddPoint(70, 0.00);
compositeOpacity->AddPoint(90, 0.40);
compositeOpacity->AddPoint(180, 0.60);
volumeProperty->SetScalarOpacity(compositeOpacity); //设置不透明度传输函数
vtkSmartPointer<vtkPiecewiseFunction> volumeGradientOpacity = vtkSmartPointer<vtkPiecewiseFunction>::New();
volumeGradientOpacity->AddPoint(10, 0.0);
volumeGradientOpacity->AddPoint(90, 0.5);
volumeGradientOpacity->AddPoint(100, 1.0);
//volumeProperty->SetGradientOpacity(volumeGradientOpacity);//设置梯度不透明度效果对比
vtkSmartPointer<vtkColorTransferFunction> color = vtkSmartPointer<vtkColorTransferFunction>::New();
color->AddRGBPoint(0.000, 0.00, 0.00, 0.00);
color->AddRGBPoint(64.00, 1.00, 0.52, 0.30);
color->AddRGBPoint(190.0, 1.00, 1.00, 1.00);
color->AddRGBPoint(220.0, 0.20, 0.20, 0.20);
volumeProperty->SetColor(color);
vtkSmartPointer<vtkVolume> volume = vtkSmartPointer<vtkVolume>::New();
volume->SetMapper(volumeMapper);
volume->SetProperty(volumeProperty);
vtkSmartPointer<vtkRenderer> ren = vtkSmartPointer<vtkRenderer>::New();
ren->SetBackground(1, 1, 0);
ren->AddVolume( volume );
vtkSmartPointer<vtkRenderWindow> renWin = vtkSmartPointer<vtkRenderWindow>::New();
renWin->AddRenderer(ren);
renWin->SetSize(640, 480);
renWin->Render();
renWin->SetWindowName("VolumeRenderingApp");
vtkSmartPointer<vtkRenderWindowInteractor> iren = vtkSmartPointer<vtkRenderWindowInteractor>::New();
iren->SetRenderWindow(renWin);
ren->ResetCamera();
renWin->Render();
iren->Start();
std::cin.get();
return EXIT_SUCCESS;
}
边栏推荐
- COS 用户实践征文
- Keras deep learning practice - traffic sign recognition
- Screen: GFF, OGS, Oncell, Incell of full lamination process
- 2022年 PHP面试问题记录
- LeetCode 0151. Reverse a string of words
- 暑假第一周总结博客
- Zabbix6.0 DingTalk robot alarm
- Tower Defense Shoreline User Agreement
- Golang协程调度器scheduler怎么使用
- 【LeetCode】Day109-最长回文串
猜你喜欢

明尼苏达大学团队结合高通量实验与机器学习,实现有效可预测的特定位点重组过程,可调节基因编辑速度

Library website construction source code sharing

Multi-Party Threshold Private Set Intersection with Sublinear Communication-2021:解读

C#/VB.NET:从 PDF 文档中提取所有表格

亚马逊云科技Build On2022技能提升计划第二季——揭秘出海爆款新物种背后的黑科技

30分钟成为Contributor|如何多方位参与OpenHarmony开源贡献?

Summer vacation second week wrap-up blog

Leetcode75. 颜色分类

Prometheus的Recording rules实践

Leetcode71. 简化路径
随机推荐
A simple Flask PIN
用VS2013编译带boost库程序时提示 fatal error C1001: 编译器中发生内部错误
【神经网络】一文带你轻松解析神经网络(附实例恶搞女友)
123123123123
【LeetCode】Day109-the longest palindrome string
Three solutions: npm WARN config global --global, --local are deprecated. Use --location=global instead.
Multi-Party Threshold Private Set Intersection with Sublinear Communication-2021: Interpretation
C#/VB.NET: extracted from the PDF document all form
Hardware Bear Original Collection (Updated 2022/07)
Break the performance ceiling!AsiaInfo database supports more than 1 billion users, with a peak of one million transactions per second
Industry Salon Phase II丨How to enable chemical companies to reduce costs and increase efficiency through supply chain digital business collaboration?
modbus总线模块DAM-8082
请你说说多线程
通配符 SSL/TLS 证书
ExcelPatternTool: Excel form-database mutual import tool
odoo 编码规范(编程规范、编码指南)
MLX90640 红外热成像仪测温模块开发笔记(完整篇)
选择合适的 DevOps 工具,从理解 DevOps 开始
7月30号|来一场手把手助您打造智能视觉新爆款的技术动手实验
The XML configuration