unity两点之间抛物线,完美金手指
学校享受的日子一去不复还了,呜呜。话说面试了几个公司,真心没准备好就上了,结果当然是小悲催。还好有容身之处,就算是搬砖,也有可能为自己盖楼,吼吼。
好,下面我来分享一道有意思的面试题,说他有意思,是因为这个题目的意义很重要的,好了不卖官司了,先看看题目:
三维空间,Y轴朝上,重力加速度为大小为g, 已知A(x1, y1, z1), B(x2, y2, z2)是三维空间中的两个点,现在从A点发射一个物体,希望该物体经过时间t之后,落在B点,请给出计算发射速度向量。
说到这,请把unity相关的API全部忘记吧,因为这道题是考察物理和几何的,跟unity API,引擎无关。(话说我面试的公司虽然招unity,可连一句unity的知识都没问啊!)
怎么做呢?在思考题目的解法之前,我先说说这个目的实用价值,你在做AI的时候绝对用得着。就算不写AI,拿个简单的例子,愤怒的小鸟中,可以实现“金手指”功能,给个时间,角度和力度都算出来了,
多神气啊。再举个例子,做动态过场动画的时候,例如需要一发炮弹击中某物体,如果你写的炮弹准确度不高,那过场动画不就完了(当然也有其他方案可以避免),我的意思
就是说,可以使用这个方案实现炮弹的精确打击,而且一切又是那么自然,有重力,也有抛物线,多美好的轨迹啊!
好吧,我说这么多,就是提醒大家,如果在学习中遇到一些有意思的算法或者功能,可以结合到项目实际中去,这样的才发挥他的价值。
嗯,是时候写出答案了。伪代码如下:
//发射初速度V在X,Y,Z轴的速度分量Vx,Vy,Vz,abs(float value)是绝对值函数
Vx = abs (x2-x1) /t;
Vy =abs (y1-y2)/t+(1/2f)gt;
Vz = abs (y2-y1) /t;
V =Vector3 (Vx,Vy,Vz);
V就是我们要求的结果。看上去这个式子没什么大不了的,现在来看看把他怎么放到工程里面吧。
我们自己掌握的变量:时间T,坐标P1,坐标P2,有了这三个,一道完美的轨迹就出现了!
代码如下:
using UnityEngine;
using System.Collections; public class TestSpeed : MonoBehaviour {
public float time=;//代表从A点出发到B经过的时长
public Transform pointA;//点A
public Transform pointB;//点B
public float g=-;//重力加速度
// Use this for initialization
private Vector3 speed;//初速度向量
private Vector3 Gravity;//重力向量
void Start () { transform.position = pointA.position;//将物体置于A点
//通过一个式子计算初速度
speed = new Vector3((pointB.position.x - pointA.position.x)/time,
(pointB.position.y-pointA.position.y)/time-0.5f*g*time, (pointB.position.z - pointA.position.z) / time);
Gravity = Vector3.zero;//重力初始速度为0
}
private float dTime=;
// Update is called once per frame
void FixedUpdate () { Gravity.y = g * (dTime += Time.fixedDeltaTime);//v=at
//模拟位移
transform.Translate(speed*Time.fixedDeltaTime);
transform.Translate(Gravity * Time.fixedDeltaTime);
}
}
点击运行之前,先将A,B两点赋值。然后运行,一个完美的曲线就此划下。
本文链接:http://www.cnblogs.com/jqg-aliang/p/4806017.html,转载请申明出处,谢谢!
unity两点之间抛物线,完美金手指的更多相关文章
- 2D和3D空间中计算两点之间的距离
自己在做游戏的忘记了Unity帮我们提供计算两点之间的距离,在百度搜索了下. 原来有一个公式自己就写了一个方法O(∩_∩)O~,到僵尸到达某一个点之后就向另一个奔跑过去 /// <summary ...
- sql server2008根据经纬度计算两点之间的距离
--通过经纬度计算两点之间的距离 create FUNCTION [dbo].[fnGetDistanceNew] --LatBegin 开始经度 --LngBegin 开始维度 --29.49029 ...
- C#面向对象思想计算两点之间距离
题目为计算两点之间距离. 面向过程的思维方式,两点的横坐标之差,纵坐标之差,平方求和,再开跟,得到两点之间距离. using System; using System.Collections.Gene ...
- (转)c# math 计算两点之间的角度公式
计算两点之间的角度公式是: 假设点一(X1,Y1),点二(X2,Y2) double angleOfLine = Math.Atan2((Y2 - Y1), (X2 - X2)) * 180 / Ma ...
- Floyd算法——计算图中任意两点之间的最短路径
百度百科定义:传送门 一.floyd算法 说实话这个算法是用来求多源最短路径的算法. 算法原理: 1,从任意一条单边路径开始.所有两点之间的距离是边的权,如果两点之间没有边相连,则权为无穷大. 2,对 ...
- c++ 算法 栅格中两点之间连线
屏幕划线,通过平面坐标系实现,基本组成是一个一个的点,起点为A,终点为B 本文的算法,可以实现平面栅格中,指定的A,B两点之间进行连线(代码中仅打印了两点间需要画出的坐标点) #include < ...
- 求两点之间距离 C++
求两点之间距离(20 分) 定义一个Point类,有两个数据成员:x和y, 分别代表x坐标和y坐标,并有若干成员函数. 定义一个函数Distance(), 用于求两点之间的距离.输入格式: 输入有两行 ...
- 图上两点之间的第k最短路径的长度 ACM-ICPC 2018 沈阳赛区网络预赛 D. Made In Heaven
131072K One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. Howe ...
- js通过经纬度计算两点之间的距离
最近这几天在做地图的时候,获取到目的地经纬度和当前所在位置的经纬度,通过这几个参数,用js代码就能获取到这两点之间的直线距离: function (lat1, lng1, lat2, lng2) { ...
随机推荐
- LitDB笔记
首先,LitDB存储的不是json,而是bson.这里就有问题了,json是可以无限扩展的,但是bson不行.所有insert的时候需要使用实体类而不是hashtable.但是它又提供了一个叫做Bso ...
- bzoj1043 下落的圆盘
Description 有n个圆盘从天而降,后面落下的可以盖住前面的.求最后形成的封闭区域的周长.看下面这副图, 所有的红色线条的总长度即为所求. Input 第一行为1个整数n,N<=100 ...
- Win7系统安装Centos7.0双系统(二)
4.6语言选择
- string和stringBuilder区别
C# String 对象是不可改变的.每次使用 System.String 类中的方法之一时,都要在内存中创建一个新的字符串对象,这就需要为该新对象分配新的空间.在需要对字符串执行重复修改的情况下,与 ...
- flash bulider 无法启动
更新airsdk后无法启动,google下http://www.25kx.com/art/1826181有n种方法,怀疑是.metadata目录原因,可能是旧版的airsdk和新版的airsdk在.m ...
- java处理日期时间
java.util.Calendar Calendar 类是一个抽象类,它为特定瞬间与一组诸如 YEAR.MONTH.DAY_OF_MONTH.HOUR 等 日历字段之间的转换提供了一些方法,并为操作 ...
- svn在linux下的使用(转)
ubuntu命令行模式操作svn 首先要安装SVN客户端到你的系统才能操作各种命令 apt-get install subversion 1.将文件checkout到本地目录 svn checkout ...
- .net关于httpModules的应用示例
这三个对象我们在开发Asp.net程序时经常会用到,似乎很熟悉,但有时 候又不太确定.本文通过一个简单的例子来直观的比较一下这三个对象的使用. HttpModule:Http模块,可以在页面处理前后. ...
- python实现字体闪图
!/usr/bin/env python from future import print_function import os.path import sys from optparse impor ...
- tuple解包给类的构造函数
首先我们的第一步当然是将tuple解包.tuple提供了一个get函数来获取第N个元素.例如: get<1>(make_tuple(...)); 要将一个tuple全部拆解,就可以使用通过 ...