zoukankan      html  css  js  c++  java
  • 向量旋转

    // 向量v0沿着Y轴旋转45度得到v1
    
    Vector3 v0;
    
    Vector3 v1 = Quaternion.AngleAxis(45, Vector3.up) * v0;
    

      

    // 某游戏物体绕Y轴旋转30度得到的新Quaternion
    Quaternion rotation = Quaternion.Euler(0f,30f,0f) * Target.rotation;
    
    // 沿着Target的X轴延伸10米求目标点的3D坐标
    Vector3 newPos = Target.position + rotation * new Vector3(10f,0f,0f);
    

      

    // 物体自身正前方5米距离的点的坐标
    	private float distance = 5f;
    	void Update () 
    	{
    		Quaternion r= transform.rotation;
    		Vector3 f0 =  (transform.position  + (r *Vector3.forward) * distance);
    		Debug.DrawLine(transform.position,f0,Color.red);
    	}
    

      

    // 某坐标vo沿着某个方向距离5米得到的新坐标v1
    
    Vector3 vo;
    Vector3 direction ;// 此为单位向量
    
    Vector3 v1 = vo + direction * 5f;
    

      

    学习链接 : http://www.xuanyusong.com/archives/1977

    写在前面的话,前两天有个朋友在QQ上问我 如何获取主角面朝方向一定区域中的敌人对象。这个命题看似简单,其实里面蕴含了很多数学方面的东西。今天刚好有时间我就彻底的把这个疑问写在博客中。希望可以帮助到他。

    在上代码之前请大家跟我先做几个简单的练习题,角度向量的计算一定要学会,不然后面的东西会很难懂。

    1.已知3D坐标,和一个旋转角度,以及一段距离,求目标点的3D坐标。

    已知当前点为Target,目标点沿着Target的Y轴旋转30度,沿着Target的X轴延伸10米求目标点的3D坐标?

     输出结果 :新坐标 (8.7, 0.0, -5.0) 当前坐标 (0.0, 0.0, 0.0)两点之间的距离 10。

     2.已知3D模型的角度求它的向量。

    已知3D模型Target,Y轴旋转30度后向前平移。

     3.已知一个目标点,让模型朝着这个目标点移动。

    这是一个比较简单的例子,大家应该都能看明白。

    这里我要说的就是Vector3.forward ,它等价与 new Vector3(0,0,1);它并不是一个坐标,它是一个标准向量,方向是沿着Z轴向前。这样平移一次的距离就是1米, 如果Vector3.forward * 100那么一次平移的距离就是100米。 

    在看看下面这段代码

     用向量减去一个向量求出它们的差值,normalized 是格式化向量,意思是把它们之间向量格式化到1米内。这样就可以更加精确的计算一次平移的距离了 vecn *0.1f 就标示一次平移1分米,蛤蛤。

     向量不仅可以进行X Y Z轴的移动,同样可以进行旋转 ,下面这段代码就是让向量沿着Y轴旋转30度。

    如果上述三道简单的练习题 你都能了然于心的话,那么本文最大的难题我相信也不会是什么难事,继续阅读吧。

    假设我们需要计算主角面前5米内所有的对象时。以主角为圆心计算面前5米外的一个点,为了让大家看清楚我现将这条线绘制出来。

    如下图所,我们已经将这两个点计算出来了。此时你可以动态的编辑主角Y轴的坐标,这个点永远都是沿着主角当前角度面前5米以外的点。

    Unity3D研究院之主角面朝方向一定区域内对象角度计算(四十五) - 雨松MOMO程序研究院 - 1

    接下来,我们需要计算主角面前的一个发散性的角度。假设主角看到的是向左30度,向右30度在这个区域。

    如下图所示,这时主角面前的区域就计算出来了。看起来就是两个三角形之间的区域。

    Unity3D研究院之主角面朝方向一定区域内对象角度计算(四十五) - 雨松MOMO程序研究院 - 2

    最后就是简单的套用公式,计算一个点是否在三角形内,在本文中就是计算敌人的点是否在面前的这两个三角形内。

    如下图所示,如果箱子对象是主角的视野中就会检测到。 

    Unity3D研究院之主角面朝方向一定区域内对象角度计算(四十五) - 雨松MOMO程序研究院 - 3

    注意,上图中我的视野选择了两个三角形,如果你需要视野目标点是椭圆形的话,那么可以多设置一些三角形。但是这样就会非常消耗效率,我觉得这里完全可以使用1个三角形,,只是正对的目标点会出现一些偏差,影响其实并不会很大。如下图所示

    Unity3D研究院之主角面朝方向一定区域内对象角度计算(四十五) - 雨松MOMO程序研究院 - 4

    代码简单的修改一下即可。

    上面我们介绍了三角形判断,当然也可以通过矩形来判断是否相交。。

    Unity3D研究院之主角面朝方向一定区域内对象角度计算(四十五) - 雨松MOMO程序研究院 - 5

    代码:

    如果大家看了这篇文章后发现在你的项目中还有一些比较麻烦的角度与向量的算法,欢迎在下面留言给我,如果我有时间我会第一时间把方法贴在博客中。互相学习互相进步,加油!哇咔咔。。

    马上过年了,雨松MOMO在这里祝福大家2013年幸幸福福的过日子,嘿嘿。

    2013年4月补充

    感谢楼下朋友给我的留言。, 我在补充一下这篇博客。

    Unity3D研究院之主角面朝方向一定区域内对象角度计算(四十五) - 雨松MOMO程序研究院 - 6

    这里我以角色左右个30度。 这样就可以根据两个模型的距离以及角度来判断了。。

  • 相关阅读:
    CodeSmith注册错误的解决方法
    我是“坚守者”还是"背叛者"?
    拿什么留住你,我的程序员
    去除HTML代码得函数
    页面之间传递参数得几种方法
    nhibernate source code analyzed (abstract classes in nhibernate2.0)
    Web 2.0时代RSS的.Net实现
    Visual Studio.net 2003安装提示重启问题
    开放思路,综合考虑,心胸开阔,做一个合格的项目经理
    了解实际开发中 Hashtable 的特性原理 .NET, JAVA, PHP
  • 原文地址:https://www.cnblogs.com/dabiaoge/p/4489280.html
Copyright © 2011-2022 走看看