vtkTransform 空间变换

图像处理与VTK/ITK文章列表

VTK笔记——空间几何变换(Transform),平移、旋转和缩放

其中注意,在进行旋转和缩放操作时,都需要先将该polydata整体平移回它的中心位置,然后再进行旋转和缩放操作,最后再将其移回到原来的位置处。

vtkSmartPointer<vtkTransform> transform = vtkSmartPointer<vtkTransform>::New();
	vtkSmartPointer<vtkPolyData> polyData = vtkSmartPointer<vtkPolyData>::New();
	box->GetPolyData(polyData);
	Point3D centerPoint(polyData->GetPoints()->GetPoint(14));//最后一个点是中心点,一共15个点;围绕中心轴旋转一个弧度
	transform->Translate(centerPoint.x, centerPoint.y, centerPoint.z);//旋转和缩放都是围绕原点进行的,所以旋转需要先把坐标原点设置到物体中心
	transform->RotateY(angle);//这个变换第二步:将物体绕Y轴旋转一个角度angle
	transform->Translate(-centerPoint.x, -centerPoint.y, -centerPoint.z);//旋转完毕,需要把坐标原点放回原处

	box->SetTransform(transform);//立方体空间位置变换

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
抱歉,我之前给出的代码有误。在 VTK 中,`vtkActor` 并没有直接提供 `GetMatrixTransform` 方法来获取变换矩阵。相反,我们可以通过以下步骤来实现 `vtkActor` 绕自身旋转: ```csharp using System; using Kitware.VTK; class Program { static void Main(string[] args) { // 创建一个球体源 vtkSphereSource sphereSource = vtkSphereSource.New(); // 创建一个球体的 mapper vtkPolyDataMapper mapper = vtkPolyDataMapper.New(); mapper.SetInputConnection(sphereSource.GetOutputPort()); // 创建一个球体的 actor vtkActor actor = vtkActor.New(); actor.SetMapper(mapper); // 创建一个渲染器 vtkRenderer renderer = vtkRenderer.New(); renderer.AddActor(actor); // 创建一个渲染窗口 vtkRenderWindow renderWindow = vtkRenderWindow.New(); renderWindow.AddRenderer(renderer); // 创建一个交互式渲染窗口 vtkRenderWindowInteractor renderWindowInteractor = vtkRenderWindowInteractor.New(); renderWindowInteractor.SetRenderWindow(renderWindow); // 将旋转器添加到 actor 上 vtkTransform transform = vtkTransform.New(); actor.SetUserTransform(transform); // 设置定时器来触发旋转动作 vtkCallbackCommand callback = vtkCallbackCommand.New(); callback.SetCallback(RotateActor); callback.SetClientData(actor); renderWindowInteractor.AddObserver("TimerEvent", callback); // 设置定时器间隔(毫秒) int timerInterval = 10; renderWindowInteractor.CreateRepeatingTimer(timerInterval); // 开始交互操作 renderWindow.Render(); renderWindowInteractor.Start(); // 清理资源 sphereSource.Dispose(); mapper.Dispose(); actor.Dispose(); renderer.Dispose(); renderWindow.Dispose(); renderWindowInteractor.Dispose(); transform.Dispose(); callback.Dispose(); } // 旋转 actor 的回调函数 static void RotateActor(vtkObject sender, vtkObjectEventArgs e) { vtkActor actor = (vtkActor)e.Data; vtkTransform transform = actor.GetUserTransform(); // 设置旋转中心为 actor 的中心点 double[] center = actor.GetCenter(); transform.Translate(-center[0], -center[1], -center[2]); // 设置旋转角度(弧度) double angle = 0.01; // 绕 Z 轴旋转 transform.RotateZ(angle); // 还原旋转中心 transform.Translate(center[0], center[1], center[2]); actor.SetUserTransform(transform); } } ``` 在这个修改后的代码中,我们使用了 `vtkTransform` 对象来实现绕自身旋转。首先,我们将旋转中心设置为 actor 的中心点,然后对 `vtkTransform` 进行平移、旋转操作,最后再将旋转中心还原。这样就实现了 actor 绕自身旋转的效果。 希望这次能对您有所帮助!如果您有任何进一步的问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

C++程序员Carea

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值