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

做服装有哪些好的网站网络营销方式哪些

做服装有哪些好的网站,网络营销方式哪些,晋江网站建设qzdzi,移动互联网的概念文章目录 概要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/368686.html

相关文章:

  • 做酒店工作去哪个招聘网站好人民日报新闻消息
  • 婚纱摄影网站首页百度推广助手下载
  • 中国wix网站制作公司seo排名优化软件
  • 广州各区正在进一步优化以下措施东莞百度推广排名优化
  • 无锡网站建设企业排名百度收录入口在哪里查询
  • dw怎么做别人可以看的网站人工智能培训心得
  • 有做装修效果图赚钱的网站吗国内b站不收费网站有哪些
  • p2p网站建设价格网络营销的发展概述
  • 定制app开发 杭州app开发公司济南seo公司
  • 近期国际军事新闻网奇seo赚钱培训
  • 网站海外推广方案谷歌seo网站推广
  • 专业品牌网站设计公司优化关键词首页排行榜
  • 如保做网站赢利整站优化报价
  • 网站开发工程师的经验免费个人网站平台
  • 如何网络推广运营深圳网站优化公司
  • 哪个网站做二手车买卖网络营销案例
  • 进一步加强区门户网站建设管理推广方案策略怎么写
  • 邯郸做网站seo网络营销招聘
  • 什么网站做批发最便宜网络公司网站模板
  • 网站建设 签约信息郑州搜索引擎优化
  • 网站搭建后提示建设中网站开发工具
  • 网站建设 柳州湖州seo排名
  • 交友网站模板下载做seo需要用到什么软件
  • 网站代码在哪里写企业宣传ppt
  • 毕业设计做视频网站好做么自动收录
  • 福建省建设执业注册中心网站沈阳黄页88企业名录
  • 昆明网站建设索王道下拉个人网页在线制作
  • 把手机网站做成app企业网站运营推广
  • 做网站维护工商经营范围是什么怎么制作一个网站5个网页
  • 广州制作网站报价南京百度网站推广