码迷,mamicode.com
首页 > Windows程序 > 详细

WPF中3D旋转的实现

时间:2018-10-24 19:52:34      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:width   HERE   rev   cto   class   代码   sdn   temp   eve   

原文:WPF中3D旋转的实现

关于3D旋转的原理,请看Daniel Lehenbauer的文章

《Rotating the Camera with the Mouse》

http://viewport3d.com/trackball.htm

?

里面非常清楚的讲解了原理和方法,很受用。

?

相关代码:

?

2.1 Finding the Point on the Sphere

private Vector3D ProjectToTrackball(Double width, Double height, Point point)
??????? {
??????????? Double x = point.X / (width / 2);??? // Scale so bounds map to [0,0] - [2,2]
??????????? Double y = point.Y / (height / 2);

??????????? x = x - 1;?????????????????????????? // Translate 0,0 to the center
??????????? y = 1 - y;?????????????????????????? // Flip so +Y is up instead of down

??????????? Double z2 = 1 - x * x - y * y;?????? // z^2 = 1 - x^2 - y^2
??????????? Double z = z2 > 0 ? Math.Sqrt(z2) : 0;
??????????? return new Vector3D(x, y, z);
??????? }

?

2.2 Rotating Between the Points

??????? private void Rotate(Point currentPosition)
??????? {
??????????? Vector3D currentPosition3D = ProjectToTrackball(EventSource.ActualWidth, EventSource.ActualHeight, currentPosition);

??????????? Vector3D axis = Vector3D.CrossProduct(_previousRotPosition3D, currentPosition3D);
??????????? Double angle = Vector3D.AngleBetween(_previousRotPosition3D, currentPosition3D);

??????????? Rotate(axis, angle);

??????????? _previousRotPosition3D = currentPosition3D;
??????? }

?

??????? private void Rotate(Vector3D axis, Double angle)
??????? {
??????????? Quaternion delta = new Quaternion(axis, -angle * _rotScale);

??????????? Quaternion q = new Quaternion(_axisAngleRotation3D.Axis, _axisAngleRotation3D.Angle);

??????????? q *= delta;

??????????? Vector3D zeorVec = new Vector3D(0.0, 0.0, 0.0);
??????????? if (Vector3D.Equals(q.Axis, zeorVec))
??????????????? return;

??????????? _axisAngleRotation3D.Axis = q.Axis;
??????????? _axisAngleRotation3D.Angle = q.Angle;
??????? }

WPF中3D旋转的实现

标签:width   HERE   rev   cto   class   代码   sdn   temp   eve   

原文地址:https://www.cnblogs.com/lonelyxmas/p/9844859.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!