C#开发PACS医学影像三维重建(十三):基于人体CT值从皮肤渐变到骨骼的梯度透明思路

当我们将CT切片重建为三维体之后,通常会消除一些不必要的外部组织来观察内部病灶,

一般思路是根据人体常见CT值范围来使得部分组织透明来达到效果,

但这是非黑即白的,即,要么显示皮肤,要么显示神经,要么显示骨骼…

然而,当病灶介于两个CT值范围中间或重合时,要观察病灶这将是一个非常困难的工作,需要手动旋转、切割等一系列操作,

严重降低判断准确性和工作效率,故此采用梯度透明思想来展现渐变过程。

准备一张人体CT值范围表参考:

当我们对三维体使用鼠标操作时,将CT值从最小值到最大值映射到三维体上面,并将透明度从0到100渐变,

如果能自己用代码实现效果最好,否则也可以用VTK进行梯度透明,部分C++代码如下:

vtkSmartPointer<vtkPiecewiseFunction> GradualOp = vtkSmartPointer<vtkPiecewiseFunction>::New();
GradualOp->AddPoint(10, 0.0);
GradualOp->AddPoint(20, 0.5);
GradualOp->AddPoint(30, 1.0);
volumeProperty->SetGradientOpacity(GradualOp);

梯度小于10点的不透明度乘子设为0,完全透明。

梯度大小为10时,不透明度为0;

梯度大小为20时,不透明度乘子为0.5;

梯度大小在10-20时,不透明度乘子通过线性映射至0-0.5之间的数值;

当梯度大小在20-30之间时,不透明度乘子通过线性映射至0.5-1.0之间;

梯度值大于30时,不透明度乘子为1
 

同样最后还是用观察者模式展现体重建

//设置相机
    vtkCamera aCamera = new vtkCamera();
 
    aCamera.SetViewUp(0, 0, -1);
 
    aCamera.SetPosition(0, 1, 0);
 
    aCamera.SetFocalPoint(0, 0, 0);
 
    aCamera.ComputeViewPlaneNormal();
 
 
    //设置Actor
    vtkActor coneActor = new vtkActor();
 
    coneActor.SetMapper(skinMapper);
 
    coneActor.GetProperty().SetAmbient(0.5);
 
    coneActor.GetProperty().SetDiffuse(1);
 
    coneActor.GetProperty().SetSpecular(0.6);
 
    //显示类
    vtkRenderer renderer = renderWindowControl1.RenderWindow.GetRenderers().GetFirstRenderer();
 
    renderer.AddActor(coneActor);//添加coneActor对象
 
    //renderer.AddActor2D(new vtkProp());//添加textActor对象
 
    renderer.SetBackground(0, 0, 0);
 
    renderer.SetActiveCamera(aCamera);//添加相机
 
    renderer.ResetCamera();
 
    vtkRenderWindow renWin = renderWindowControl1.RenderWindow;//设置绘图窗口renWin->AddRenderer(renderer);//装载绘图类
 
    vtkWin32RenderWindowInteractor iren = new vtkWin32RenderWindowInteractor();
 
    iren.SetRenderWindow(renWin);//装载绘图窗口

依照上述思想,实现最终效果,

案例①:从面部重建渐变到口腔牙齿,显露出牙床钢钉:

更为直观、方便的观察牙床钢钉及口腔其他情况:

案例②:颅脑及上胸腔平扫,从皮肤渐变到肌肉、神经、骨骼

渐变过程中观察骨骼、神经、血管等病灶:

 C#开发PACS、RIS、3D医学影像处理系统系列教程 目录整理:

菜鸟入门篇

C#开发PACS医学影像处理系统(一):开发背景和功能预览

C#开发PACS医学影像处理系统(二):界面布局之菜单栏

C#开发PACS医学影像处理系统(三):界面布局之工具栏

C#开发PACS医学影像处理系统(四):界面布局之状态栏

C#开发PACS医学影像处理系统(五):查询病人信息列表

C#开发PACS医学影像处理系统(六):加载Dicom影像

C#开发PACS医学影像处理系统(七):读取影像Dicom信息

C#开发PACS医学影像处理系统(八):单元格变换

C#开发PACS医学影像处理系统(九):序列控件与拖拽

C#开发PACS医学影像处理系统(十):Dicom影像下载策略与算法

C#开发PACS医学影像处理系统(十一):Dicom影像挂片协议

C#开发PACS医学影像处理系统(十二):绘图处理之图形标记

C#开发PACS医学影像处理系统(十三):绘图处理之病灶测量

C#开发PACS医学影像处理系统(十四):处理Dicom影像窗宽窗位

C#开发PACS医学影像处理系统(十五):Dicom影像交叉定位线算法

C#开发PACS医学影像处理系统(十六):2D处理之影像平移和缩放

C#开发PACS医学影像处理系统(十七):2D处理之影像旋转和翻转

C#开发PACS医学影像处理系统(十八):Dicom使用LUT色彩增强和反色

C#开发PACS医学影像处理系统(十九):Dicom影像放大镜

医学影像三维篇

C#开发PACS医学影像三维重建(一):使用VTK重建3D影像

C#开发PACS医学影像三维重建(二):使用VTK进行体绘制

C#开发PACS医学影像三维重建(三):纹理映射与颜色传输

C#开发PACS医学影像三维重建(四):3D网格平滑效果

C#开发PACS医学影像三维重建(五):基于梯度透明的组织漫游

C#开发PACS医学影像三维重建(六):三维光源与阴影效果

C#开发PACS医学影像三维重建(七):空间测量与标注

C#开发PACS医学影像三维重建(八):VR体绘制

C#开发PACS医学影像三维重建(九):MPR三视图切面重建

C#开发PACS医学影像三维重建(十):MIP最小密度投影

C#开发PACS医学影像三维重建(十一):CPR曲面重建

C#开发PACS医学影像三维重建(十二):VE虚拟内镜技术

C#开发PACS医学影像三维重建(十三):基于人体CT值从皮肤渐变到骨骼的梯度透明思路

C#开发PACS医学影像三维重建(十四):基于能量模型算法将曲面牙床展开至二维平面

熟手进阶篇

C#处理医学影像(一):基于Hessian矩阵的血管肺纹理骨骼增强对比

C#处理医学影像(二):基于Hessian矩阵的医学影像增强与窗宽窗位

C#处理医学影像(三):基于漫水边界自动选取病灶范围的实现思路

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

胶片打印:

C#开发医学影像胶片打印系统(一):万能花式布局的实现思路

C#开发医学影像胶片打印系统(二):胶片打印机通讯

C#开发医学影像胶片打印系统(三):Pacs二维功能在排版中的应用

登峰造极篇

C#开发基于Python人工智能的肺结节自动检测

C#开发基于Python人工智能的脊柱侧弯曲率算法

C#开发基于Python机器学习的医学影像骨骼仿真动画

C#开发基于Python机器学习的术后恢复模拟

C#开发基于U3D的VR眼镜设备虚拟人体三维重建

C#开发基于全息投影的裸眼3D医学影像显示技术

免费下载

免费下载使用本教程PACS软件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值