WPF 3D 模型旋转

简介: 原文:WPF 3D 模型旋转    WPF 是 Microsoft 在 Framework3.0 中支持的一种技术,它能作出很绚丽的界面,同时它也支持3D的操作。在3D操作主要包括平移(Translate)、旋转(Rotation)、缩放(Scale)。
原文: WPF 3D 模型旋转

    WPF 是 Microsoft 在 Framework3.0 中支持的一种技术,它能作出很绚丽的界面,同时它也支持3D的操作。在3D操作主要包括平移(Translate)、旋转(Rotation)、缩放(Scale)。

    本文中主要是讨论3D 模型的旋转。对于旋转操作可以采用旋转模型,通过模型的Transform属性来完成;也可以通过第一人称的摄像机通过旋转摄像机来完成旋转。当然处于对性能的考虑本文选择第二种方法的方式来旋转模型。

    完成摄像机的旋转需要通过以下几个步骤:

    1. 对于不同的模型,设置摄像机的位置(Position),远焦距(FarPlaneDistance),近焦距(NearPlaneDistance),看的方向(LookDirection),向上的向量(UpDirection)。

    2. 旋转围绕的旋转抽和围绕旋转的中心。

    首先,对于不同的模型放入到世界坐标中摄像机的位置肯定会不同。如何确定摄像机的位置呢?在XNA中XNA框架提供了一个SphereBounding的属性来获得模型的外切圆,从而得到了圆心。然而在WPF中却没有发现SphereBounding的身影。不过仔细想想,Microsoft 不可能在XNA中提供了计算外切圆的方法,在WPF中不可能不提供类似的方法。然后我们仔细寻找,你会发现在MeshGeometry3D有一个Bounds的属性,该属性是返回MesheGeometry3D的边界Rect3D。Rect3D表示一个三维矩形,也就是模型的外切矩形。

    对于一个模型很有可能是由多个ModelVisual3D组成,这就预味着要把这些ModelVisual3D的外切矩形合并,好在在Rect3D中提供了Union方法(MSDN: 已重载。 更新指定的 Rect3D 以反映该 Rect3D 与第二个指定 Rect3D 的联合)。最后通过对三维矩形的Size 和 Location 来计算出矩形的中心。

    

View Code
 1 private void UnionRect(ModelVisual3D model, ref Rect3D rect3D)
 2         {
 3             for (int i = 0; i < model.Children.Count; i++)
 4             {
 5                 var child = model.Children[i] as ModelVisual3D;
 6                 UnionRect(child, ref rect3D);
 7 
 8             }
 9             if (model.Content != null)
10                 rect3D.Union(model.Content.Bounds);
11         }

    通过上面获得的中心和矩形的对角线来计算出矩形外切圆的半径。在本例中我们让模型围绕Y轴以自己为中心旋转,所以只需要通过中心点和半径来设置摄像机的Z或者X,通过设置摄像机的X和Z。这样就使得中心点 X,Z在同一个平面中,同时还在同一个圆形中,这样就是的摄像机的旋转围绕着圆点做圆心运动。

    

 public void MeasureModel(ModelVisual3D model)
        {
            var camera = _baseModel.Camera;
            var rect3D = Rect3D.Empty;
            UnionRect(model, ref rect3D);

            _center = new Point3D((rect3D.X + rect3D.SizeX / 2), (rect3D.Y + rect3D.SizeY / 2),
                                  (rect3D.Z + rect3D.SizeZ / 2));

            double radius = (_center - rect3D.Location).Length;
            Point3D position = _center;
            position.Z += radius * 1.2;
            position.X = position.Z;
            camera.Position = position;
            camera.LookDirection = _center - position;
            camera.NearPlaneDistance = radius / 100;
            camera.FarPlaneDistance = radius * 100;
        }

  设置摄像机的相关属性后,接下来就该是对摄像机做旋转操作了。WPF中旋转提供了两个类AxisAngleRotation3D 和 QuaternionRotation3D。本例中我们选择最常用的AxisAngleRotation3D来完成。在AxisAngleRotation3D提供了CenterX,CenterY,CenterZ这几个属性,用来设置旋转围绕的中心,默认的中心点为(0,0,0),本例中为了实现模型以自己为中心旋转,因此我们需要设置旋转中心。

