当前位置: 首页 > news >正文

VTK显示像素图

VTK用来显示一些内定的数据结构,立体图像和图片很容易,但是很多人都找不到怎么显示出一张像素图。有人问我相关的技术,我整理了整理,弄成了一篇博客。

先把所需的头文件包含一下:

#include<vtkAutoInit.h>
VTK_MODULE_INIT(vtkRenderingOpenGL2)
VTK_MODULE_INIT(vtkInteractionStyle);
VTK_MODULE_INIT(vtkRenderingFreeType);
VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2);
#include <vtkImageImport.h>
#include <vtkSmartPointer.h>
#include <vtkRenderer.h>
#include <vtkImageActor.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkInteractorStyleTrackballCamera.h>
#include <iostream>
using std::cout;
using std::endl;
#include <vtkInteractorStyleImage.h>

其中,

VTK_MODULE_INIT(vtkRenderingOpenGL2)
VTK_MODULE_INIT(vtkInteractionStyle);
VTK_MODULE_INIT(vtkRenderingFreeType);
VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2);

是为了避免相关的一些错误。暂时我也忘了这些错误哪里来的了,反正别的博客上说加了就好了。

int main(int argc, char *argv[])
{

	return EXIT_SUCCESS;
}

在main函数里,我们要开始添加内容:首先创建一堆对象,第一个用来存储图像数据,然后是场景渲染器,以及之前介绍过的渲染引擎的Actor,然后是渲染窗口和交互器,这里使用一个简单的交互style。(目前我开的系列博客中还会介绍自定义的交互器样式)

	vtkSmartPointer<vtkImageImport>imageImport = 
		vtkSmartPointer<vtkImageImport>::New();
	vtkSmartPointer<vtkRenderer>sceneRenderer = 
		vtkSmartPointer<vtkRenderer>::New();
	vtkSmartPointer<vtkImageActor>imageActor = 
		vtkSmartPointer<vtkImageActor>::New();
	vtkSmartPointer<vtkRenderWindow>renderWindow = 
		vtkSmartPointer<vtkRenderWindow>::New();
	vtkSmartPointer<vtkRenderWindowInteractor> interactor = 
		vtkSmartPointer<vtkRenderWindowInteractor>::New();
	vtkSmartPointer<vtkInteractorStyleImage> style =
		vtkSmartPointer<vtkInteractorStyleImage>::New();

接下来我们进行一些窗口的初始化工作。

	renderWindow->SetSize(600,600);
	sceneRenderer->SetBackground(0.8, 0.0, 0.0);
	renderWindow->AddRenderer(sceneRenderer);	
	sceneRenderer->AddActor(imageActor);
	//renderWindow->SetMultiSamples(0);
	interactor->SetRenderWindow(renderWindow);
	interactor->SetInteractorStyle(style);
	int width = 512;
	int height = 512;

我们定义一个存放数据的数组:

	const int Size = width* height * 3 * sizeof(unsigned char);
	unsigned char* m_pPixels = (unsigned char*)malloc(Size);

	for (int i = 0;i<width;i++){
		for (int j = 0;j < height;j+=1) {
			m_pPixels[(i*width + j) * 3] = 0;
			m_pPixels[(i*width + j) * 3 + 1] = 255;
			m_pPixels[(i*width + j) * 3 + 2] = 0;
		}
	}
	for (int i = 0;i<20;i++) {
		for (int j = 0;j < 20;j += 1) {
			m_pPixels[(i*width + j) * 3] = 0;
			m_pPixels[(i*width + j) * 3 + 1] = 0;
			m_pPixels[(i*width + j) * 3 + 2] = 255;
		}
	}
	for (int i = 40;i<60;i++) {
		for (int j = 0;j < 20;j += 1) {
			m_pPixels[(i*width + j) * 3] = 0;
			m_pPixels[(i*width + j) * 3 + 1] = 0;
			m_pPixels[(i*width + j) * 3 + 2] = 255;
		}
	}

在这个数组是3倍的长乘宽,也就是说每个像素对应了RGB三个颜色。然后我们将整片空间设置为绿色,再将里面两块区域设置为蓝色。

	imageImport->SetImportVoidPointer(m_pPixels);
	//imageImport->SetDataOrigin(-0.5f * (float)width, -0.5f * (float)height, 0);
	imageImport->SetWholeExtent(0, width - 1, 0, height - 1, 0, 0);
	imageImport->UpdateWholeExtent();
	imageImport->SetDataExtentToWholeExtent();
	imageImport->SetDataScalarTypeToUnsignedChar();
	imageImport->SetNumberOfScalarComponents(3);
	imageImport->Update();

	imageActor->SetInputData(imageImport->GetOutput());
	renderWindow->Render();
	interactor->Start();

然后再在里面设置显示的内容区域,数据的范围。之后送到actor里面,开始渲染。效果如下:

注意,绿色区域会随着显示框的改变而等长宽比放缩。

现在把全部代码附上:

#include<vtkAutoInit.h>
VTK_MODULE_INIT(vtkRenderingOpenGL2)
VTK_MODULE_INIT(vtkInteractionStyle);
VTK_MODULE_INIT(vtkRenderingFreeType);
VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2);
#include <vtkImageImport.h>
#include <vtkSmartPointer.h>
#include <vtkRenderer.h>
#include <vtkImageActor.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkInteractorStyleTrackballCamera.h>
#include <iostream>
using std::cout;
using std::endl;
#include <vtkInteractorStyleImage.h>

int main(int argc, char *argv[])
{

	vtkSmartPointer<vtkImageImport>imageImport = 
		vtkSmartPointer<vtkImageImport>::New();
	vtkSmartPointer<vtkRenderer>sceneRenderer = 
		vtkSmartPointer<vtkRenderer>::New();
	vtkSmartPointer<vtkImageActor>imageActor = 
		vtkSmartPointer<vtkImageActor>::New();
	vtkSmartPointer<vtkRenderWindow>renderWindow = 
		vtkSmartPointer<vtkRenderWindow>::New();
	vtkSmartPointer<vtkRenderWindowInteractor> interactor = 
		vtkSmartPointer<vtkRenderWindowInteractor>::New();
	vtkSmartPointer<vtkInteractorStyleImage> style =
		vtkSmartPointer<vtkInteractorStyleImage>::New();

	renderWindow->SetSize(600,600);
	sceneRenderer->SetBackground(0.8, 0.0, 0.0);
	renderWindow->AddRenderer(sceneRenderer);	
	sceneRenderer->AddActor(imageActor);
	//renderWindow->SetMultiSamples(0);
	interactor->SetRenderWindow(renderWindow);
	interactor->SetInteractorStyle(style);

	int width = 512;//(renderWindow->GetSize())[0];
	int height = 512;//(renderWindow->GetSize())[1];
	//cout << width << "  " << height<<endl;
	
	const int Size = width* height * 3 * sizeof(unsigned char);
	unsigned char* m_pPixels = (unsigned char*)malloc(Size);

	for (int i = 0;i<width;i++){
		for (int j = 0;j < height;j+=1) {
			m_pPixels[(i*width + j) * 3] = 0;
			m_pPixels[(i*width + j) * 3 + 1] = 255;
			m_pPixels[(i*width + j) * 3 + 2] = 0;
		}
	}
	for (int i = 0;i<20;i++) {
		for (int j = 0;j < 20;j += 1) {
			m_pPixels[(i*width + j) * 3] = 0;
			m_pPixels[(i*width + j) * 3 + 1] = 0;
			m_pPixels[(i*width + j) * 3 + 2] = 255;
		}
	}
	for (int i = 40;i<60;i++) {
		for (int j = 0;j < 20;j += 1) {
			m_pPixels[(i*width + j) * 3] = 0;
			m_pPixels[(i*width + j) * 3 + 1] = 0;
			m_pPixels[(i*width + j) * 3 + 2] = 255;
		}
	}
	imageImport->SetImportVoidPointer(m_pPixels);
	//imageImport->SetDataOrigin(-0.5f * (float)width, -0.5f * (float)height, 0);
	imageImport->SetWholeExtent(0, width - 1, 0, height - 1, 0, 0);
	imageImport->UpdateWholeExtent();
	imageImport->SetDataExtentToWholeExtent();
	imageImport->SetDataScalarTypeToUnsignedChar();
	imageImport->SetNumberOfScalarComponents(3);
	imageImport->Update();
	


	imageActor->SetInputData(imageImport->GetOutput());
	renderWindow->Render();
	interactor->Start();


	return EXIT_SUCCESS;

}

 

 

