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()
相关推荐
a11177621 分钟前
MonoGS 在 Jetson Orin Nano 上的部署与性能测试
python·开源·torch·cv
dgaf21 分钟前
DX12 快速教程(17) —— 立体图标与合并渲染
c语言·c++·3d·图形渲染·d3d12
偶尔微微一笑26 分钟前
智能体四大核心模块揭秘
python
2301_8159019744 分钟前
SQL如何将多行记录聚合成逗号分隔字符串_GROUP_CONCAT技巧
jvm·数据库·python
西索斯1 小时前
Claude API 报 529 Overloaded 怎么办?3 种方案实测,最后一种最省心
python·claude
Flittly1 小时前
【LangGraph新手村系列】(3)PostgreSQL 持久化检查点:让状态跨越进程与重启
人工智能·python·langchain
.柒宇.1 小时前
FastAPI 基础指南:从入门到实战
开发语言·python·fastapi
魔都吴所谓1 小时前
【Python】从扁平参数到层级架构:基于Python argparse构建校园管理CLI工具实战
python·编程语言
zjy277771 小时前
Layui tab选项卡如何动态根据ID值进行程序化切换
jvm·数据库·python
m0_602857761 小时前
Redis如何修复槽位分配重叠的脏状态_使用redis-cli --cluster fix工具扫描并修复不一致的Slot
jvm·数据库·python