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

ColoredElevationMap 根据标量进行颜色映射

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①标量的颜色映射


二:代码及注释

import vtkmodules.vtkInteractionStyle import vtkmodules.vtkRenderingOpenGL2 from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkCommonCore import vtkLookupTable, vtkMinimalStandardRandomSequence, vtkPoints,vtkUnsignedCharArray from vtkmodules.vtkCommonDataModel import vtkPolyData from vtkmodules.vtkFiltersCore import vtkDelaunay2D from vtkmodules.vtkRenderingCore import ( vtkActor, vtkPolyDataMapper, vtkRenderWindow, vtkRenderWindowInteractor, vtkRenderer ) def main(): named_colors = vtkNamedColors() points = vtkPoints() xx, yy, zz = 0.0, 0.0, 0.0 GridSize = 20 rng = vtkMinimalStandardRandomSequence() rng.SetSeed(8775586) for x in range(0, GridSize): for y in range(0, GridSize): rng.Next() xx = x + rng.GetRangeValue(-0.2, 0.2) rng.Next() yy = y + rng.GetRangeValue(-0.2, 0.2) rng.Next() zz = rng.GetRangeValue(-0.5, 0.5) points.InsertNextPoint(xx, yy, zz) inputPolyData = vtkPolyData() inputPolyData.SetPoints(points) # Delaunay2D delaunay = vtkDelaunay2D() delaunay.SetInputData(inputPolyData) delaunay.Update() outputPolyData = delaunay.GetOutput() # 获取其包围盒 bounds = [0.0] * 6 outputPolyData.GetBounds(bounds) # 得到z值的范围 minz = bounds[4] maxz = bounds[5] # 构建颜色映射表 colorLookupTable = vtkLookupTable() colorLookupTable.SetTableRange(minz, maxz) colorLookupTable.Build() # 遍历点并应用颜色 colors = vtkUnsignedCharArray() colors.SetNumberOfComponents(3) colors.SetName("Colors") for i in range(0, outputPolyData.GetNumberOfPoints()): p = [0.0] * 3 outputPolyData.GetPoint(i, p) dcolor = [0.0] * 3 colorLookupTable.GetColor(p[2], dcolor) # 利用当前点的z值得到其对应的rgb颜色 color = [0] * 3 for j in range(0, 3): color[j] = int(255 * dcolor[j]) colors.InsertNextTuple3(color[0], color[1], color[2]) outputPolyData.GetPointData().SetScalars(colors) # Create a mapper and actor mapper = vtkPolyDataMapper() mapper.SetInputData(outputPolyData) """ 由于已经用 outputPolyData.GetPointData().SetScalars(colors) 将颜色数组设置在了默认的 Scalars 槽位,Mapper 应该能够自动找到并使用它 """ actor = vtkActor() actor.SetMapper(mapper) # Create a renderer, render window, and interactor renderer = vtkRenderer() renderWindow = vtkRenderWindow() renderWindow.AddRenderer(renderer) renderWindow.SetWindowName('ColoredElevationMap') renderWindowInteractor = vtkRenderWindowInteractor() renderWindowInteractor.SetRenderWindow(renderWindow) # Add the actor to the scene renderer.AddActor(actor) renderer.SetBackground(named_colors.GetColor3d("DarkSlateGray")) # Render and interact renderWindow.Render() renderWindowInteractor.Start() if __name__ == '__main__': main()
http://www.cnnetsun.cn/news/178921.html

相关文章:

  • LangFlow B站视频内容创作方向建议
  • LangFlow代码质量检查工具集成(ESLint/Prettier)
  • LangFlow Google排名冲顶可能性分析
  • TLS 1.0/1.1停用倒计时,Open-AutoGLM如何快速适配TLS 1.2+?
  • 基于springboot的家教管理系统的设计与实现
  • 解锁科研新维度:书匠策AI期刊论文模块,开启学术写作的“智变”时代
  • LangFlow百度搜索排名优化技巧
  • 数智时代,openGauss Summit 2025即将发布哪些技术创新破局
  • LangFlow CI/CD流水线搭建实践
  • 论指针运算
  • 面试官:多模态 Transformer 如何处理不同模态的序列长度差异?
  • LangFlow结合RAG架构构建企业知识库问答
  • 480万人才缺口!网络安全,一个被低估的“金饭碗”!
  • Web 安全入门:从 OWASP Top 10 到常见漏洞,从零基础入门到精通,收藏这一篇就够了!_web top10
  • TOSHIBA 2SA1162-GR,LF SOT-23-3 三极管(BJT)
  • 【MWORKS使用技巧84】Sysplorer中使用Constants组件时,如何产生向量信号?
  • 掌握这4种异常处理模式,轻松应对Open-AutoGLM解密崩溃危机
  • 如何在30分钟内完成Open-AutoGLM加密传输配置?高效运维必看
  • NetSupport Manager 路径遍历漏洞 (CVE-2025-34181) 技术深度解析
  • Electron 实战项目
  • Open-AutoGLM解密异常频发?(企业级容错架构设计实践)
  • 你还在用传统加密?Open-AutoGLM的这4个优势已彻底改写行业规则
  • 企业级城市垃圾分类管理系统管理系统源码|SpringBoot+Vue+MyBatis架构+MySQL数据库【完整版】
  • 为什么你的系统总被Open-AutoGLM误封?一文看懂白名单配置核心要点
  • 【数据安全突围战】:Open-AutoGLM为何成为2024年最值得掌握的加密技术?
  • 使用机器学习简化机构沟通,提升可读性与包容性
  • LangFlow降低AI开发门槛:非技术人员也能构建智能应用
  • LangFlow与LangChain协同工作原理深度剖析
  • 16.2 对齐方法论:FineTune与RAG两大技术路径
  • 16.3 微调技术盘点:产品经理需要了解的核心方法