# Static Maps Static views of CARTO maps can be generated using the [Static Maps API](https://carto.com/docs/carto-engine/maps-api/static-maps-api/) within CARTO.js. The map's style, including the zoom and bounding box, follows from what was set in the `viz.json` file, but you can change the zoom, center, and size of your image with a few lines of code. You can also change your basemap Images can be placed in specified DOM elements on your page, or you can generate a URL for the image. ## Quick Start The easiest way to generate an image is by using the following piece of code, which generates is replaced by an `img` tag once run in an HTML file: ```javascript ``` #### Result ```html ``` ### cartodb.Image(_layerSource[, options]_) #### Arguments Name |Description --- | --- layerSource | can be either a `viz.json` object or a [MapConfig object](https://carto.com/docs/carto-engine/maps-api/mapconfig#mapnik-layer-options).

**Note:** If defining an image through the MapConfig layer definition, you must set the `tiler_domain`, `tiler_port`, and `tiler_protocol`, as displayed in this [example](https://github.com/CartoDB/cartodb.js/blob/4ba5148638091fd2c194f48b2fa3ed6ac4ecdb23/examples/layer_definition.html). Otherwise the Static Image API tries to use your localhost to source the tiles and an error appears. options | --- | --- |_ basemap | change the basemap specified in the layer definition. Type: Object defining base map properties (see example below). |_ no_cdn | Disable CDN usage. Type: Boolean. Default: `false` (use CDN) |_ override_bbox | Override default of using the bounding box of the visualization. This is needed to use `Image.center` and `Image.zoom`. Type: Boolean. Default: `false` (use bounding box) #### Returns An `Image` object #### Example ```javascript ``` --- ## cartodb.Image ### Image.size(_width, height_) Sets the size of the image. #### Arguments Name |Description --- | --- width | the width of the resulting image in pixels height | the height of the resulting image in pixels #### Returns An `Image` object ### Image.center(_latLng_) Sets the center of the map. #### Arguments Name |Description --- | --- latLng | an array of the latitude and longitude of the center of the map. Example: `[40.4378271, -3.6795367]` #### Returns An `Image` object ### Image.zoom(_zoomLevel_) Sets the zoom level of the static map. Must be used with the option `override_bbox: true` if not using `Image.center` or `Image.bbox`. #### Arguments Name |Description --- | --- zoomLevel | the zoom of the resulting static map. `zoomLevel` must be an integer in the range [0,24]. #### Returns An `Image` object ### Image.bbox(_boundingBox_) If you set `bbox`, `center` and `zoom` will be overridden. #### Arguments Name |Description --- | --- boundingBox | an array of coordinates making up the bounding box for your map. `boundingBox` takes the form: `[sw_lat, sw_lon, ne_lat, ne_lon]`. #### Returns An `Image` object ### Image.into(_HTMLImageElement_) Inserts the image into the HTML DOM element specified. #### Arguments Name |Description --- | --- HTMLImageElement | the DOM element where your image is to be located. #### Returns An `Image` object #### Example ```javascript cartodb.Image(vizjson_url).into(document.getElementById('map_preview')) ``` ### Image.write(_attributes_) Adds an `img` tag in the same place script is executed. It's possible to specify a class name (`class`) and/or an id attribute (`id`) for the resulting image: #### Arguments Name |Description --- | --- class | the DOM class applied to the resulting `img` tag. id | the DOM id applied to the resulting `img` tag. src | path to a temporary image that acts as a placeholder while the static map is retrieved. #### Returns An `Image` object #### Example ```javascript ``` ### Image.getUrl(_callback(err, url)_) Gets the URL for the image requested. #### Callback Arguments Name |Description --- | --- err | error associated with the image request, if any. url | URL of the generated image. #### Returns An `Image` object #### Example ```javascript ``` ### Image.format(_format_) Gets the URL for the image requested. #### Arguments Name |Description --- | --- format | image format of resulting image. One of `png` (default) or `jpg` (which have a quality of 85 dpi) #### Returns An `Image` object