Unity实现已知落点和速度自动计算发射角度

本文实例为大家分享了Unity已知落点和速度自动计算发射角度的具体代码,供大家参考,具体内容如下

在发射物已知落点和速度的情况下如果刚体应用重力,不容易算出发射角度,以下为计算过程

/// <summary>
/// 挂载到发射器上即可
/// </summary>
public class Rotate : MonoBehaviour
{
 public GameObject prefab; //发射物
 public float speed;   //发射物速度
 public bool 抛射 = false; //抛射:仰角 > 45°,否:仰角 < 45°
 Ray RayMouse;
 Vector3 direction;
 Quaternion rotation;

 void Update()
 {
  if (Input.GetMouseButtonDown(0))
  {
   GameObject go = Instantiate(prefab, transform.position, transform.rotation);
   go.AddComponent<Rigidbody>().velocity = go.transform.forward * speed;
  }

  RaycastHit hit;
  RayMouse = Camera.main.ScreenPointToRay(Input.mousePosition);
  if (Physics.Raycast(RayMouse.origin, RayMouse.direction, out hit, Mathf.Infinity))
  {
   RotateToMouseDirection(gameObject, hit.point);
  }
 }

 /// <summary>
 /// 执行整体旋转
 /// </summary>
 /// <param name="obj">旋转的物体(自身)</param>
 /// <param name="destination">目标点(鼠标指向)</param>
 void RotateToMouseDirection(GameObject obj, Vector3 destination)
 {
  direction = destination - obj.transform.position;
  rotation = Quaternion.LookRotation(direction);

  Vector3 finalAngle = rotation.eulerAngles;
  float targetAng = Angle(destination);
  finalAngle = new Vector3(-targetAng, finalAngle.y, finalAngle.z);//注意正负

  obj.transform.localRotation = Quaternion.Euler(finalAngle);
 }

 /// <summary>
 /// 自动计算x欧拉角,即仰角
 /// </summary>
 /// <param name="target">目标点坐标</param>
 /// <returns></returns>
 float Angle(Vector3 target)
 {
  float angleX;
  float distX = Vector2.Distance(new Vector2(target.x, target.z), new Vector2(transform.position.x, transform.position.z));
  float distY = target.y - transform.position.y;
  float posBase = (Physics.gravity.y * Mathf.Pow(distX, 2.0f)) / (2.0f * Mathf.Pow(speed, 2.0f));
  float posX = distX / posBase;
  float posY = (Mathf.Pow(posX, 2.0f) / 4.0f) - ((posBase - distY) / posBase);
  if (posY >= 0.0f)
  {
   if (抛射) //字段
    angleX = Mathf.Rad2Deg * Mathf.Atan(-posX / 2.0f + Mathf.Pow(posY, 0.5f));
   else
    angleX = Mathf.Rad2Deg * Mathf.Atan(-posX / 2.0f - Mathf.Pow(posY, 0.5f));
  }
  else
  {
   angleX = 45.0f;
  }
  return angleX;
 }
}

实际效果

