位置: 编程技术 - 正文

rotation 与vector3乘积关系

编辑:rootadmin

推荐整理分享rotation 与vector3乘积关系,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

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

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

双击代码全选usingUnityEngine; usingSystem.Collections; publicclassTest : MonoBehaviour { publicTransform Target; voidLateUpdate () { Quaternion rotation = Quaternion.Euler(0f,f,0f) * Target.rotation; Vector3 newPos = rotation * newVector3(f,0f,0f); Debug.DrawLine(newPos,Vector3.zero,Color.red); Debug.Log("newpos " &#; newPos &#;" nowpos " &#; Target.position &#; " distance " &#; Vector3.Distance(newPos,Target.position)); } }

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

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

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

双击代码全选usingUnityEngine; usingSystem.Collections; publicclassTest : MonoBehaviour { publicTransform Target; voidLateUpdate () { if(Input.GetMouseButton(0)) { Quaternion rotation = Quaternion.Euler(0f,f,0f) * Target.rotation; Vector3 newPos = rotation * Vector3.forward; Target.Translate(newPos.x,newPos.y,newPos.z); } } }

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

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

双击代码全选Target.transform.LookAt(newVector3 (f,f,f)); Target.Translate(Vector3.forward);

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

在看看下面这段代码

双击代码全选Vector3 vecn = (TargetCube.position - Target.position).normalized; Target.Translate(vecn *0.1f);rotation 与vector3乘积关系

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

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

双击代码全选Vector3 vecn = (TargetCube.position - Target.position).normalized; vecn = Quaternion.Euler(0f,f,0f) * vecn; Target.Translate(vecn *0.1f);

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

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

双击代码全选privatefloatdistance = 5f; voidUpdate () { Quaternion r= transform.rotation; Vector3 f0 = (transform.position &#; (r *Vector3.forward) * distance); Debug.DrawLine(transform.position,f0,Color.red); }

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

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

双击代码全选privatefloatdistance = 5f; voidUpdate () { Quaternion r= transform.rotation; Vector3 f0 = (transform.position &#; (r *Vector3.forward) * distance); Debug.DrawLine(transform.position,f0,Color.red); Quaternion r0= Quaternion.Euler(transform.rotation.eulerAngles.x,transform.rotation.eulerAngles.y - f,transform.rotation.eulerAngles.z); Quaternion r1= Quaternion.Euler(transform.rotation.eulerAngles.x,transform.rotation.eulerAngles.y &#; f,transform.rotation.eulerAngles.z); Vector3 f1 = (transform.position &#; (r0 *Vector3.forward) * distance); Vector3 f2 = (transform.position &#; (r1 *Vector3.forward) * distance); Debug.DrawLine(transform.position,f1,Color.red); Debug.DrawLine(transform.position,f2,Color.red); Debug.DrawLine(f0,f1,Color.red); Debug.DrawLine(f0,f2,Color.red); }

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

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

双击代码全选usingUnityEngine; usingSystem.Collections; publicclassMyTest : MonoBehaviour { publicTransform cube; privatefloatdistance = 5f; voidUpdate () { Quaternion r= transform.rotation; Vector3 f0 = (transform.position &#; (r *Vector3.forward) * distance); Debug.DrawLine(transform.position,f0,Color.red); Quaternion r0= Quaternion.Euler(transform.rotation.eulerAngles.x,transform.rotation.eulerAngles.y - f,transform.rotation.eulerAngles.z); Quaternion r1= Quaternion.Euler(transform.rotation.eulerAngles.x,transform.rotation.eulerAngles.y &#; f,transform.rotation.eulerAngles.z); Vector3 f1 = (transform.position &#; (r0 *Vector3.forward) * distance); Vector3 f2 = (transform.position &#; (r1 *Vector3.forward) * distance); Debug.DrawLine(transform.position,f1,Color.red); Debug.DrawLine(transform.position,f2,Color.red); Debug.DrawLine(f0,f1,Color.red); Debug.DrawLine(f0,f2,Color.red); Vector3 point = cube.position; if(isINTriangle(point,transform.position,f1,f0) || isINTriangle(point,transform.position,f2,f0) ) { Debug.Log("cube in this !!!"); }else { Debug.Log("cube not in this !!!"); } } private floattriangleArea(floatv0x,floatv0y,floatv1x,floatv1y,floatv2x,floatv2y) { returnMathf.Abs((v0x * v1y &#; v1x * v2y &#; v2x * v0y - v1x * v0y - v2x * v1y - v0x * v2y) / 2f); } boolisINTriangle(Vector3 point,Vector3 v0,Vector3 v1,Vector3 v2) { floatx = point.x; floaty = point.z; floatv0x = v0.x; floatv0y = v0.z; floatv1x = v1.x; floatv1y = v1.z; floatv2x = v2.x; floatv2y = v2.z; floatt = triangleArea(v0x,v0y,v1x,v1y,v2x,v2y); floata = triangleArea(v0x,v0y,v1x,v1y,x,y) &#; triangleArea(v0x,v0y,x,y,v2x,v2y) &#; triangleArea(x,y,v1x,v1y,v2x,v2y); if(Mathf.Abs(t - a) <= 0.f) { returntrue; }else { returnfalse; } } }

Unity3D 获取控件四个角在屏幕上的坐标 Vector3[]corners=newVector3[4];gameObject.GetComponentRectTransform().GetWorldCorners(corners);foreach(varitemincorners){Debug.Log(item);}出来的坐标的顺序是左下、左上、右上、右下

Metaio SDK 6.0.2自带Example自己实现(三) 前言:本文实现的是Example中的TutorialEdgeBasedInitialization功能,如果Metaio不知道怎么在Unity中进行简单的开发,请参考我的另一篇文章Metaio在Unity中的简单

[置顶] unity汤姆猫自动检测录音,不说话自动播放 unity汤姆猫自动检测录音,不说话自动播放脚本usingSystem.Collections.Generic;usingSystem.Linq;usingUnityEngine;[RequireComponent(typeof(AudioSource))]publicclassMicrophoneInput:MonoBe

标签: rotation 与vector3乘积关系

本文链接地址:https://www.jiuchutong.com/biancheng/369374.html 转载请保留说明!

上一篇:Unity协同程序(unity协程yield)

下一篇:Unity3D 获取控件四个角在屏幕上的坐标(unity获取组件的方法)

  • 账面价值大于计税基础
  • 所得税会计与财务会计比较研究
  • 员工借款业务流程
  • 房地产企业的会计核算
  • 所得税汇算清缴补税的会计处理
  • 个税补缴纳
  • 小规模纳税人免征增值税政策
  • 小规模纳税人无进项票怎么办
  • 手撕汽车票在哪里弄到
  • 预缴增值税怎么填表
  • 所得税汇算清缴退税会计分录怎么做
  • 烟叶收购方案制定步骤
  • 购入农产品的增值税率
  • 企业购买商品发生的商业 应该计入财务费用吗
  • 用友t3固定资产计提折旧后没有凭证
  • 营改增对建筑行业税负的影响
  • 外经证是先开票还是先预缴税款
  • 差额纳税计算方法
  • 报销单大写金额填写格式1000
  • 公司收境外汇款
  • 金税盘密码忘记了打客服有用吗?
  • 在产品的成本
  • 应交税费的借方表示什么
  • 长期股权投资核算的成本法与权益法的主要差别有哪些
  • 货款已经收到
  • 企业注销时往来账目挂账怎么处理
  • 动态投资回收期名词解释
  • 税控服务费政策
  • 花卉盆景苗木
  • 充值会员卡销售话语
  • php面向对象详解
  • macbookpro安装dmg
  • 投资利润率用什么表示
  • 一叶兰的养殖方法和注意事项有哪些
  • ghoststartservice.exe是什么进程 有什么作用 ghoststartservice进程查询
  • 营改增后固定资产报废处置收入计税
  • 待摊费用和预提费用属于什么账户
  • PHP:imagecreatefromjpeg()的用法_GD库图像处理函数
  • 土地使用权转让法律规定
  • yii2框架结构
  • php批量上传图片到服务器
  • php统计系统
  • 卖出回购证券的钱怎么算
  • 个体工商户超过100万怎么缴税
  • 哪些发票可以抵企业所得税
  • 营业执照更换法人需要哪些手续
  • 酒店收取电费合理吗
  • python合并集合
  • 企业购买理财产品收益要交税吗
  • 小规模纳税人月销售额超过10万怎么交税
  • 固定资产原价和账面价值的区别
  • 计提投资性房地产折旧会计科目
  • 材料成本差异怎么做分录
  • 暂估收入的会计分录怎么写
  • 电子商务交易类应用发展现状
  • 预期收益率怎么用市场预期收益率算
  • 用于研发购买的云服务器应计入研发费用直接投入里吗
  • 轿车折旧年限为几年
  • windows10怎样安装
  • 新买的读卡器不读卡,提示放入驱动盘
  • centos怎么样
  • xp系统打不开电脑
  • win1020h2正式版
  • 歌词特效是怎么弄的
  • windows8.1版本区别
  • 基于HTML5和CSS3的响应式Web的设计与实现
  • angular指令详解
  • 批处理执行bat文件
  • 如何使用css设置元素的层叠效果?
  • django图片加载不出来
  • unity动画教程
  • 安卓中adapter
  • 学习JavaScript事件流和事件处理程序
  • jquery事件处理有哪些
  • js初级教程
  • js按下回车键时提交
  • 运输公司抵扣
  • 代扣代缴企业所得税手续费
  • 芜湖地税微机编码是什么
  • 国家税务总局年底结算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设