预判修改方向

2023-10-20 15:20
文章标签 方向 修改 预判

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

/// <summary>
/// 是否闪避修改方向
/// </summary>
/// <param name="ArmsObject">武器对象</param>
/// <param name="ArmsVelocity">武器线速度</param>
/// <param name="CurrentObject">当前对象</param>
/// <param name="CurrentObjectMoveDir">当前对象移动方向</param>
/// <param name="CurrentObjectMoveSpeed">当前对象移动速度</param>
/// <param name="PrejudgeDistance">预判距离</param>
/// <returns></returns>
public bool IsDodgeChangeDir(GameObject ArmsObject, Vector3 ArmsVelocity, GameObject CurrentObject, Vector3 CurrentObjectMoveDir, float CurrentObjectMoveSpeed, float PrejudgeDistance)
{//(武器对象点)到(当前对象移动方向向量)之间的垂直距离float fProj = Vector3.Dot(ArmsObject.transform.position - CurrentObject.transform.position, CurrentObjectMoveDir.normalized);float PointToLineDistance = Mathf.Sqrt((ArmsObject.transform.position - CurrentObject.transform.position).sqrMagnitude - fProj * fProj);//(武器移动方向的反方向)与(当前对象移动方向的方向)之间的夹角float dot = Vector3.Dot(-ArmsVelocity.normalized, -CurrentObjectMoveDir);//计算武器移动的距离float ArmsObjectMoveLength = Mathf.Sqrt(Mathf.Pow(PointToLineDistance, 2) / (1 - Mathf.Pow(dot, 2)));//Vector3 ArmsVelocityNormalized = ArmsVelocity.normalized;float ArmsObjectSpeed = 0;if (ArmsVelocity.x != 0){ArmsObjectSpeed = ArmsVelocity.x / ArmsVelocityNormalized.x;}else if (ArmsVelocity.z != 0){ArmsObjectSpeed = ArmsVelocity.z / ArmsVelocityNormalized.z;}//武器以(武器移动的速度)的速度在(武器移动的距离)的距离上移动所需时间float t = ArmsObjectMoveLength / ArmsObjectSpeed;//当前对象在规定时间移动后的坐标Vector3 CurrentObjectEndPos = CurrentObject.transform.position + (CurrentObjectMoveDir * CurrentObjectMoveSpeed * t);//武器对象在规定时间移动后的坐标Vector3 ArmsObjectEndPos = ArmsObject.transform.position + ArmsVelocity * t;//(武器对象在规定时间移动后的坐标)与(当前对象在规定时间移动后的坐标)之间的距离float distance = Vector3.Distance(ArmsObjectEndPos, CurrentObjectEndPos);//预判距离if (distance < PrejudgeDistance){Debug.Log("预判距离" + distance);return true;}return false;
}

备注:需要提前检测,例如触发检测
在这里插入图片描述

这篇关于预判修改方向的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

如何在运行时修改serialVersionUID

优质博文:IT-BLOG-CN 问题 我正在使用第三方库连接到外部系统,一切运行正常,但突然出现序列化错误 java.io.InvalidClassException: com.essbase.api.base.EssException; local class incompatible: stream classdesc serialVersionUID = 90314637791991

嵌入式方向的毕业生,找工作很迷茫

一个应届硕士生的问题: 虽然我明白想成为技术大牛需要日积月累的磨练,但我总感觉自己学习方法或者哪些方面有问题,时间一天天过去,自己也每天不停学习,但总感觉自己没有想象中那样进步,总感觉找不到一个很清晰的学习规划……眼看 9 月份就要参加秋招了,我想毕业了去大城市磨练几年,涨涨见识,拓开眼界多学点东西。但是感觉自己的实力还是很不够,内心慌得不行,总怕浪费了这人生唯一的校招机会,当然我也明白,毕业

理解分类器(linear)为什么可以做语义方向的指导?(解纠缠)

Attribute Manipulation(属性编辑)、disentanglement(解纠缠)常用的两种做法:线性探针和PCA_disentanglement和alignment-CSDN博客 在解纠缠的过程中,有一种非常简单的方法来引导G向某个方向进行生成,然后我们通过向不同的方向进行行走,那么就会得到这个属性上的图像。那么你利用多个方向进行生成,便得到了各种方向的图像,每个方向对应了很多

android系统源码12 修改默认桌面壁纸--SRO方式

1、aosp12修改默认桌面壁纸 代码路径 :frameworks\base\core\res\res\drawable-nodpi 替换成自己的图片即可,不过需要覆盖所有目录下的图片。 由于是静态修改,则需要make一下,重新编译。 2、方法二Overlay方式 由于上述方法有很大缺点,修改多了之后容易遗忘自己修改哪些文件,为此我们采用另外一种方法,使用Overlay方式。

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity

SW - 引入第三方dwg图纸后,修改坐标原点

文章目录 SW - 引入第三方dwg图纸后,修改坐标原点概述笔记设置图纸新原点END SW - 引入第三方dwg图纸后,修改坐标原点 概述 在solidworks中引入第三方的dwg格式图纸后,坐标原点大概率都不合适。 全图自动缩放后,引入的图纸离默认的原点位置差很多。 需要自己重新设置原点位置,才能自动缩放后,在工作区中间显示引入的图纸。 笔记 将dwg图纸拖到SW中

linux下修改系统日期与时间

cp /usr/share/zoneinfo/Asia/Shanghai  /etc/localtime

Windows11电脑上自带的画图软件修改照片大小(不裁剪尺寸的情况下)

针对一张图片,有时候上传的图片有大小限制,那么在这种情况下如何修改其大小呢,在不裁剪尺寸的情况下 步骤如下: 1.选定一张图片,右击->打开方式->画图,如下: 第二步:打开图片后,我们可以看到图片的大小为82.1kb,点击上面工具栏的“重设大小和倾斜”进行调整,如下: 第三步:修改水平和垂直的数字,此处我修改为分别都修改为50,然后保存,可以看到大小变成63.5kb,如下:

【第0007页 · 数组】数组中重复的数据(如何实现数组的原地修改)

【前言】本文以及之后的一些题解都会陆续整理到目录中,若想了解全部题解整理,请看这里: 第0007页 · 数组中重复的数据         今天,我们来看一个在实际工作中运用不多,但是对于一些算法题还是有必要的奇技淫巧——数组的原地修改。下面我们将通过两道题目来学习这种技巧。 【找到所有数组中消失的数】 给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1,