news 2026/1/31 0:27:07

HighlightWithSilhouette 选择对象进行轮廓线高亮

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HighlightWithSilhouette 选择对象进行轮廓线高亮

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①选择对象并高亮显示


二:代码及注释

import vtkmodules.vtkInteractionStyle import vtkmodules.vtkRenderingOpenGL2 from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkCommonCore import vtkMinimalStandardRandomSequence from vtkmodules.vtkRenderingCore import vtkActor, vtkRenderer, vtkRenderWindow, vtkRenderWindowInteractor, \ vtkPropPicker, vtkPolyDataMapper from vtkmodules.vtkFiltersHybrid import vtkPolyDataSilhouette from vtkmodules.vtkFiltersSources import vtkSphereSource from vtkmodules.vtkInteractionStyle import vtkInteractorStyleTrackballCamera class MouseInteractorHighLightActor(vtkInteractorStyleTrackballCamera): def __init__(self, silhouette=None, silhouetteActor=None): self.AddObserver("LeftButtonPressEvent", self.onLeftButtonDown) self.LastPickedActor = None self.Silhouette = silhouette self.SilhouetteActor = silhouetteActor def onLeftButtonDown(self, obj, event): clickPos = self.GetInteractor().GetEventPosition() picker = vtkPropPicker() picker.Pick(clickPos[0], clickPos[1], 0, self.GetDefaultRenderer()) self.LastPickedActor = picker.GetActor() if self.LastPickedActor: self.GetDefaultRenderer().RemoveActor(self.SilhouetteActor) # 清除渲染器中当前显示的轮廓线 self.Silhouette.SetInputData(self.LastPickedActor.GetMapper().GetInput()) self.GetDefaultRenderer().AddActor(self.SilhouetteActor) self.OnLeftButtonDown() def main(): numberOfSpheres = 10 colors = vtkNamedColors() renderer = vtkRenderer() renderer.SetBackground(colors.GetColor3d('SteelBlue')) renderWindow = vtkRenderWindow() renderWindow.SetSize(640, 480) renderWindow.AddRenderer(renderer) interactor = vtkRenderWindowInteractor() interactor.SetRenderWindow(renderWindow) randomSequence = vtkMinimalStandardRandomSequence() randomSequence.SetSeed(8775070) for i in range(numberOfSpheres): source = vtkSphereSource() # random position and radius x = randomSequence.GetRangeValue(-5.0, 5.0) randomSequence.Next() y = randomSequence.GetRangeValue(-5.0, 5.0) randomSequence.Next() z = randomSequence.GetRangeValue(-5.0, 5.0) randomSequence.Next() radius = randomSequence.GetRangeValue(0.5, 1.0) randomSequence.Next() source.SetRadius(radius) source.SetCenter(x, y, z) source.SetPhiResolution(11) source.SetThetaResolution(21) mapper = vtkPolyDataMapper() mapper.SetInputConnection(source.GetOutputPort()) actor = vtkActor() actor.SetMapper(mapper) r = randomSequence.GetRangeValue(0.4, 1.0) randomSequence.Next() g = randomSequence.GetRangeValue(0.4, 1.0) randomSequence.Next() b = randomSequence.GetRangeValue(0.4, 1.0) randomSequence.Next() actor.GetProperty().SetDiffuseColor(r, g, b) actor.GetProperty().SetDiffuse(0.8) actor.GetProperty().SetSpecular(0.5) actor.GetProperty().SetSpecularColor(colors.GetColor3d('White')) actor.GetProperty().SetSpecularPower(30.0) renderer.AddActor(actor) renderWindow.Render() """ vtkPolyDataSilhouette 是一个几何特征可视化类,用来生成并显示一个模型的轮廓线 即——从某个视点或光源方向看去,模型边缘的可见轮廓线 """ silhouette = vtkPolyDataSilhouette() silhouette.SetCamera(renderer.GetActiveCamera()) # 指定相机,用来计算哪些属于轮廓 silhouetteMapper = vtkPolyDataMapper() silhouetteMapper.SetInputConnection(silhouette.GetOutputPort()) silhouetteActor = vtkActor() silhouetteActor.SetMapper(silhouetteMapper) silhouetteActor.GetProperty().SetColor(colors.GetColor3d("Tomato")) silhouetteActor.GetProperty().SetLineWidth(5) style = MouseInteractorHighLightActor(silhouette, silhouetteActor) style.SetDefaultRenderer(renderer) interactor.Initialize() interactor.SetInteractorStyle(style) renderWindow.SetWindowName('HighlightWithSilhouette') renderWindow.Render() interactor.Start() if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 9:44:56

零基础教程:用AI轻松制作你的第一个1024网站

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 设计一个极简版的1024导航网站模板,特别适合新手学习使用,要求:1.只有核心导航功能 2.最简化的代码结构 3.详细的步骤说明文档 4.内置示例数据。…

作者头像 李华
网站建设 2026/1/30 11:57:02

GLM-4.6V-Flash-WEB网络超时?API调用优化实战

GLM-4.6V-Flash-WEB网络超时?API调用优化实战 智谱最新开源,视觉大模型。 1. 背景与问题定位 1.1 GLM-4.6V-Flash-WEB 简介 GLM-4.6V-Flash-WEB 是智谱 AI 推出的最新开源多模态视觉大模型,支持图像理解、图文生成、视觉问答(VQ…

作者头像 李华
网站建设 2026/1/30 11:20:45

PinWin窗口置顶工具:多任务处理的高效解决方案

PinWin窗口置顶工具:多任务处理的高效解决方案 【免费下载链接】PinWin Pin any window to be always on top of the screen 项目地址: https://gitcode.com/gh_mirrors/pin/PinWin 在现代电脑使用中,多任务处理已成为常态,但频繁切换…

作者头像 李华
网站建设 2026/1/29 11:53:16

WorkshopDL完全指南:无需Steam客户端轻松获取创意工坊模组

WorkshopDL完全指南:无需Steam客户端轻松获取创意工坊模组 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 对于在非Steam平台购买游戏的玩家来说,无法访…

作者头像 李华
网站建设 2026/1/30 3:59:57

混沌工程安全检查表:构建安全故障的系统性防御体系

——面向软件测试工程师的韧性验证实战手册 一、安全故障在混沌工程中的特殊性与验证价值 1.1 安全故障的链式反应特征 相较于常规故障,安全事件具有明显的传导性(如密钥泄漏→数据泄露→合规危机)。根据Gartner 2025年安全报告,…

作者头像 李华
网站建设 2026/1/29 21:44:42

韧性量化双引擎:软件测试中的MTTF/MTTR深度解析

——构建系统稳定性的数字标尺 一、韧性工程的核心量化困境 在分布式系统复杂度指数级增长的2026年,软件测试团队面临的核心挑战已从单纯的功能验证转向韧性验证。据Gartner最新报告显示,73%的企业级故障源于未被充分测试的韧性短板。而量化韧性需解决…

作者头像 李华