-
Notifications
You must be signed in to change notification settings - Fork 138
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add ImageViz for mapbox ImageSource
#61
Conversation
GL JS explicitly takes the order of
It seems that this would be most useful for displaying manipulated data, which in most cases would be coordinates = [... ]
img = imread('img.jpg')
visualization = ImageViz(img, coordinates, ...)
visualization.show() Beyond what this might add in terms of ndarray ==> image data encoding within the library, to be more effectively used we'd probably have to add a utility to take data ndarrays and apply a color ramp (which could be done via `matplotlib): from matplotlib import cm
# data scaled to 0-1
data
# using the viridis colormap
img = (cm.viridis(data) * np.iiinfo(np.uint8).max).astype(np.uint8) |
This is awesome @vincentsarago! Let me know when you're ready for 👀 on a review. |
mapboxgl/templates/image.html
Outdated
center: {{ center }}, | ||
zoom: {{ zoom }}, | ||
transformRequest: (url, resourceType)=> { | ||
if ( url.slice(0,22) == 'https://api.mapbox.com' ) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should use regex to be more robust in catching requests to the Mapbox api -- older styles may still have
- api.tiles.mapbox.com
- a.tiles.mapbox.com
- b.tiles ..
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@dnomadb good flag. I'll include this change in a separate PR, since it spans all visualization types.
@@ -276,3 +276,33 @@ def add_unique_template_variables(self, options): | |||
clusterRadius=self.clusterRadius, | |||
clusterMaxZoom=self.clusterMaxZoom | |||
)) | |||
|
|||
|
|||
class ImageViz(MapViz): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@vincentsarago could we call this class an ImageLayer
? it looks layer-like to me and I think Layer
could tell a user a lot about how to use the class.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right now it's a proper MapViz, but I think at the end we could make it a layer meaning that instead of having a ImageViz, we could add a addImage
function to the MapViz
class.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agree, a change to use layer
nomenclature makes sense here. I'd propose a renaming of the API from *Viz
to *Layer
in a separate PR from this one, as a part of #34.
Ok I like the idea of using Matplotlib (+Pillow) if this is what the users are use to do. Here is what I propose
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@vincentsarago looks great! Made a few comments, all optional. Made a small commit to aid running the example locally for the first time.
img_format = kwargs['format'] if kwargs.get('format') else 'png' | ||
img_str = base64.b64encode(sio.getvalue()).decode() | ||
|
||
return 'data:image/{};base64,{}'.format(img_format, img_str) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@vincentsarago it may be good to include an optional filename
output parameter here. This would encourage users to output a local file with the encoded image data so that the mapboxgl
viz class can load the image data asynchronously (versus stick it into a large HTML blob).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In fact I think because mapboxgl can read local files we can totally remove this utility function and show the user it can use imsave
"\n", | ||
" map.addSource('image', {\n", | ||
" 'type': 'image',\n", | ||
" 'url': ' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@vincentsarago let's change this to an async URL load from a local file, if possible, to reduce file size of the notebook and encourage async loading of images.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh well I didn't knew mapboxgl could read a local file 👌
@@ -276,3 +276,33 @@ def add_unique_template_variables(self, options): | |||
clusterRadius=self.clusterRadius, | |||
clusterMaxZoom=self.clusterMaxZoom | |||
)) | |||
|
|||
|
|||
class ImageViz(MapViz): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agree, a change to use layer
nomenclature makes sense here. I'd propose a renaming of the API from *Viz
to *Layer
in a separate PR from this one, as a part of #34.
mapboxgl/viz.py
Outdated
|
||
def __init__(self, | ||
data, | ||
image, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@vincentsarago could we simplify the syntax by just passing the pixels or URL for an image
to the required data
parameter, instead of adding a new parameter?
@@ -14,7 +14,8 @@ | |||
"\n", | |||
"```\n", | |||
"pip install mapboxgl\n", | |||
"pip install Pillow numpy\n", | |||
"pip install imread\n", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ryanbaumann imread
comes from matplotlib
which is already installed
Line 34 in cf08d3e
install_requires=['jinja2', 'geojson', 'colour', 'matplotlib'], |
imread
@@ -14,7 +14,8 @@ | |||
"\n", | |||
"```\n", | |||
"pip install mapboxgl\n", | |||
"pip install Pillow numpy\n", | |||
"pip install imread\n", | |||
"pip install numpy\n", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
same here, numpy will be installed by default when installing mapboxgl-jupyter
ok going back to @dnomadb point earlier, maybe
If a numpy array is given cc @ryanbaumann |
this is ready @ryanbaumann I'll merge it when the tests will be over ! |
🎉 @vincentsarago thanks! |
This PR tries to add an
ImageViz
method to enable Mapbox GL staticImageSource
.There is couple things that need to be discussed:
data
heremapboxgl-jupyter/mapboxgl/viz.py
Lines 281 to 290 in 6034cfc
Preview
cc @dnomadb @ryanbaumann