WarpTo 对 3D 几何体进行形变(Warping操作,使其顶点朝着一个指定的空间点移动

一:主要的知识点

1、说明

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

2、知识点纪要

本段代码主要涉及的有①几何模型的变形vtkWarpTo

二:代码及注释

python 复制代码
import vtkmodules.vtkRenderingOpenGL2
import vtkmodules.vtkInteractionStyle
from vtkmodules.vtkCommonColor import vtkNamedColors
from vtkmodules.vtkFiltersCore import vtkTubeFilter
from vtkmodules.vtkFiltersSources import vtkLineSource
from vtkmodules.vtkFiltersGeneral import vtkWarpTo
from vtkmodules.vtkRenderingCore import (
    vtkActor,
    vtkDataSetMapper,
    vtkRenderWindow,
    vtkRenderWindowInteractor,
    vtkRenderer
)

def main():
    colors = vtkNamedColors()

    lineSource = vtkLineSource()
    lineSource.SetPoint1(0, 0, 0)
    lineSource.SetPoint2(0, 1, 0)
    lineSource.SetResolution(20)
    lineSource.Update()

    tubeFilter = vtkTubeFilter()
    tubeFilter.SetInputConnection(lineSource.GetOutputPort())
    tubeFilter.SetRadius(0.01)  # 设置生成的圆柱体/管子的横截面半径是0.01个单位长度
    tubeFilter.SetNumberOfSides(50)
    tubeFilter.Update()

    """
    vtkWarpTo  是vtk中一个几何变换的过滤器
    它可以把输入的点云或模型**"拉向"一个指定的点或方向**,相当于对整个几何体做收缩、伸展或弯曲形变
    它可以模拟一种"磁性吸引"或"拉伸到目标点"的效果
    主要有两种模式:
    ①它可以模拟一种"磁性吸引"或"拉伸到目标点"的效果
    ②沿着指定方向移动(DirectionMode)
    """
    warpTo = vtkWarpTo()
    warpTo.SetInputConnection(tubeFilter.GetOutputPort())
    warpTo.SetPosition(10, 1, 0)  # 指定"目标点"的坐标(即你要拉向的点)
    warpTo.SetScaleFactor(5)  # 设置形变强度,值越大,拉得越"狠"
    warpTo.AbsoluteOn()  # 位移相对于数据集的原点进行,所有的点都会向同一个方向偏移
    #warpTo.AbsoluteOff()  # 位移相对于该点的当前位置进行计算,会导致每个点偏移到不同的方向

    mapper = vtkDataSetMapper()
    mapper.SetInputConnection(warpTo.GetOutputPort())
    mapper.ScalarVisibilityOff()

    actor = vtkActor()
    actor.SetMapper(mapper)
    actor.GetProperty().SetColor(colors.GetColor3d('Gold'))
    renderer = vtkRenderer()
    renderWindow = vtkRenderWindow()
    renderWindow.AddRenderer(renderer)
    renderWindowInteractor = vtkRenderWindowInteractor()
    renderWindowInteractor.SetRenderWindow(renderWindow)

    renderer.SetBackground(colors.GetColor3d('Green'))
    renderer.AddActor(actor)

    renderWindow.SetWindowName('WarpTo')
    renderWindow.Render()

    renderWindowInteractor.Initialize()
    renderWindowInteractor.Start()

if __name__ == '__main__':
    main()
相关推荐
肖永威7 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
TechWJ7 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
枷锁—sha7 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
abluckyboy8 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
喵手8 小时前
Python爬虫实战:构建各地统计局数据发布板块的自动化索引爬虫(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集数据csv导出·采集各地统计局数据发布数据·统计局数据采集
天天爱吃肉82189 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
m0_715575349 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
甄心爱学习9 小时前
【leetcode】判断平衡二叉树
python·算法·leetcode
深蓝电商API9 小时前
滑块验证码破解思路与常见绕过方法
爬虫·python
Ulyanov9 小时前
Pymunk物理引擎深度解析:从入门到实战的2D物理模拟全攻略
python·游戏开发·pygame·物理引擎·pymunk