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

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
        

运行结果:

 

posted on 2012-12-18 20:35  |残阳|露  阅读(3884)  评论(0编辑  收藏  举报

导航