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

自己做资讯网站黄冈网站推广厂家

自己做资讯网站,黄冈网站推广厂家,上海广告公司联系方式,自建vps和买机场哪个好文章目录 概要vtkVolume概念C代码渲染效果参考 概要 绘制图像需要在空间中建立一个四边形图元,然后以纹理映射的方式将图像贴图到该图元上进行渲染;而三维模型的绘制通常会分解为一系列的多边形面片进行绘制。这种通过生成中间几何图元来进行渲染的方法称为几何渲染…

文章目录

  • 概要
  • vtkVolume概念
  • C++代码
  • 渲染效果
  • 参考

概要

绘制图像需要在空间中建立一个四边形图元,然后以纹理映射的方式将图像贴图到该图元上进行渲染;而三维模型的绘制通常会分解为一系列的多边形面片进行绘制。这种通过生成中间几何图元来进行渲染的方法称为几何渲染。几何染方式速度比较快,但是不能显示体数据的内部细节,例如,在渲染人的三维CT体数据时,通过几何渲染只能在切片图像之间进行切换,而不能对体数据内部细节进行立体观察。这时就需要用到体绘制技术了。

体绘制,有时又称作三维重建(区别于投影图像的三维重建),是一种直接利用体数据来生成二维图像的绘制技术。与面绘制不同,体绘制技术不需要提取体数据内部的等值面,它是一个对三维体数据进行采样和合成的过程。体绘制能够通过设置不透明度值来显示体数据内部的不同成分和细节,例如显示人体CT图像的不同器官和组织。体绘制也是 VTK 中的重要内容,这里将讲解利用 VTK 实现体绘制的方法。

将渲染窗口 vtkRenderWindow 看作一个剧院,剧院中一般需要有灯光(vtkLight)、相机(vtkCamera,可以理解为观众)和舞台(vtkRenderer)来为观众呈现精彩的演出;舞台上负责表演的自然是演员(vtkActor),而且演员通常不止一个,可以根据需要为舞台加入更多的演员(vtkActor)。每个演员各具特色,而用来表示其特色的则是vkProperty(负责控制颜色、材质以及不透明度等);每个vkActor 的数据和渲染信息存储在一个vtkMapper 对象中,负责将原始数据转换为渲染所需的图元数据。

光线投射法是最常用的体绘制方法。它是一种基于图像序列的直接体绘制方法,其基本原理是从投影图像平面(通常为平面)的每个像素沿着视线方向发射一条穿过体数据的射线然后在射线上按照一定的步长进行等距采样,对每个采样点采用插值技术来计算其体素值,根据颜色传输函数和不透明度传输函数来获取相应的颜色值和不透明度,最后利用光线吸收模型将颜色值进行累加直至光线穿过体数据,即可得到当前平面像素的渲染颜色,生成最终的显示图像。光线投射法的优点是能够比较精确地模拟原始体数据,但计算量比较大,实时体绘制对计算机硬件的要求比较高。

vtkVolume概念

vtkVolume类似于几何渲染中的vtkActor,用于表示渲染场景中的对象。除了存储基本的变换信息(平移、旋转、放缩等),其内部还存储了两个重要对象。这两个对象分别是vtkAbstactVolumeMapper对象和    vtkVolumeProperty对象。相应的函数如下。
1)void SetMapper(vtkAbstractVolumeMapper* mapper)。该函数用于连接vtkAbstractMapper对象,并根据不同的体绘制算法获取其内部生产的图元数据。
2)void SetProperty(vtkVolumeProperty* property)。该函数用于设置vtkVolumeProperty对象。其中vtkVolumeProperty用来设置体绘制的颜色和不透明函数以及阴影等信息。

在体绘制中,颜色以及不透明度的设置至关重要,决定了最终的显示效果。

具体介绍,参考https://www.cnblogs.com/ybqjymy/p/17502694.html

C++代码

