news 2026/5/23 17:50:10

Decimation 模型的下采样

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Decimation 模型的下采样

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①模型下采样


二:代码及注释

import vtkmodules.vtkRenderingOpenGL2 import vtkmodules.vtkInteractionStyle from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkIOXML import vtkXMLPolyDataReader from vtkmodules.vtkFiltersCore import vtkDecimatePro from vtkmodules.vtkCommonDataModel import vtkPolyData from vtkmodules.vtkRenderingCore import vtkPolyDataMapper, vtkProperty, vtkActor, vtkRenderer, vtkRenderWindow, \ vtkRenderWindowInteractor, vtkCamera def main(): filePath = "Data/Torso.vtp" reduction = 0.9 colors = vtkNamedColors() backFaceColor = colors.GetColor3d("Gold") inputActorColor = colors.GetColor3d("NavajoWhite") decimatedActorColor = colors.GetColor3d('NavajoWhite') reader = vtkXMLPolyDataReader() reader.SetFileName(filePath) reader.Update() inputPolyData = reader.GetOutput() """ vtkDecimatePro 通过去除冗余的或不重要的三角形和顶点,将一个高分辨率的模型转换为一个低分辨率的模型 """ decimate = vtkDecimatePro() decimate.SetInputData(inputPolyData) decimate.SetTargetReduction(reduction) decimate.PreserveTopologyOn() # 保存原先的拓扑结构,不破坏洞或边界 decimate.Update() decimated = vtkPolyData() decimated.ShallowCopy(decimate.GetOutput()) inputMapper = vtkPolyDataMapper() inputMapper.SetInputData(inputPolyData) backFace = vtkProperty() backFace.SetColor(backFaceColor) inputActor = vtkActor() inputActor.SetMapper(inputMapper) inputActor.GetProperty().SetInterpolationToFlat() inputActor.GetProperty().SetColor(inputActorColor) inputActor.SetBackfaceProperty(backFace) decimatedMapper = vtkPolyDataMapper() decimatedMapper.SetInputData(decimated) decimatedActor = vtkActor() decimatedActor.SetMapper(decimatedMapper) decimatedActor.GetProperty().SetColor(decimatedActorColor) decimatedActor.GetProperty().SetInterpolationToFlat() decimatedActor.SetBackfaceProperty(backFace) renderWindow = vtkRenderWindow() renderWindow.SetSize(600, 300) renderWindow.SetWindowName('Decimation'); # And one interactor interactor = vtkRenderWindowInteractor() interactor.SetRenderWindow(renderWindow) leftViewport = [0.0, 0.0, 0.5, 1.0] rightViewport = [0.5, 0.0, 1.0, 1.0] leftRenderer = vtkRenderer() renderWindow.AddRenderer(leftRenderer) leftRenderer.SetViewport(leftViewport) # leftRenderer.SetBackground((colors.GetColor3d('leftBkg'))) leftRenderer.SetBackground((colors.GetColor3d('Peru'))) rightRenderer = vtkRenderer() renderWindow.AddRenderer(rightRenderer) rightRenderer.SetViewport(rightViewport) # rightRenderer.SetBackground((colors.GetColor3d('rightBkg'))) rightRenderer.SetBackground((colors.GetColor3d('CornflowerBlue'))) # Add the sphere to the left and the cube to the right leftRenderer.AddActor(inputActor) rightRenderer.AddActor(decimatedActor) # Shared camera # Shared camera looking down the -y axis camera = vtkCamera() camera.SetPosition(0, -1, 0) camera.SetFocalPoint(0, 0, 0) camera.SetViewUp(0, 0, 1) camera.Elevation(30) camera.Azimuth(30) leftRenderer.SetActiveCamera(camera) rightRenderer.SetActiveCamera(camera) leftRenderer.ResetCamera() leftRenderer.ResetCameraClippingRange() renderWindow.Render() renderWindow.SetWindowName('Decimation') interactor.Start() if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 21:15:40

为什么你的Open-AutoGLM服务突然中断?可能是证书过期未设提醒!

第一章:Open-AutoGLM服务中断的根源解析Open-AutoGLM作为一款基于大语言模型的自动化推理服务平台,在高并发场景下偶发的服务中断问题逐渐暴露其架构层面的潜在缺陷。通过对近期多次故障日志的聚合分析,核心问题可归结为资源调度失衡、依赖服…

作者头像 李华
网站建设 2026/5/22 7:40:23

为什么90%的团队用不好Open-AutoGLM?你必须知道的3条脱敏规则设计原则

第一章:为什么90%的团队用不好Open-AutoGLM?许多团队在引入 Open-AutoGLM 时寄予厚望,期望其自动化生成高质量语言模型输出的能力能提升开发效率。然而,实际落地过程中,超过九成的团队未能充分发挥其潜力。根本原因往往…

作者头像 李华
网站建设 2026/5/20 19:40:55

【企业级数据防护指南】:Open-AutoGLM脱敏恢复控制的5大应用场景

第一章:Open-AutoGLM脱敏后数据恢复控制的核心价值在数据安全与隐私保护日益重要的今天,Open-AutoGLM 提供了一种创新机制,用于在数据脱敏后实现可控的恢复能力。该机制不仅保障了敏感信息在传输和存储过程中的安全性,还为授权场景…

作者头像 李华
网站建设 2026/5/21 20:58:41

基于智能推荐的卫生健康系统的设计与实现

在数字化医疗快速发展的背景下,传统卫生健康服务面临信息过载、资源匹配效率低等问题,难以满足用户个性化需求。为此,本研究旨在设计并实现基于智能推荐的卫生健康系统,通过整合医疗资源与用户需求,提升服务精准性与便…

作者头像 李华
网站建设 2026/5/14 20:01:17

Win11 紧凑任务栏开启攻略:小屏设备扩容神器,注册表修改一步到位

用 Win11 平板或小屏笔记本的朋友,大概率都吐槽过默认任务栏的 “占地问题”—— 本就有限的屏幕空间,被宽大的任务栏占据不少,不管是浏览网页、编辑文档还是追剧,都少了点沉浸式体验。其实 Win11 隐藏着 “紧凑任务栏” 功能&…

作者头像 李华