news 2026/6/10 16:51:38

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 13:14:16

ResNet18技术解析:ImageNet预训练模型的应用

ResNet18技术解析:ImageNet预训练模型的应用 1. 通用物体识别中的ResNet18:从理论到落地 1.1 深度学习时代的图像分类演进 在计算机视觉的发展历程中,图像分类是最早被深度神经网络攻克的核心任务之一。2012年AlexNet的横空出世标志着卷积…

作者头像 李华
网站建设 2026/6/10 13:01:25

ResNet18实战指南:构建智能农业监测系统

ResNet18实战指南:构建智能农业监测系统 1. 引言:通用物体识别在智能农业中的价值 随着人工智能技术的普及,通用物体识别正成为智能农业系统的核心能力之一。从田间作物生长状态监测、病虫害识别,到农机设备自动巡检、牲畜行为分…

作者头像 李华
网站建设 2026/6/10 12:55:15

ResNet18实战案例:打造稳定物体识别服务

ResNet18实战案例:打造稳定物体识别服务 1. 引言:通用物体识别中的ResNet18价值 在当前AI应用快速落地的背景下,通用物体识别已成为智能监控、内容审核、辅助交互等场景的核心能力。然而,许多开发者面临模型依赖外部API、响应延…

作者头像 李华
网站建设 2026/6/10 12:56:27

嵌入式Linux中ioctl接口的完整指南

嵌入式Linux中ioctl接口的实战解析:从入门到避坑 你有没有遇到过这样的场景?想通过程序设置串口波特率,却发现 write() 函数无能为力;或者要读取一个传感器的状态寄存器,但 read() 只能返回原始数据流。这时候&…

作者头像 李华
网站建设 2026/6/10 12:53:54

三极管开关模式详解:超详细版硬件设计指南

三极管开关设计实战指南:从原理到避坑全解析在嵌入式和电源系统中,你可能已经用过无数个MOSFET、DC-DC芯片甚至智能栅极驱动器。但当你翻开发烧友的电路板或拆开一台老式家电时,总会发现那个熟悉的身影——一个小小的三极管,正默默…

作者头像 李华
网站建设 2026/6/10 12:55:36

ResNet18应用场景:从日用品到自然风景识别

ResNet18应用场景:从日用品到自然风景识别 1. 引言:通用物体识别中的ResNet18价值 在计算机视觉领域,图像分类是基础且关键的任务之一。无论是智能相册自动打标签、电商平台商品识别,还是安防系统中的异常物品检测,背…

作者头像 李华