课程表

CoffeeScript 语法

CoffeeScript 类和对象

CoffeeScript 字符串

CoffeeScript 数组

CoffeeScript 日期和时间

CoffeeScript 数学

CoffeeScript 方法

CoffeeScript 元编程

CoffeeScript jQuery

CoffeeScript 正则表达式

CoffeeScript 网络

CoffeeScript 设计模式

CoffeeScript 数据库

CoffeeScript 测试

工具箱
速查手册

计算月球的相位

当前位置:免费教程 » JS/JS库/框架 » CoffeeScript

问题

你想找出月球的相位。

解决方案

以下代码提供了一种计算给出日期的月球相位计算方案:

  1. # moonPhase.coffee
  2. # Moon-phase calculator
  3. # Roger W. Sinnott, Sky & Telescope, June 16, 2006
  4. # http://www.skyandtelescope.com/observing/objects/javascript/moon_phases
  5. #
  6. # Translated to CoffeeScript by Mike Hatfield @WebCoding4Fun
  7. proper_ang = (big) ->
  8. tmp = 0
  9. if big > 0
  10. tmp = big / 360.0
  11. tmp = (tmp - (~~tmp)) * 360.0
  12. else
  13. tmp = Math.ceil(Math.abs(big / 360.0))
  14. tmp = big + tmp * 360.0
  15. tmp
  16. jdn = (date) ->
  17. month = date.getMonth()
  18. day = date.getDate()
  19. year = date.getFullYear()
  20. zone = date.getTimezoneOffset() / 1440
  21. mm = month
  22. dd = day
  23. yy = year
  24. yyy = yy
  25. mmm = mm
  26. if mm < 3
  27. yyy = yyy - 1
  28. mmm = mm + 12
  29. day = dd + zone + 0.5
  30. a = ~~( yyy / 100 )
  31. b = 2 - a + ~~( a / 4 )
  32. jd = ~~( 365.25 * yyy ) + ~~( 30.6001 * ( mmm+ 1 ) ) + day + 1720994.5
  33. jd + b if jd > 2299160.4999999
  34. moonElong = (jd) ->
  35. dr = Math.PI / 180
  36. rd = 1 / dr
  37. meeDT = Math.pow((jd - 2382148), 2) / (41048480 * 86400)
  38. meeT = (jd + meeDT - 2451545.0) / 36525
  39. meeT2 = Math.pow(meeT, 2)
  40. meeT3 = Math.pow(meeT, 3)
  41. meeD = 297.85 + (445267.1115 * meeT) - (0.0016300 * meeT2) + (meeT3 / 545868)
  42. meeD = (proper_ang meeD) * dr
  43. meeM1 = 134.96 + (477198.8676 * meeT) + (0.0089970 * meeT2) + (meeT3 / 69699)
  44. meeM1 = (proper_ang meeM1) * dr
  45. meeM = 357.53 + (35999.0503 * meeT)
  46. meeM = (proper_ang meeM) * dr
  47. elong = meeD * rd + 6.29 * Math.sin( meeM1 )
  48. elong = elong - 2.10 * Math.sin( meeM )
  49. elong = elong + 1.27 * Math.sin( 2*meeD - meeM1 )
  50. elong = elong + 0.66 * Math.sin( 2*meeD )
  51. elong = proper_ang elong
  52. elong = Math.round elong
  53. moonNum = ( ( elong + 6.43 ) / 360 ) * 28
  54. moonNum = ~~( moonNum )
  55. if moonNum is 28 then 0 else moonNum
  56. getMoonPhase = (age) ->
  57. moonPhase = "new Moon"
  58. moonPhase = "first quarter" if age > 3 and age < 11
  59. moonPhase = "full Moon" if age > 10 and age < 18
  60. moonPhase = "last quarter" if age > 17 and age < 25
  61. if ((age is 1) or (age is 8) or (age is 15) or (age is 22))
  62. moonPhase = "1 day past " + moonPhase
  63. if ((age is 2) or (age is 9) or (age is 16) or (age is 23))
  64. moonPhase = "2 days past " + moonPhase
  65. if ((age is 3) or (age is 1) or (age is 17) or (age is 24))
  66. moonPhase = "3 days past " + moonPhase
  67. if ((age is 4) or (age is 11) or (age is 18) or (age is 25))
  68. moonPhase = "3 days before " + moonPhase
  69. if ((age is 5) or (age is 12) or (age is 19) or (age is 26))
  70. moonPhase = "2 days before " + moonPhase
  71. if ((age is 6) or (age is 13) or (age is 20) or (age is 27))
  72. moonPhase = "1 day before " + moonPhase
  73. moonPhase
  74. MoonPhase = exports? and exports or @MoonPhase = {}
  75. class MoonPhase.Calculator
  76. getMoonDays: (date) ->
  77. jd = jdn date
  78. moonElong jd
  79. getMoonPhase: (date) ->
  80. jd = jdn date
  81. getMoonPhase( moonElong jd )

讨论

此代码显示一个月球相位计算器对象的方法有两种。计算器 -> getmoonphase 将返回一用个文本表示的日期的月球相位。

这可以用在浏览器和 Node.js 中。

  1. $ node
  2. > var MoonPhase = require('./moonPhase.js');
  3. undefined
  4. > var calc = new MoonPhase.Calculator();
  5. undefined
  6. > calc.getMoonPhase(new Date());
  7. 'full moon'
  8. > calc.getMoonPhase(new Date(1972, 6, 30));
  9. '3 days before last quarter'
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号