public void Yaw(bool leftRight, double angleDeltaFactor)
        {
            var camera = _baseModel.Camera;
            var axis = new AxisAngleRotation3D(camera.UpDirection, leftRight ? angleDeltaFactor : -angleDeltaFactor);
            var rt3D = new RotateTransform3D(axis) { CenterX = _center.X, CenterY = _center.Y, CenterZ = _center.Z };
            Matrix3D matrix3D = rt3D.Value;
            Point3D point3D = camera.Position;
            Point3D position = matrix3D.Transform(point3D);
            camera.Position = position;
            camera.LookDirection = camera.LookDirection = _center - position;
        }

  源码下载

目录
相关文章
|
算法 C# 图形学
WPF绘制深度不同颜色的3D模型填充图和线框图
原文:WPF绘制深度不同颜色的3D模型填充图和线框图 在机械测量过程中,测量的数据需要进行软件处理。通常测量一个零件之后,需要重建零件的3D模型,便于观察测量结果是否与所测工件一致。
2864 0
|
C# 图形学 传感器
WPF在3D Cad模型中利用TextureCoordinates实现颜色渐变显示偏差值的变化
原文:WPF在3D Cad模型中利用TextureCoordinates实现颜色渐变显示偏差值的变化 注:最近在做3D机械模型重建方面的软件,需要根据光栅传感器采集的数据绘制3D图形,并显示出色差以及填充和线框图。
1022 0
|
C# 索引
好玩的WPF第四弹:用Viewport2DVisual3D实现3D旋转效果
原文:好玩的WPF第四弹:用Viewport2DVisual3D实现3D旋转效果 版权声明:转载请联系本人,感谢配合!本站地址:http://blog.csdn.net/nomasp https://blog.csdn.net/NoMasp/article/details/46567895 效果呢就是这么个效果,但是大家要发挥想象力,比如做成一个可以旋转的按钮等等。
891 0
|
C# Windows 图形学
优化WPF 3D性能
原文:优化WPF 3D性能 Maximize WPF 3D Performance .NET Framework 4.5   As you use the Windows Presentation Foundation (WPF) to build 3D contr...
1316 0
|
C# 小程序
WPF 3D变换应用
原文:WPF 3D变换应用  WPF可以提供的3D模型使我们可以轻松地创建3D实体,虽然目前来看还很有一些性能上的问题,不过对于一些简单的3D应用应该是可取的,毕竟其开发效率高,而且也容易上手。         下面给大家演示的是使用在WPF 3D上实现视角变换,通过鼠标拖动来变换观察视角,通过滚轮来放缩视距。
703 0
|
C#
WPF特效-实现3D足球效果
原文:WPF特效-实现3D足球效果 WPF 实现 3D足球效果,效果图如下:  每个面加载不同贴图。                                                          ...
860 0
|
算法 C# 容器
WPF特效-实现弧形旋转轮播图
原文:WPF特效-实现弧形旋转轮播图        项目遇到,琢磨并实现了循环算法,主要处理循环替换显示问题       (如:12张图组成一个圆弧,但总共有120张图需要呈现,如何在滑动中进行显示块的替换,并毫无卡顿)        处理的自己感觉比较满意,记录一下。
2046 0
|
C#
【C#/WPF】Image图片的Transform变换:平移、缩放、旋转
原文:【C#/WPF】Image图片的Transform变换:平移、缩放、旋转 WPF中图像控件Image的变换属性Transform: 平移 缩放 旋转 即要想实现图片的平移、缩放、旋转,是修改它所在的Image控件的Transform变换属性。
4747 0
|
C#
在WPF中将图片转换成3D图像并可以旋转
原文:在WPF中将图片转换成3D图像并可以旋转 时光偷走的,永远都是我们眼皮底下看不见的珍贵。   https://pan.baidu.com/s/14dk-OU2SR0nxXj2bL4bVpQ 首先先看一下源代码最初的运行效果,是否是自己需要的。
1487 0
|
缓存 .NET 中间件
【WPF】【UWP】借鉴 asp.net core 管道处理模型打造图片缓存控件 ImageEx
原文:【WPF】【UWP】借鉴 asp.net core 管道处理模型打造图片缓存控件 ImageEx 在 Web 开发中,img 标签用来呈现图片,而且一般来说,浏览器是会对这些图片进行缓存的。 比如访问百度,我们可以发现,图片、脚本这种都是从缓存(内存缓存/磁盘缓存)中加载的,而不是再去访问一次百度的服务器,这样一方面改善了响应速度,另一方面也减轻了服务端的压力。
1376 0