您的位置:首页 > 其它

vtk类之vtkTransform 和 vtkTransformFilter:对可视化管线中的点坐标进行齐次坐标转换

2012-12-18 20:35 239 查看
vtkTransform

描述通过一个 4 × 4 矩阵的线性变换
VtkTransform 可以用于描述线性的完整范围 (也称为仿射) 坐标转换在三个维度,内部表示为 4 x 4 齐次变换矩阵。当您创建新的 vtkTransform 时,它总是初始化为标识转换。
SetInput() 方法允许您设置另一种转换,替换身份转换。有一个管道机制来确保当修改输入,则当前转换将相应更新。这种管道机制也支持由 Concatenate() 方法。
在 PostMultiply 模式下,额外的转换将由当前矩阵表示任何转换之后发生。
此类执行所有业务在右手坐标系中用右手旋转。剩下的一些图形库使用左手坐标系统和旋转。

vtkTransformFilter 是一个筛选器来变换的点的坐标和关联的点法线向量。其他点数据被通过筛选器。
一种替代方法是使用 vtkActor 的方法来缩放、 旋转和平移对象。这两种方法之间的区别是 vtkActor 的转换只是影响那里呈现对象的 (通过图形管线),而 vtkTransformFilter 实际修改可视化管线中的点坐标。这是必要的需要作为输入的点的坐标的某些对象 (例如,vtkProbeFilter)。

基本方法:
Identity() 把vtkTransform重置成标准状态。
   Elements:
      1 0 0 0
      0 1 0 0
      0 0 1 0
      0 0 0 1

GetPosition ()从该矩阵中,返回位置点 如原始矩阵RotateY(90),得到位置(0.0, 0.0, 0.0)

GetOrientationWXYZ ()从矩阵中,返回角度+ 方向量 如原始矩阵RotateY(90),(90.0, 0.0, 1.0, 0.0)

RotateX,RotateY,RotateZ 该方法,分别围绕X,y,z 轴,顺时针旋转一定角度。如 RotateZ(30) 则,GetOrientationWXYZ() == (29.999999999999993, 0.0, 0.0, 1.0)

Translate (double x, double y, double z)平移矩阵。

    tf.Translate(3, 4, 5)
    tf.RotateZ(90)

    print tf.GetPosition (), tf.GetOrientation(),tf.GetOrientationWXYZ()

    结果:(3.0, 4.0, 5.0) (90.0, 0.0, 0.0, 1.0)

  

例子:

#-*- coding: UTF-8 -*-
#-------------------------------------------------------------------------------
# Name:        模块2
# Purpose:
#
# Author:      ankier
#
# Created:     18-12-2012
# Copyright:   (c) Administrator 2012
# Licence:     <your licence>
#-------------------------------------------------------------------------------

from ActorFactory import ActorFactory

from vtk import *
## @detal 地球类
class TransformActorFactory(ActorFactory):
def __init__(self):
ActorFactory.__init__(self)
self.__ElevationFilter = vtkElevationFilter()

self.__ElevationFilter.SetLowPoint(0, 0, -0.5)
self.__ElevationFilter.SetHighPoint(0, 0, 0.5)

def _MakeActors(self):
sphere = vtkSphereSource()
sphere.SetThetaResolution(8)
sphere.SetPhiResolution(8)
sphere.SetRadius(20)
transform = vtkTransform()
transform.Scale(0.5, 1.5, 2.0)
transformFilter = vtkTransformFilter()
transformFilter.SetInput(sphere.GetOutput())
transformFilter.SetTransform(transform)

self.__ElevationFilter.SetInput(transformFilter.GetOutput())

polyDataMapper = vtkPolyDataMapper()
polyDataMapper.SetInput(self.__ElevationFilter.GetOutput())
actor = self._NewActor()
actor.SetMapper(polyDataMapper)
#actor.GetProperty().SetColor((0.5, 0.7, 0.2))

return [actor]

def __del__(self):
del self.__EarthSource


运行结果:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: