0

所以我有这段代码是为了做这个等式:

(1 / 15) * arccos(-tan(L) * tan(23.44 * sin(360 * (D + 284) / 365))) 

并出于测试目的提醒它!但由于某种原因,它返回“NaN”。我可能做了一些非常愚蠢的事情:P

var now = new Date();
var start = new Date(now.getFullYear(), 0, 0);
var diff = now - start;
var oneDay = 1000 * 60 * 60 * 24;
var d = Math.floor(diff / oneDay);


var lat = position.coords.latitude;
var long = position.coords.longitude;
var tanlat = Math.atan(lat); 
var tantwentythree = Math.tan(23.44);
var dayplus = d + 284;
var sinday = Math.sin(360 * dayplus);
var arccos = Math.acos(tanlat);
var start = 1 / 15;
var equation = start * arccos * tantwentythree * sinday / 365;
alert(equation);


var result = rad2deg / 15 * Math.acos(-Math.tan(lat*deg2rad) * Math.tan(23.44*deg2rad * Math.sin(360*deg2rad * (day + 284) / 365)));
alert(result);
var resultstr = string(result);
document.getElementById('sunrise').innerHTML = resultstr;

我有一个 id 为“sunrise”的,当函数运行时,var resultstr 应该被添加到(我认为?)但我没有!

4

1 回答 1

0

也许你想要

tanlat= Math.tan(lat)

不是Math.atan(lat)哪个是相反的...

但是你还有另一个问题:三角函数的所有参数都应该是弧度,而不是度数。您将不得不将度数乘以Math.PI / 180

但是你有更多的问题。不是你需要的tan(23.44)数量,你需要的tan是产品的数量。

我要做的就是简单地采用你的公式,只将度数添加到弧度转换:

var deg2rad = Math.PI / 180;
var rad2deg = 180 / Math.PI;
var result = rad2deg / 15 * Math.acos(-Math.tan(lat*deg2rad) *
             Math.tan(23.44*deg2rad * Math.sin(360*deg2rad * (d + 284) / 365)))
于 2013-10-22T21:45:19.530 回答