|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 |
-
- SunCalc
- =======
-
- [![Build Status](https://travis-ci.org/mourner/suncalc.svg?branch=master)](https://travis-ci.org/mourner/suncalc)
-
- SunCalc is a tiny BSD-licensed JavaScript library for calculating sun position,
- sunlight phases (times for sunrise, sunset, dusk, etc.),
- moon position and lunar phase for the given location and time,
- created by [Vladimir Agafonkin](http://agafonkin.com/en) ([@mourner](https://github.com/mourner))
- as a part of the [SunCalc.net project](http://suncalc.net).
-
- Most calculations are based on the formulas given in the excellent Astronomy Answers articles
- about [position of the sun](http://aa.quae.nl/en/reken/zonpositie.html)
- and [the planets](http://aa.quae.nl/en/reken/hemelpositie.html).
- You can read about different twilight phases calculated by SunCalc
- in the [Twilight article on Wikipedia](http://en.wikipedia.org/wiki/Twilight).
-
-
- ## Usage example
-
- ```javascript
- // get today's sunlight times for London
- var times = SunCalc.getTimes(new Date(), 51.5, -0.1);
-
- // format sunrise time from the Date object
- var sunriseStr = times.sunrise.getHours() + ':' + times.sunrise.getMinutes();
-
- // get position of the sun (azimuth and altitude) at today's sunrise
- var sunrisePos = SunCalc.getPosition(times.sunrise, 51.5, -0.1);
-
- // get sunrise azimuth in degrees
- var sunriseAzimuth = sunrisePos.azimuth * 180 / Math.PI;
- ```
-
- SunCalc is also available as an NPM package:
-
- ```bash
- $ npm install suncalc
- ```
-
- ```js
- var SunCalc = require('suncalc');
- ```
-
-
- ## Reference
-
- ### Sunlight times
-
- ```javascript
- SunCalc.getTimes(/*Date*/ date, /*Number*/ latitude, /*Number*/ longitude)
- ```
-
- Returns an object with the following properties (each is a `Date` object):
-
- | Property | Description |
- | --------------- | ------------------------------------------------------------------------ |
- | `sunrise` | sunrise (top edge of the sun appears on the horizon) |
- | `sunriseEnd` | sunrise ends (bottom edge of the sun touches the horizon) |
- | `goldenHourEnd` | morning golden hour (soft light, best time for photography) ends |
- | `solarNoon` | solar noon (sun is in the highest position) |
- | `goldenHour` | evening golden hour starts |
- | `sunsetStart` | sunset starts (bottom edge of the sun touches the horizon) |
- | `sunset` | sunset (sun disappears below the horizon, evening civil twilight starts) |
- | `dusk` | dusk (evening nautical twilight starts) |
- | `nauticalDusk` | nautical dusk (evening astronomical twilight starts) |
- | `night` | night starts (dark enough for astronomical observations) |
- | `nadir` | nadir (darkest moment of the night, sun is in the lowest position) |
- | `nightEnd` | night ends (morning astronomical twilight starts) |
- | `nauticalDawn` | nautical dawn (morning nautical twilight starts) |
- | `dawn` | dawn (morning nautical twilight ends, morning civil twilight starts) |
-
- ```javascript
- SunCalc.addTime(/*Number*/ angleInDegrees, /*String*/ morningName, /*String*/ eveningName)
- ```
-
- Adds a custom time when the sun reaches the given angle to results returned by `SunCalc.getTimes`.
-
- `SunCalc.times` property contains all currently defined times.
-
-
- ### Sun position
-
- ```javascript
- SunCalc.getPosition(/*Date*/ timeAndDate, /*Number*/ latitude, /*Number*/ longitude)
- ```
-
- Returns an object with the following properties:
-
- * `altitude`: sun altitude above the horizon in radians,
- e.g. `0` at the horizon and `PI/2` at the zenith (straight over your head)
- * `azimuth`: sun azimuth in radians (direction along the horizon, measured from south to west),
- e.g. `0` is south and `Math.PI * 3/4` is northwest
-
-
- ### Moon position
-
- ```javascript
- SunCalc.getMoonPosition(/*Date*/ timeAndDate, /*Number*/ latitude, /*Number*/ longitude)
- ```
-
- Returns an object with the following properties:
-
- * `altitude`: moon altitude above the horizon in radians
- * `azimuth`: moon azimuth in radians
- * `distance`: distance to moon in kilometers
- * `parallacticAngle`: parallactic angle of the moon in radians
-
-
- ### Moon illumination
-
- ```javascript
- SunCalc.getMoonIllumination(/*Date*/ timeAndDate)
- ```
-
- Returns an object with the following properties:
-
- * `fraction`: illuminated fraction of the moon; varies from `0.0` (new moon) to `1.0` (full moon)
- * `phase`: moon phase; varies from `0.0` to `1.0`, described below
- * `angle`: midpoint angle in radians of the illuminated limb of the moon reckoned eastward from the north point of the disk;
- the moon is waxing if the angle is negative, and waning if positive
-
- Moon phase value should be interpreted like this:
-
- | Phase | Name |
- | -----:| --------------- |
- | 0 | New Moon |
- | | Waxing Crescent |
- | 0.25 | First Quarter |
- | | Waxing Gibbous |
- | 0.5 | Full Moon |
- | | Waning Gibbous |
- | 0.75 | Last Quarter |
- | | Waning Crescent |
-
- By subtracting the `parallacticAngle` from the `angle` one can get the zenith angle of the moons bright limb (anticlockwise).
- The zenith angle can be used do draw the moon shape from the observers perspective (e.g. moon lying on its back).
-
- ### Moon rise and set times
-
- ```js
- SunCalc.getMoonTimes(/*Date*/ date, /*Number*/ latitude, /*Number*/ longitude[, inUTC])
- ```
-
- Returns an object with the following properties:
-
- * `rise`: moonrise time as `Date`
- * `set`: moonset time as `Date`
- * `alwaysUp`: `true` if the moon never rises/sets and is always _above_ the horizon during the day
- * `alwaysDown`: `true` if the moon is always _below_ the horizon
-
- By default, it will search for moon rise and set during local user's day (frou 0 to 24 hours).
- If `inUTC` is set to true, it will instead search the specified date from 0 to 24 UTC hours.
-
- ## Changelog
-
- #### 1.8.0 — Dec 22, 2016
-
- - Improved precision of moonrise/moonset calculations.
- - Added `parallacticAngle` calculation to `getMoonPosition`.
- - Default to today's date in `getMoonIllumination`.
- - Fixed incompatibility when using Browserify/Webpack together with a global AMD loader.
-
- #### 1.7.0 — Nov 11, 2015
-
- - Added `inUTC` argument to `getMoonTimes`.
-
- #### 1.6.0 — Oct 27, 2014
-
- - Added `SunCalc.getMoonTimes` for calculating moon rise and set times.
-
- #### 1.5.1 — May 16, 2014
-
- - Exposed `SunCalc.times` property with defined daylight times.
- - Slightly improved `SunCalc.getTimes` performance.
-
- #### 1.4.0 — Apr 10, 2014
-
- - Added `phase` to `SunCalc.getMoonIllumination` results (moon phase).
- - Switched from mocha to tape for tests.
-
- #### 1.3.0 — Feb 21, 2014
-
- - Added `SunCalc.getMoonIllumination` (in place of `getMoonFraction`) that returns an object with `fraction` and `angle`
- (angle of illuminated limb of the moon).
-
- #### 1.2.0 — Mar 07, 2013
-
- - Added `SunCalc.getMoonFraction` function that returns illuminated fraction of the moon.
-
- #### 1.1.0 — Mar 06, 2013
-
- - Added `SunCalc.getMoonPosition` function.
- - Added nadir (darkest time of the day, middle of the night).
- - Added tests.
-
- #### 1.0.0 — Dec 07, 2011
-
- - Published to NPM.
- - Added `SunCalc.addTime` function.
-
- #### 0.0.0 — Aug 25, 2011
-
- - First commit.
|