Actually, there is nothing too hard, especially if you have a good astronomical algorithm library. Nowadays we could do this using only plain JavaScript and HTML5 canvas.
¹ Make sure that daylight saving time settings are configured properly on your system
The algorithm is the following:
- To obtain the latitude and longitude of the subsolar point find the current equatorial coordinates of the Sun: the hour angle and declination.
- Map each pixel of the Earth map to the corresponding geographical coordinates using its map projection transformations.
- Map each geographical coordinate of a pixel to the corresponding equatorial coordinates.
- Using equatorial coordinates check whether each pixel of the map is distant from the subsolar point farther than 90 degrees (because the shadow edge is a great circle).
- If so, convert RGB values of the pixel to HSV color space and decrease the Value channel by two (or get the same pixel from a night version of the map), then put processed pixel data back using reverse HSV to RGB conversion.
- That's all.
- To find estimate subsolar point coordinates it is only necessary to correct the current UTC time with the equation of time (to get the hour angle) and calculate the position of the Sun on the ecliptic using the amount of time since the vernal equinox (to get the declination). This approximate algorithm also works. But there are more precise algorithms that deal with Earth axial precessions and nutations, elliptical motion and other periodic theories described in the book Astronomical Algorithms by Jean Meeus. Because it is very hard to implement and debug them properly, we will use existing JavaScript implementation by Henning Umland.
- Since we use the equirectangular map projection, there is no need for Cartesian/geographical coordinate conversion - the longitude and latitude are mapped directly to the Cartesian coordinates. We only need to adjust the origin of the map.
- To find the angular distance between the subsolar point and the pixel being processed we need to apply the spherical law of cosines to spherical (equatorial) coordinates of the corresponding points obtained from the geographical ones.
- Because HTML5 canvas has the ability to draw semitransparent rectangles, we do not need to mess with HSV color representation and can optimize the algorithm further. As we know that a projection of the sunlight shadow on the Earth map is a sine-like figure (sine is an unambiguous mapping), we only need to find the first top or bottom pixel (depends on the current season) of the shadow for a given pixel column and draw one pixel wide semitransparent rectangle to the opposite map edge.
- See Windows Desktop Gadget on GitHub for an HTML5 demo.
No comments:
Post a Comment