Hello 隐式建模

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①vtkImplicitModeller隐式建模

二:代码及注释

python 复制代码
"""
主要展示了如何使用**隐式建模(implicit modelling)**技术,
将一个简单的二维线条集合(hello.vtk 文件中的文字)"加厚"成一个平滑、半透明的三维实体
"""
import vtkmodules.vtkRenderingOpenGL2
from vtkmodules.vtkCommonColor import vtkNamedColors
from vtkmodules.vtkFiltersCore import vtkContourFilter
from vtkmodules.vtkFiltersHybrid import vtkImplicitModeller
from vtkmodules.vtkIOLegacy import vtkPolyDataReader
from vtkmodules.vtkRenderingCore import (
    vtkActor,
    vtkCamera,
    vtkPolyDataMapper,
    vtkRenderWindow,
    vtkRenderWindowInteractor,
    vtkRenderer
)
 
 
def main():
    fileName = "Data/hello.vtk"
 
    colors = vtkNamedColors()
 
    reader = vtkPolyDataReader()
    reader.SetFileName(fileName)
    reader.Update()
 
    lineMapper = vtkPolyDataMapper()
    lineMapper.SetInputConnection(reader.GetOutputPort())
 
    lineActor = vtkActor()
    lineActor.SetMapper(lineMapper)
    lineActor.GetProperty().SetColor(colors.GetColor3d("Tomato"))
    lineActor.GetProperty().SetLineWidth(3)
 
    """
    vtkImplicitModeller  
    把输入的几何(reader 读出的模型,比如一个 vtkPolyData)转换成一个 隐式函数场
    (就像 vtkSampleFunction 生成标量场一样),以便后续做等值面提取、布尔运算等
    """
    imp = vtkImplicitModeller()
    """
    输出的几何体(比如一个三维曲面)会被转换成"体素化的标量场"
    """
    imp.SetInputConnection(reader.GetOutputPort())
    """
    设置体素网格的分辨率(x, y, z 三个方向上有多少采样点)
    """
    imp.SetSampleDimensions(110, 40, 20)
    """
    设置一个截断距离
    隐式建模器会计算"每个采样点到最近输入几何的距离"
    小于 0.25 的地方会存下真实距离
    大于 0.25 的地方会统一设置为 0.25(避免无限大)
    """
    imp.SetMaximumDistance(0.25)
    imp.SetModelBounds(-1.0, 10.0, -1.0, 3.0, -1.0, 1.0)
 
    contour = vtkContourFilter()
    contour.SetInputConnection(imp.GetOutputPort())
    """
    SetValue 这里的值如果大于SetMaximumDistance
    vtkImplicitModeller 会自动调整并可能忽略你设定的 MaximumDistance
    """
    contour.SetValue(0,  0.25)
 
    impMapper = vtkPolyDataMapper()
    impMapper.SetInputConnection(contour.GetOutputPort())
    impMapper.ScalarVisibilityOff()
 
    impActor = vtkActor()
    impActor.SetMapper(impMapper)
    impActor.GetProperty().SetColor(colors.GetColor3d('Peacock'))
    impActor.GetProperty().SetOpacity(0.5)
 
    # Create the usual graphics stuff.
    # Create the RenderWindow, Renderer and Interactor.
    #
    ren1 = vtkRenderer()
 
    renWin = vtkRenderWindow()
    renWin.AddRenderer(ren1)
    renWin.SetWindowName('Hello')
 
    iren = vtkRenderWindowInteractor()
    iren.SetRenderWindow(renWin)
 
    # Add the actors to the renderer, set the background and size
    #
    ren1.AddActor(lineActor)
    ren1.AddActor(impActor)
    ren1.SetBackground(colors.GetColor3d('Wheat'))
    renWin.SetSize(640, 480)
 
    camera = vtkCamera()
    camera.SetFocalPoint(4.5, 1, 0)
    camera.SetPosition(4.5, 1.0, 6.73257)
    camera.SetViewUp(0, 1, 0)
 
    ren1.SetActiveCamera(camera)
    ren1.ResetCamera()
    camera.Dolly(1.3)
    camera.SetClippingRange(1.81325, 90.6627)
 
    renWin.Render()
    iren.Start()
 
 
if __name__ == '__main__':
    main()
相关推荐
寻星探路13 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
ValhallaCoder16 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
猫头虎17 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
八零后琐话17 小时前
干货:程序员必备性能分析工具——Arthas火焰图
开发语言·python
青春不朽51218 小时前
Scrapy框架入门指南
python·scrapy
MZ_ZXD00119 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
全栈老石19 小时前
Python 异步生存手册:给被 JS async/await 宠坏的全栈工程师
后端·python
梨落秋霜20 小时前
Python入门篇【模块/包】
python
阔皮大师21 小时前
INote轻量文本编辑器
java·javascript·python·c#