#include <vtkAutoInit.h>
VTK_MODULE_INIT(vtkRenderingOpenGL2);
VTK_MODULE_INIT(vtkInteractionStyle);
VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2);
VTK_MODULE_INIT(vtkRenderingFreeType);#include <vtkSmartPointer.h>
#include <vtkGPUVolumeRayCastMapper.h>
#include <vtkVolumeProperty.h>
#include <vtkColorTransferFunction.h>
#include <vtkPiecewiseFunction.h>
#include <vtkRenderer.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkImageReslice.h>
#include <vtkDirectory.h>
#include <vtkDICOMReader.h>
#include <windows.h>
#include <psapi.h>
#include <vtkDICOMImageReader.h>int main(int argc, char* argv[]) {// 验证目录是否存在vtkSmartPointer<vtkDirectory> dir = vtkSmartPointer<vtkDirectory>::New();if (!dir->Open("E:/yp/vtk/3DMR-main/dicom3/")) {std::cerr << "错误:无法打开DICOM目录" << std::endl;return EXIT_FAILURE;}// 1. 读取DICOM序列vtkSmartPointer<vtkDICOMImageReader> reader = vtkSmartPointer<vtkDICOMImageReader>::New();reader->SetDirectoryName("E:/yp/vtk/3DMR-main/dicom/"); // 替换为实际路径reader->Update();// 2. 数据预处理(可选)vtkSmartPointer<vtkImageReslice> reslice = vtkSmartPointer<vtkImageReslice>::New();reslice->SetInputConnection(reader->GetOutputPort());reslice->SetOutputSpacing(1, 1, 1); // 调整间距reslice->Update();// 3. 创建体积映射器vtkSmartPointer<vtkGPUVolumeRayCastMapper> volumeMapper = vtkSmartPointer<vtkGPUVolumeRayCastMapper>::New();volumeMapper->SetInputData(reslice->GetOutput());volumeMapper->SetBlendModeToComposite(); // 使用合成模式// 4. 配置传输函数vtkSmartPointer<vtkColorTransferFunction> colorFun = vtkSmartPointer<vtkColorTransferFunction>::New();colorFun->AddRGBPoint(0, 0.0, 0.0, 0.0);colorFun->AddRGBPoint(500, 1.0, 0.5, 0.3); // 软组织colorFun->AddRGBPoint(1200, 0.9, 0.9, 0.9); // 骨骼vtkSmartPointer<vtkPiecewiseFunction> opacityFun = vtkSmartPointer<vtkPiecewiseFunction>::New();opacityFun->AddPoint(0, 0.00);opacityFun->AddPoint(500, 0.15);opacityFun->AddPoint(1200, 0.85);// 5. 配置体积属性vtkSmartPointer<vtkVolumeProperty> volumeProperty = vtkSmartPointer<vtkVolumeProperty>::New();volumeProperty->SetColor(colorFun);volumeProperty->SetScalarOpacity(opacityFun);volumeProperty->SetInterpolationTypeToLinear();volumeProperty->ShadeOn(); // 启用阴影// 6. 创建体积对象vtkSmartPointer<vtkVolume> volume = vtkSmartPointer<vtkVolume>::New();volume->SetMapper(volumeMapper);volume->SetProperty(volumeProperty);// 7. 创建渲染管线vtkSmartPointer<vtkRenderer> renderer = vtkSmartPointer<vtkRenderer>::New();renderer->AddVolume(volume);renderer->SetBackground(0.2, 0.3, 0.4);vtkSmartPointer<vtkRenderWindow> renderWindow = vtkSmartPointer<vtkRenderWindow>::New();renderWindow->AddRenderer(renderer);renderWindow->SetSize(1280, 720);vtkSmartPointer<vtkRenderWindowInteractor> interactor = vtkSmartPointer<vtkRenderWindowInteractor>::New();interactor->SetRenderWindow(renderWindow);// 8. 启动交互renderWindow->Render();interactor->Start();return 0;
}

渲染效果

在这里插入图片描述

参考

https://www.cnblogs.com/ybqjymy/p/17633008.html

http://www.dtcms.com/wzjs/457480.html

相关文章:

  • 怎么免费做网站不要域名营销方案案例范文
  • 石家庄免费网站建设百度2023免费
  • 智慧团建入口登录网站沈阳百度seo排名优化软件
  • 如何自己建站网站制作百度搜索简洁版网址
  • 用什么网站做一手楼好策划品牌全案
  • 旅游网站框架代码优化
  • 网站布局策划案中国十大互联网公司
  • .net程序员网站开发工程师百度上做优化
  • 泰安企业做网站哪家公司建设网站好
  • 福州网站制作建设廊坊seo排名扣费
  • 刚接触网站建设有哪些问题如何进行网络营销策划
  • 泉州做网站360免费做网站
  • 简述网站建设及维护的全过程免费网页在线客服系统代码
  • 做网站前期需要准备什么建站网站
  • 建设网站的书籍国际新闻直播
  • 个人网页设计作品欣赏图片南宁seo推广服务
  • 可以做查询功能的网站快速优化网站排名的方法
  • 做食品企业网站的费用微信推广费用一般多少
  • 2017网站建设报价方案seo关键词优化软件怎么样
  • 网站建设应具备哪些专业技能商务软文写作范文200字
  • 自己搭建网站需要多少钱快速提高网站关键词排名优化
  • 做网站机构图用什么工具长春网站关键词排名
  • 东莞网站建设推广多少钱南京百度快照优化排名
  • 做海报 画册的素材网站seo人员的职责
  • 做外贸自己的公司网站武汉网站推广排名
  • 中国交通建设集团英语网站怎么做网上销售
  • 做个网站设计多少钱百度关键字优化价格
  • 青岛高端网站开发百度广告买下的订单在哪里找
  • 在天极网做网站有效果吗快速排名刷
  • 关于做情侣的网站的图片网络推广最好的网站有哪些