以下のJavaScriptプログラムをArduinoプログラムに変換したいのですが、JavaScriptのことがよくわからないのでできません。よろしくお願いします。
JavaScript
1var R_EARTH = 6378137; // 地球の赤道半径 2var RAD = Math.PI / 180; // 1°あたりのラジアン 3 4// 2点間の距離を求める関数 5function distance(lat1, lon1, lat2, lon2) { 6 // 度をラジアンに変換 7 lat1 *= RAD; 8 lon1 *= RAD; 9 lat2 *= RAD; 10 lon2 *= RAD; 11 12 var lat_c = (lat1 + lat2) / 2; // 緯度の中心値 13 var dx = R_EARTH * (lon2 - lon1) * Math.cos(lat_c); 14 var dy = R_EARTH * (lat2 - lat1); 15 16 return Math.sqrt(dx * dx + dy * dy); 17} 18 19// 2点間の方位角を求める関数 20function azimuth(lat1, lon1, lat2, lon2) { 21 // 度をラジアンに変換 22 lat1 *= RAD; 23 lon1 *= RAD; 24 lat2 *= RAD; 25 lon2 *= RAD; 26 27 var lat_c = (lat1 + lat2) / 2; // 緯度の中心値 28 var dx = R_EARTH * (lon2 - lon1) * Math.cos(lat_c); 29 var dy = R_EARTH * (lat2 - lat1); 30 31 if (dx == 0 && dy == 0) { 32 return 0; // dx, dyともに0のときは強制的に0とする。 33 } 34 else { 35 return Math.atan2(dy, dx) / RAD; // 結果は度単位で返す 36 } 37} 38 39function calculate() { 40 var lat1 = parseFloat(document.getElementById("lat1").value); 41 var lon1 = parseFloat(document.getElementById("lon1").value); 42 var lat2 = parseFloat(document.getElementById("lat2").value); 43 var lon2 = parseFloat(document.getElementById("lon2").value); 44 45 document.getElementById("distance").value = distance(lat1, lon1, lat2, lon2).toFixed(1); 46 document.getElementById("azimuth").value = azimuth(lat1, lon1, lat2, lon2).toFixed(2); 47}
このJavaScriptのソース、どこから持ってきましたか?
回答1件
あなたの回答
tips
プレビュー