-
Notifications
You must be signed in to change notification settings - Fork 64
/
rasterio_cartopy_merc.py
36 lines (28 loc) · 1.02 KB
/
rasterio_cartopy_merc.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
"""
Plot a raster image with Cartopy axes on a Mercator map.
This example reprojects the UTM image to Mercator.
Kelsey Jordahl
SciPy tutorial 2015
"""
import os
import rasterio
import cartopy.crs as ccrs
import matplotlib.pyplot as plt
utm18n = ccrs.UTM(18)
merc = ccrs.Mercator()
ax = plt.axes(projection=merc)
here = os.path.dirname(os.path.abspath('__file__'))
data_dir = os.path.join(here, '..', 'data')
raster_file = os.path.join(data_dir, 'manhattan.tif')
with rasterio.open(raster_file) as src:
left, bottom, right, top = src.bounds
ax.set_extent((left, right, bottom, top), utm18n)
ax.imshow(src.read(1), origin='upper', transform=utm18n,
extent=(left, right, bottom, top), cmap='gray',
interpolation='nearest')
x = [left, right, right, left, left]
y = [bottom, bottom, top, top, bottom]
ax.coastlines(resolution='10m', linewidth=4, color='red')
ax.gridlines(linewidth=2, color='lightblue', alpha=0.5, linestyle='--')
plt.savefig('rasterio_cartopy.png', dpi=300)
plt.show()