Animate a series of images
Use a series of image sources to create an animation.
<!DOCTYPE html><html><head><meta charset="utf-8" /><title>Animate a series of images</title><meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no" /><script src="https://cdn.ndrive.com/nmapsgl/v.1.6.8/nmaps-gl.js"></script><link href="https://cdn.ndrive.com/nmapsgl/v.1.6.8/nmaps-gl.css" rel="stylesheet" /><style> body { margin: 0; padding: 0; } #map { position: absolute; top: 0; bottom: 0; width: 100%; }</style></head><body><div id="map"></div><script> // TO MAKE THE MAP APPEAR YOU MUST ADD YOUR ACCESS TOKEN nmapsgl.accessToken = '<your access token here>'; const map = new nmapsgl.Map({container: 'map',style: 'Dark',maxZoom: 5.99,minZoom: 4,zoom: 5,center: [-75.789, 41.874]}); const frameCount = 5;let currentImage = 0; function getPath() {return ('https://nmaps-gl.ndrive.com/nmaps-gl-js/assets/radar' +currentImage +'.gif');} map.on('load', () => {map.addSource('radar', {type: 'image',url: getPath(),coordinates: [[-80.425, 46.437],[-71.516, 46.437],[-71.516, 37.936],[-80.425, 37.936]]});map.addLayer({id: 'radar-layer','type': 'raster','source': 'radar','paint': {'raster-fade-duration': 0}}); setInterval(() => {currentImage = (currentImage + 1) % frameCount;map.getSource('radar').updateImage({ url: getPath() });}, 200);});</script> </body></html>