相关文章:

  • VTK交互系统 2 交互器样式
  • VTK交互系统 3 自定义交互器样式
  • VTK交互系统 4 自定义交互器样式2 键盘鼠标交互器设置
  • Qt多线程1
  • Qt多线程2
  • 基于QT的文件管理软件编写 系列 引言
  • 基于QT的文件管理软件编写 系列 1
  • python安装tensorflow
  • 机器学习之 Keras默认数据集/模型存放位置
  • 从零开始写出分而治之查找最大子列表的算法
  • 学机器学习必备的一些python句法基础 1 列表 元组 字典 条件语句
  • 学机器学习必备的一些python句法基础 2 循环
  • 学机器学习必备的一些python句法基础 3 函数 内建函数 模块 包 全局局部变量
  • 学机器学习必备的一些python句法基础 4 Python类和对象
  • 学机器学习必备的一些python句法基础 5 文件读写
  • CSS相对定位
  • magento2项目上线注意事项
  • Making An Indicator With Pure CSS
  • Python 反序列化安全问题(二)
  • vue2.0项目引入element-ui
  • 安卓应用性能调试和优化经验分享
  • 第2章 网络文档
  • 给Prometheus造假数据的方法
  • 使用Swoole加速Laravel(正式环境中)
  • 算法之不定期更新(一)(2018-04-12)
  • 栈实现走出迷宫(C++)
  • 这几个编码小技巧将令你 PHP 代码更加简洁
  • 阿里云重庆大学大数据训练营落地分享
  • 第二十章:异步和文件I/O.(二十三)
  • 专访Pony.ai 楼天城:自动驾驶已经走过了“从0到1”,“规模”是行业的分水岭| 自动驾驶这十年 ...
  • ###项目技术发展史
  • #[Composer学习笔记]Part1:安装composer并通过composer创建一个项目
  • #HarmonyOS:Web组件的使用
  • #NOIP 2014#Day.2 T3 解方程
  • #WEB前端(HTML属性)
  • #使用清华镜像源 安装/更新 指定版本tensorflow
  • #我与Java虚拟机的故事#连载06:收获颇多的经典之作
  • #中的引用型是什么意识_Java中四种引用有什么区别以及应用场景
  • $jQuery 重写Alert样式方法
  • (3)(3.2) MAVLink2数据包签名(安全)
  • (day 12)JavaScript学习笔记(数组3)
  • (JSP)EL——优化登录界面,获取对象,获取数据
  • (十三)Maven插件解析运行机制
  • (学习日记)2024.04.10:UCOSIII第三十八节:事件实验
  • (转) 深度模型优化性能 调参
  • (转)创业家杂志:UCWEB天使第一步
  • *p++,*(p++),*++p,(*p)++区别?
  • .\OBJ\test1.axf: Error: L6230W: Ignoring --entry command. Cannot find argumen 'Reset_Handler'
  • .bat批处理(一):@echo off
  • .NET C#版本和.NET版本以及VS版本的对应关系
  • .NET Core工程编译事件$(TargetDir)变量为空引发的思考
  • .net 反编译_.net反编译的相关问题
  • .Net的C#语言取月份数值对应的MonthName值
  • .NET连接数据库方式
  • .考试倒计时43天!来提分啦!