news 2026/4/23 22:24:58

TriangulateTerrainMap Delaunay 三角剖分创建 3D 地形

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
TriangulateTerrainMap Delaunay 三角剖分创建 3D 地形

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①Delaunay三角剖分创建3维模型


二:代码及注释

import vtkmodules.vtkRenderingOpenGL2 import vtkmodules.vtkInteractionStyle from vtkmodules.vtkCommonColor import vtkNamedColors from vtkmodules.vtkCommonCore import vtkPoints, vtkMinimalStandardRandomSequence from vtkmodules.vtkCommonDataModel import vtkPolyData from vtkmodules.vtkFiltersGeneral import vtkVertexGlyphFilter from vtkmodules.vtkRenderingCore import vtkPolyDataMapper, vtkActor, vtkRenderer, vtkRenderWindowInteractor, \ vtkRenderWindow from vtkmodules.vtkFiltersCore import vtkDelaunay2D def main(): colors = vtkNamedColors() points = vtkPoints() gridSize = 10 seed = 10 rng = vtkMinimalStandardRandomSequence() rng.SetSeed(seed) # 等价于 rng.Initialize(seed) for x in range(0, gridSize): for y in range(0, gridSize): d = rng.GetValue() rng.Next() points.InsertNextPoint(x, y, d * 3) polydata = vtkPolyData() polydata.SetPoints(points) # 将点集转换为可以渲染的单元 glyphFilter = vtkVertexGlyphFilter() glyphFilter.SetInputData(polydata) glyphFilter.Update() pointsMapper = vtkPolyDataMapper() pointsMapper.SetInputConnection(glyphFilter.GetOutputPort()) pointsActor = vtkActor() pointsActor.SetMapper(pointsMapper) pointsActor.GetProperty().SetPointSize(3) pointsActor.GetProperty().SetColor(colors.GetColor3d("Red")) # 根据三维坐标点生成一个三角剖分地图 delaunay = vtkDelaunay2D() delaunay.SetInputData(polydata) delaunay.Update() triangulatedMapper = vtkPolyDataMapper() triangulatedMapper.SetInputConnection(delaunay.GetOutputPort()) triangulatedActor = vtkActor() triangulatedActor.SetMapper(triangulatedMapper) # Create a renderer, render window, and interactor renderer = vtkRenderer() renderWindow = vtkRenderWindow() renderWindow.AddRenderer(renderer) renderWindowInteractor = vtkRenderWindowInteractor() renderWindowInteractor.SetRenderWindow(renderWindow) # Add the actor to the scene renderer.AddActor(pointsActor) renderer.AddActor(triangulatedActor) renderer.SetBackground(colors.GetColor3d("Green")) # Background color green # Render and interact renderWindow.SetWindowName('TriangulateTerrainMap') renderWindow.Render() renderWindowInteractor.Start() if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 6:22:48

WarpVector 基于向量数据的形变

一:主要的知识点 1、说明 本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客 2、知识点纪要 本段代码主要涉及的有①vtkWarpVector基于向量的形变 二&#xf…

作者头像 李华
网站建设 2026/4/22 10:09:31

CompositePolyDataMapper复合数据集的展示与渲染

一:主要的知识点 1、说明 本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客 2、知识点纪要 本段代码主要涉及的有①vtkMultiBlockDataSet复合数据的管理与渲…

作者头像 李华
网站建设 2026/4/23 9:55:23

为什么顶尖工程师都在用Open-AutoGLM做知识沉淀?

第一章:为什么顶尖工程师都在用Open-AutoGLM做知识沉淀?在快速迭代的技术环境中,知识管理已成为区分普通开发者与顶尖工程师的关键能力。Open-AutoGLM 作为一款开源的自动化知识图谱生成工具,正被越来越多技术专家用于系统性地沉淀…

作者头像 李华
网站建设 2026/4/23 9:53:54

Excalidraw AI模型更新频率及维护计划

Excalidraw AI 模型的更新与维护:构建可持续演进的智能绘图系统 在远程协作成为常态的今天,可视化表达早已不再是设计师的专属技能。从产品原型到系统架构,从流程梳理到头脑风暴,越来越多的技术团队依赖轻量级、高自由度的白板工具…

作者头像 李华
网站建设 2026/4/23 9:58:08

14、网络安全综合指南:区域、协议与认证详解

网络安全综合指南:区域、协议与认证详解 1. 安全区域 网络可想象为由离散的网络段组成,这些网络段被称为安全区域,每个区域内的系统具有共同的需求。安全区域具有以下特点: - 区域内的系统可能运行不同的协议和操作系统,如Windows和NetWare。 - 计算机类型和操作系统并…

作者头像 李华