这是一个非常简单的本科物理问题。您从 x 和 y 方向的牛顿定律开始:
data:image/s3,"s3://crabby-images/5d974/5d974a8dfd33b22eb7bd3cd9c68621679dfc1944" alt="x方向的力平衡"
data:image/s3,"s3://crabby-images/101ca/101ca361427d6554a3f3f095c43b8f7d50cd9b67" alt="y方向的力平衡"
初始条件:
data:image/s3,"s3://crabby-images/b1896/b189679f1dbbfb282a29aee62a7ffe8395d42a10" alt="零时的 x 位移"
data:image/s3,"s3://crabby-images/0fcc3/0fcc3f13ae6e5da1a336e611ed55e8dedf71a060" alt="零时的 x 速度"
data:image/s3,"s3://crabby-images/33e4b/33e4bfd09a90c762809b0e21fd4e844e5878eb07" alt="零时间的 y 位移"
data:image/s3,"s3://crabby-images/bbf12/bbf12d27b08ec7bfc3cc96000ce15a4eb62f72e5" alt="零时间的 y 速度"
其中 Q 是弹丸的初始速度,而 theta 是如果枪指向右侧,则从地平线逆时针测量的角度。
因此,如果您将每一项整合一次,您将获得:
data:image/s3,"s3://crabby-images/182bf/182bf9d7d5b3abaf8a6bbbdae382c1f4c5dcee56" alt="x-速度与时间"
data:image/s3,"s3://crabby-images/c090d/c090dffba4599cd68b3e8be4aae003954e76dc94" alt="y 速度与时间的关系"
应用初始条件:
data:image/s3,"s3://crabby-images/5efd9/5efd92de75b59b5edfb650071681f944187486a9" alt="x-速度常数"
data:image/s3,"s3://crabby-images/88f03/88f034f9192c604f1e3491ecb25632bf6e1e72ed" alt="y-速度常数"
第二次积分给出:
data:image/s3,"s3://crabby-images/b0358/b0358280d08b02f8b525bd1163e52fba465fe7f2" alt="x 位移与时间的关系"
data:image/s3,"s3://crabby-images/9a599/9a599f06ebd99340f4be8330df495fc78be5e558" alt="y 位移与时间"
再次应用初始条件:
data:image/s3,"s3://crabby-images/c8871/c887120b282e5b4b8e628b4f346096db783f04e0" alt="x位移初始条件"
从枪响起,进行替换就可以得到您想要的射弹 (u, v) 位置的最终方程:
data:image/s3,"s3://crabby-images/4067a/4067a3f0c3b4c9539549d21b864f576d4bea0153" alt="作为时间函数的射弹的 x 位置"
data:image/s3,"s3://crabby-images/fe190/fe190dfcf6422e3bb61a58509a5b45c9ec82353b" alt="弹丸的 y 位置作为时间的函数"
如果把坐标系的原点放在枪口出口处,那么两个初始位移为零。
现在你有两个方程来表示弹丸的 (u, v) 位置。您可以插入弹丸的初始速度和枪的角度,从地平线测量为零,指向右侧。
您只需从零开始,选择时间增量,然后循环任意长的时间间隔。您将时间的当前值插入这些方程式,评估结果,增加时间,然后重复。
让我们想象一下,您将枪从地平线逆时针倾斜 45 度,并以 1000 英寸/秒的速度发射弹丸。您可以穿越时间,看到抛物线沿抛物线路径向上和向右移动,直到它到达顶点,然后开始回落到地平线。最终,您的 y 位移将回到零,然后继续进入负区域,就好像您是从悬崖边缘拍摄的一样。
如果您想知道弹丸在撞击地面之前走了多远,只需在高度小于或等于零时停止时间循环:
data:image/s3,"s3://crabby-images/a8427/a84274f63184665cd638fd9c8dae50b60a6c168f" alt="是时候回到地球了"
这是为您提供的 Java 实现:
package physics;
/**
* CannonSimulator simulates shooting a projectile. Users are responsible for making
* sure that all constants use consistent units (e.g. meters for length, seconds for
* time, kg for mass, etc.)
* @author Michael
* @since 6/14/12 9:47 PM
* @link http://stackoverflow.com/questions/10935060/2d-projectile-tracing-path-clarification/11043389#11043389
*/
public class CannonSimulator {
private double m;
private double g;
private double q;
private double theta;
public static void main(String[] args) {
double m = ((args.length > 0) ? Double.valueOf(args[0]) : 1.0); // default mass is 1 kg
double g = ((args.length > 1) ? Double.valueOf(args[1]) : 9.8); // default gravity is 9.8 m/sec^2
double q = ((args.length > 2) ? Double.valueOf(args[2]) : 100.0); // default velocity is 100 m/sec
double theta = ((args.length > 3 ? Double.valueOf(args[3]) : Math.PI/4.0)); // default angle is 45 degrees
CannonSimulator simulator = new CannonSimulator(m, g, q, theta);
double t = 0.0;
double dt = 0.001; // time increment of 0.1 seconds
while (simulator.v(t) >= 0.0) {
System.out.println(String.format("time: %10.3f u: %10.3f v: %10.3f", t, simulator.u(t), simulator.v(t)));
t += dt;
}
}
public CannonSimulator(double m, double g, double q, double theta) {
if (m <= 0.0) throw new IllegalArgumentException("mass must be greater than zero");
if (g <= 0.0) throw new IllegalArgumentException("gravity must be greater than zero");
if (q <= 0.0) throw new IllegalArgumentException("velocity must be greater than zero");
this.m = m;
this.g = g;
this.q = q;
this.theta = theta;
}
public double v(double time) {
return time*(q*Math.sin(theta) - g*time/m);
}
public double u(double time) {
return time*q*Math.cos(theta);
}
}
这就是解决这个问题的方法。