Vector3.Dot 方位判断

2024-03-30 16:18
文章标签 判断 vector3 dot 方位

本文主要是介绍Vector3.Dot 方位判断,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Dot函数经常被用在方位判断,放上代码和结果。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;//UTF8 说明
public class dottest : MonoBehaviour
{[SerializeField] Text txtShow;[SerializeField] Transform me;  //胶囊[SerializeField] Transform point; //目标点// Update is called once per framevoid Update(){Vector3 target_dir = (point.position - me.position).normalized;//Debug.DrawLine(me.position, target_dir * 10f, Color.blue,0.1f);float dot = Vector3.Dot(me.forward, target_dir);float dot2 = Vector3.Dot(point.right, target_dir);txtShow.text = "Dot(me.forward, target_dir) = " + dot.ToString("F1")+"\n"+"Dot(me.right, target_dir) = " + dot2.ToString("F1");}
}

如图:我们看蓝色的第一行输出:Dot参数1是胶囊的forward,参数2是红色球的方向。
当目标在胶囊正前方,Dot得到正数(0~1),正对着球时候最大为1。反之就是负数。

//当目标在胶囊正前方,Dot得到1。
在这里插入图片描述

//当目标在胶囊正右方,Dot得到0。
在这里插入图片描述
//当目标在胶囊正后方,Dot得到-1。
在这里插入图片描述

//当目标在胶囊正左方,Dot得到0。
在这里插入图片描述
下面是GIF图,来观测下数值变化。
请添加图片描述
我们可以看到两个向量方向相同就是1,夹角越大就越趋近-1。

这样我们就可以知道目标是在后面还是前面。
但是左边和右边如何区分呢?
这里我还做了一个right和dir的Dot的数值。就是第二行蓝色输出。
在胶囊的右侧就是正数,左侧就是负数。

参数1和参数2的向量位置可以互换,不用考虑先后问题。
这个Dot函数被应用在方位指向等。

这篇关于Vector3.Dot 方位判断的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/861965

相关文章

poj 3259 uva 558 Wormholes(bellman最短路负权回路判断)

poj 3259: 题意:John的农场里n块地,m条路连接两块地,w个虫洞,虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts。 任务是求你会不会在从某块地出发后又回来,看到了离开之前的自己。 判断树中是否存在负权回路就ok了。 bellman代码: #include<stdio.h>const int MaxN = 501;//农场数const int

zoj 1721 判断2条线段(完全)相交

给出起点,终点,与一些障碍线段。 求起点到终点的最短路。 枚举2点的距离,然后最短路。 2点可达条件:没有线段与这2点所构成的线段(完全)相交。 const double eps = 1e-8 ;double add(double x , double y){if(fabs(x+y) < eps*(fabs(x) + fabs(y))) return 0 ;return x + y ;

POJ1269 判断2条直线的位置关系

题目大意:给两个点能够确定一条直线,题目给出两条直线(由4个点确定),要求判断出这两条直线的关系:平行,同线,相交。如果相交还要求出交点坐标。 解题思路: 先判断两条直线p1p2, q1q2是否共线, 如果不是,再判断 直线 是否平行, 如果还不是, 则两直线相交。  判断共线:  p1p2q1 共线 且 p1p2q2 共线 ,共线用叉乘为 0  来判断,  判断 平行:  p1p

Codeforces Round #113 (Div. 2) B 判断多边形是否在凸包内

题目点击打开链接 凸多边形A, 多边形B, 判断B是否严格在A内。  注意AB有重点 。  将A,B上的点合在一起求凸包,如果凸包上的点是B的某个点,则B肯定不在A内。 或者说B上的某点在凸包的边上则也说明B不严格在A里面。 这个处理有个巧妙的方法,只需在求凸包的时候, <=  改成< 也就是说凸包一条边上的所有点都重复点都记录在凸包里面了。 另外不能去重点。 int

【408DS算法题】039进阶-判断图中路径是否存在

Index 题目分析实现总结 题目 对于给定的图G,设计函数实现判断G中是否含有从start结点到stop结点的路径。 分析实现 对于图的路径的存在性判断,有两种做法:(本文的实现均基于邻接矩阵存储方式的图) 1.图的BFS BFS的思路相对比较直观——从起始结点出发进行层次遍历,遍历过程中遇到结点i就表示存在路径start->i,故只需判断每个结点i是否就是stop

linux 判断某个命令是否安装

linux 判断某个命令是否安装 if ! [ -x "$(command -v git)" ]; thenecho 'Error: git is not installed.' >&2exit 1fi

Vector3 三维向量

Vector3 三维向量 Struct Representation of 3D vectors and points. 表示3D的向量和点。 This structure is used throughout Unity to pass 3D positions and directions around. It also contains functions for doin

shell循环sleep while例子 条件判断

i=1# 小于5等于时候才执行while [ ${i} -le 5 ]doecho ${i}i=`expr ${i} + 1`# 休眠3秒sleep 3doneecho done 参考 http://c.biancheng.net/cpp/view/2736.html

(二)Vue.js 条件判断 20170818

条件判断 (一)v-if  使用 概念:v-if  其实说白了就是类似于java里面的判断语句,在vue.js中经常跟 template一起使用  1.jsp 代码 <template v-if="false"><label>符亮星</label><br/><label>职业爱好:编码制造方便</label></template> 设置为false时就会隐藏掉 结果图

如何判断一个数组中是否包含一个字符或字符串

第一种方法:遍历数组 String[] arr1 = {"1","2","3","4","6","7"}; for (int i = 0; i < arr1.length; i++) { if("5".equals(arr1[i])) { System.out.println("包含"); }else { System.out.println("不包含"); } } 第二种方法:先把数组