Python map overlay software to read CNO and CNOB files.
Project description
pycno
Python map overlay software to read CNO and CNOB files. This provides a light-weight interface to add overlays to matplotlib plots. For longitude/latitude plots, no additional prerequisites are required. For data with projected coordinates, see "projection support." This allows for pure python installation with supplemental support if desired.
status
Early development. Useful light weight mapping library. Interface may change.
install
- Latest release:
pip install pycno - Lastest development:
pip install https://github.com/barronh/pycno/archive/main.zip
example usage
By default, this adds coasts and countries to the current axes. If the current axes has no other data on it, provide the xlim/ylim keywords to define the extents.
import pycno
import matplotlib.pyplot as plt
cno = pycno.cno(xlim=(-180, 180), ylim=(-90, 90))
cno.draw()
plt.savefig('coasts_countries.png')
Use the cnopath keyword to specify another overlay. If you specify a downloadable cnopath you don't have, it will automatically be downloaded. For a list of downloadable cnob, see pycno.downloadable. Currently, this includes the Panoply Overlay cnobs. For example, cno.draw('MWDB_Coasts_NA_1.cnob') will download a high-resolution version of North American coasts, continents, and states.
projection support
pycno.cno supports the pyproj projections. If you provide the proj keyword, then overlays coordinates will be converted to the projection space before being plotted. In this case, the xlim/ylim keyworkds will need to be provided in projection space. This should work for most projections, but has only been tested with Lambert Conformal Conic and Polar Stereographic. If you test it with another projection, please post a comment under issues and let us know.
lambert conic conformal
Example uses LCC domain used by EPA and called 12US2
import pycno
import pyproj
import matplotlib.pyplot as plt
proj = pyproj.Proj(
(
'+proj=lcc +lat_0=40 +lon_0=-97 +lat_1=33 +lat_2=45 ' +
'+x_0=2412000 +y_0=1620000 +R=6370000 +to_meter=12000 ' +
'+no_defs'
),
preserve_units=True
)
plt.axis('image')
cno = pycno.cno(proj=proj, xlim=(0, 396), ylim=(0, 246))
cno.draw()
plt.savefig('coasts_countries_lcc.png')
polar stereographic
Example uses Polar Stereographic domain used by EPA and called 108NHEMI2
import pycno
import pyproj
import matplotlib.pyplot as plt
proj = pyproj.Proj(
(
'+proj=stere +lat_0=90 +lat_ts=45 +lon_0=-98 ' +
'+x_0=10098000 +y_0=10098000 +R=6370000 +to_meter=108000 ' +
'+no_defs'
),
preserve_units=True
)
plt.axis('image')
cno = pycno.cno(proj=proj, xlim=(0, 187), ylim=(0, 187))
cno.draw()
plt.savefig('coasts_countries_ps.png')
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pycno-0.3.2.tar.gz.
File metadata
- Download URL: pycno-0.3.2.tar.gz
- Upload date:
- Size: 150.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
47541ea2febba48bfe0ea3099a5f7cea0579c0c932ad6711437a4548ceaa8603
|
|
| MD5 |
7ec64a85b93a25ea0539a1d95c3074c6
|
|
| BLAKE2b-256 |
915113b4adfef68d1c7ec53edabc55fad3a2d6a977416d22b21f3308cd8c5680
|
File details
Details for the file pycno-0.3.2-py3-none-any.whl.
File metadata
- Download URL: pycno-0.3.2-py3-none-any.whl
- Upload date:
- Size: 149.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2ac4031728fde38868e35b360ae137a5235a47fc4c86553e499f99f79eb2a13c
|
|
| MD5 |
cd60f480025ac4cfbd16e1acec5368c6
|
|
| BLAKE2b-256 |
3ebcd7d8a6593f87b46f5be029829d3ff181433928dc9d8f3c442b044e3fbf5c
|