Add the new client-side hillshade layer
data:image/s3,"s3://crabby-images/42697/42697dac73d4257f88d4aeb965cd5f47c9ea519b" alt=""
By: Molly Lloyd
With our new hillshade layer type, you can create a more detailed, realistic model of terrain (aka shaded relief map), representing a 3D view of hills, valleys, and mountains across a 2D surface. The rendering happens on the client, so every aspect of the visualization can be customized.
For example, more accurately simulate how the sun moves across terrain in the real world:
Or get real creative with different shading techniques and lighting effects. Properties like hillshade-exaggeration, hillshade-shadow-color, hillshade-highlight-color, hillshade-accent-color, and more can be customized at runtime.
data:image/s3,"s3://crabby-images/8f77b/8f77bc250c3f8cf112bff9243e90ceb9f257be93" alt=""
How it works
Our hillshade layer type uses a raster digital elevation model (DEM) — high-resolution elevation data encoded into raster image tiles — to calculate the precise shadow or highlight for every individual pixel on the map. Because we calculate the slope and shadow pixel-by-pixel on the user’s computer, the resulting hillshading is much more detailed than the shading that is possible with a vector-terrain tileset. It’s the difference between styling individual pixels vs. broader, less detailed polygons.
data:image/s3,"s3://crabby-images/eecde/eecde243f68dca787245330cab03b72f3b6dd34e" alt=""
data:image/s3,"s3://crabby-images/b0655/b0655e92b44195e8dca8496440337581e07c7d66" alt=""
You can see the difference side-by-side below. The current Mapbox Outdoors style (image left) uses the vector-terrain tileset’s hillshade layer to color polygons based on whether they represent a shaded or highlighted area. The new client-side hillshading layer (image right) references a raster DEM source that encodes elevation into the red, green, and blue color channels of each pixel in the tile. The result is terrain with more definition and detail.
data:image/s3,"s3://crabby-images/aacca/aaccafba08349c3b16b61d8890e46311e075f50a" alt=""
data:image/s3,"s3://crabby-images/2eb40/2eb4000ee82b740485cedd61d13d24bf2365270c" alt=""
Add the new client-side hillshade layer to your project using mapbox-gl-js v0.43.0 or later; we just released v0.44.0. To get started, create an account and follow this tutorial. You can report bugs or contribute to feature development in our public, open-source repo.
Realistic terrain with custom styling was originally published in Points of interest on Medium, where people are continuing the conversation by highlighting and responding to this story.