抛射效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Unity实现绕任意轴任意角度旋转向量

    本文实例为大家分享了Unity实现绕任意轴任意角度旋转向量的具体代码,供大家参考,具体内容如下 游戏中有一需求,就是一个矩形或者Cube绕着某一点旋转任意角度,现在给出下面算法. public static Vector3 RotateRound(Vector3 position, Vector3 center, Vector3 axis, float angle) { Vector3 point = Quaternion.AngleAxis(angle, axis) * (position -

  • Unity实现已知落点和速度自动计算发射角度

    本文实例为大家分享了Unity已知落点和速度自动计算发射角度的具体代码,供大家参考,具体内容如下 在发射物已知落点和速度的情况下如果刚体应用重力,不容易算出发射角度,以下为计算过程 /// <summary> /// 挂载到发射器上即可 /// </summary> public class Rotate : MonoBehaviour { public GameObject prefab; //发射物 public float speed; //发射物速度 public bool

  • 转载未知大小的图片在一个已知大小容器中的水平和垂直居中(二)

    这是一个未知大小的图片在一个已知大小容器中的水平和垂直居中的例子,原文标题:"Centering an image of unknown size in an outer container of known size", 作者:Stu Nicholls form:http://www.cssplay.co.uk/menu/centered.html ,发表日期:15th October 2006. 此文由forestgan于2006-10-17翻译发表,更多文章. 这个水平和垂直居中

  • javascript 动态设置已知select的option的value值的代码

    复制代码 代码如下: funtion setSelectOption(a,b){//a =>select 的id名,b=>已知option的值 for (i=0;i<$(a).length;i++) //$(a)获取a的id的简单写法,前提是必须用引用prototype.js if($(a).options[i].value == b){//遍历select $(a).options[i].selected=true;//选中特定值 break; }

  • java 获取已知文件扩展名的代码

    一.需求分析 1.获取已知文件的扩展名---------------------------------------------->要先读到文件,得到文件名 2.abc.txt的扩展名是txt, abc.Java.txt的扩展名也是txt------------->获取扩展名的正确性保证 二.技术难点 1.将一个给出的路径转换成一个文件对象,并获取到完整的文件名 直接用new File()类就可以实现,然后通过getName获取到文件名 2.怎么通过文件名获取到扩展名? 通过对文件名进行正则表

  • python绘制已知点的坐标的直线实例

    如下所示: import matplotlib.pyplot as plt import numpy as np x = [11422,11360,11312,11274,11233,11196,11160,11129,11098,11038, 10984,10944,10903,10863,10828,10789,10752,10715,10675,10639, 10654,10619,10587,10550,10510,10466,10425,10389,10350,10311, 10272

  • Python根据已知邻接矩阵绘制无向图操作示例

    本文实例讲述了Python根据已知邻接矩阵绘制无向图操作.分享给大家供大家参考,具体如下: 有六个点:[0,1,2,3,4,5,6],六个点之间的邻接矩阵如表格所示,根据邻接矩阵绘制出相对应的图 0 1 2 3 4 5 6 0 0 1 0 1 0 1 0 1 1 0 1 1 1 1 1 2 0 1 0 1 0 1 0 3 1 1 1 0 1 1 1 4 0 1 0 1 1 1 1 5 1 1 1 1 1 0 0 6 0 1 0 1 1 0 0 将点之间的联系构造成如下矩阵 N = [[0, 3,

  • 浅谈python已知元素,获取元素索引(numpy,pandas)

    目前搜索到的方法有: np.where('元素') 还有就是pandas的方法: df.index('元素') 但是第二个方法的问题就是会报错,嗯,这就比较尴尬了,查询了网上的解决方案,有这样的: 此外使用 df[df['列名'].isin([相应的值])] 这个命令会输出等于该值的行. 此外如果想快速找到dataframe最后几行的话,可以使用的方法是tail,可以获取若干行的值 以上这篇浅谈python已知元素,获取元素索引(numpy,pandas)就是小编分享给大家的全部内容了,希望能给

  • python 已知一个字符,在一个list中找出近似值或相似值实现模糊匹配

    已知一个元素,在一个list中找出相似的元素 使用场景: 已知一个其它来源的字符串, 它有可能是不完全与我数据库中相应的字符串匹配的,因此,我需要将其转为适合我数据库中的字符串 使用场景太绕了, 直接举例来说吧 随便举例: 按青岛城市的城区来说, 我数据库中存储的城区是个list:['市北区', '市南区', '莱州市', '四方区']等 从其它的数据来源得到一个城区是:市北 我怎么得到与市北相似相近的市北区 解决方案: In [1]: import difflib In [2]: cityar

  • python 已知三条边求三角形的角度案例

    我就废话不多说了,还是直接看代码吧! import math a=1;//边1 b=1;//边2 c=math.sqrt(2);//边3 A=math.degrees(math.acos((a*a-b*b-c*c)/(-2*b*c)))//夹角1 B=math.degrees(math.acos((b*b-a*a-c*c)/(-2*a*c)))//夹角2 C=math.degrees(math.acos((c*c-a*a-b*b)/(-2*a*b)))//夹角3 print(A) print(B

  • python 已知平行四边形三个点,求第四个点的案例

    我就废话不多说了,大家还是直接看代码吧! import numpy as np #已知平行四边形三个点,求第四个点 #计算两点之间的距离 def CalcEuclideanDistance(point1,point2): vec1 = np.array(point1) vec2 = np.array(point2) distance = np.linalg.norm(vec1 - vec2) return distance #计算第四个点 def CalcFourthPoint(point1,p

随机推荐