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

CreateBFont 2D图像的高斯平滑并转化为3D几何体

一:主要的知识点

1、说明

本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客

2、知识点纪要

本段代码主要涉及的有①vtkImageDataGeometryFilter结构化图像数据转换为几何数据


二:代码及注释

import vtkmodules.vtkInteractionStyle import vtkmodules.vtkRenderingOpenGL2 from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkIOImage import vtkPNMReader from vtkmodules.vtkImagingGeneral import vtkImageGaussianSmooth from vtkmodules.vtkFiltersGeometry import vtkImageDataGeometryFilter from vtkmodules.vtkFiltersCore import vtkClipPolyData from vtkmodules.vtkRenderingCore import ( vtkActor, vtkPolyDataMapper, vtkRenderWindow, vtkRenderWindowInteractor, vtkRenderer ) def main(): colors = vtkNamedColors() fileName = "Data/B.pgm" ren1 = vtkRenderer() renWin = vtkRenderWindow() renWin.AddRenderer(ren1) iren = vtkRenderWindowInteractor() iren.SetRenderWindow(renWin) imageIn = vtkPNMReader() imageIn.SetFileName(fileName) """ vtkImageGaussianSmooth 对图像或体数据进行高斯平滑,用来降噪、平滑梯度等 """ gaussian = vtkImageGaussianSmooth() gaussian.SetInputConnection(imageIn.GetOutputPort()) gaussian.SetStandardDeviations(2, 2) # 设置高斯核在每个维度上的标准差,σ值越大,高斯核越宽,平滑的强度就越大,图像越模糊 gaussian.SetDimensionality(2) # 告知过滤器,正在处理一个二维图像,忽略Z维度存在 gaussian.SetRadiusFactors(1, 1) # 设置高斯平滑操作的计算范围 """ vtkImageDataGeometryFilter 把结构化图像数据 (vtkImageData) 转换成几何数据 (vtkPolyData),以便可视化或进一步几何处理 """ geometry = vtkImageDataGeometryFilter() geometry.SetInputConnection(gaussian.GetOutputPort()) """ 高斯平滑的2D图像转换成的3D平面多边形数据。这个平面上的每个点都带有一个标量值(原始图像的像素强度) """ aClipper = vtkClipPolyData() aClipper.SetInputConnection(geometry.GetOutputPort()) aClipper.SetValue(127.5) # 大于127.5的部分被保留,小于127.5的部分被丢弃 aClipper.InsideOutOn() # 翻转裁剪逻辑 aClipper.GenerateClipScalarsOff() # 禁用生成新的剪裁标量 aClipper.GetOutput().GetPointData().CopyScalarsOff() aClipper.Update() mapper = vtkPolyDataMapper() mapper.SetInputConnection(aClipper.GetOutputPort()) mapper.ScalarVisibilityOff() letter = vtkActor() letter.SetMapper(mapper) ren1.AddActor(letter) letter.GetProperty().SetDiffuseColor(colors.GetColor3d("LampBlack")) letter.GetProperty().SetRepresentationToWireframe() ren1.SetBackground(colors.GetColor3d("WhiteSmoke")) ren1.ResetCamera() ren1.GetActiveCamera().Dolly(1.2) ren1.ResetCameraClippingRange() renWin.SetSize(640, 480) renWin.SetWindowName('CreateBFont') renWin.Render() iren.Start() if __name__ == '__main__': main()
http://www.jsqmd.com/news/232059/

相关文章:

  • 3541365413
  • ResNet18实战案例:工业机器人视觉
  • ResNet18实战教程:工业缺陷检测系统
  • ResNet18实战:构建高精度图像分类服务
  • ResNet18优化实战:推理吞吐量提升
  • ResNet18部署详解:Serverless架构图像识别
  • Multisim14使用教程:傅里叶分析功能操作指南
  • CubeAxesActor 为几何体添加边框和坐标轴
  • MOSFET基本工作原理图解:开关状态转换详解
  • ResNet18代码详解:从模型加载到推理全流程
  • ResNet18实战指南:构建智能农业监测系统
  • ResNet18部署案例:教育场景应用开发指南
  • USB_Burning_Tool批量模式下固件一致性保障方案
  • DisplacementPlot 结构动态可视化
  • ResNet18实战:5分钟搭建高精度图像分类系统
  • ExponentialCosine 复杂的二维数学函数映射为3D曲面
  • STC89C52控制蜂鸣器演奏乐曲完整指南
  • ResNet18实战:教育智能教具识别系统
  • ResNet18优化实战:量化加速推理的完整步骤
  • 通俗解释波形发生器设计中的频率控制
  • ResNet18实战:智能监控系统物体识别部署案例
  • ResNet18实战:构建高稳定性识别服务的关键
  • ResNet18应用解析:智能交通管理系统
  • ResNet18实战教程:服装分类系统开发
  • ResNet18性能测试:CPU环境下的推理速度对比
  • ResNet18应用案例:智能垃圾分类系统
  • 多层板PCB生产流程实例分析:常见缺陷及改善措施
  • ResNet18部署详解:Kubernetes集群部署方案
  • ResNet18入门指南:零代码实现物体识别WebUI
  • ResNet18应用实例:零售货架商品识别系统