Skip to content

Commit

Permalink
Snapshot marker support (#1328)
Browse files Browse the repository at this point in the history
* Fix #1325. Get only main map svg

* Introduced Support for marker snapshot in leaflet

There is still a problem when the map is panned.
When possible, you have to parse the transform inline style of the mapdiv to properly shift the clonded marker div to snap (or properly set the canvas).

* fixed issues with query selector and FF-31.0.0
  • Loading branch information
offtherailz authored and mbarto committed Dec 13, 2016
1 parent 685938c commit 5400892
Showing 1 changed file with 24 additions and 2 deletions.
26 changes: 24 additions & 2 deletions web/client/components/map/leaflet/snapshot/GrabMap.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -200,8 +200,30 @@ let GrabLMap = React.createClass({

});
let finialize = () => {
this.props.onStatusChange("READY", this.isTainted(finalCanvas));
this.props.onSnapshotReady(canvas, null, null, null, this.isTainted(finalCanvas));
// TODO parse map-div transform to shift all markers toghether properly
let markers = this.mapDiv.getElementsByClassName("leaflet-marker-pane");
if ( markers && markers.length > 0) {
let newCanvas = this.refs.canvas.cloneNode();
newCanvas.width = newCanvas.width + left;
html2canvas(markers, {
// you have to provide a canvas to avoid html2canvas to crop the image
canvas: newCanvas,
logging: false,
proxy: this.proxy,
allowTaint: props && props.allowTaint,
// TODO: improve to useCORS if every source has CORS enabled
useCORS: props && props.allowTaint
}).then( (c) => {
let cx = finalCanvas.getContext("2d");
cx.globalAlpha = 1;
cx.drawImage(c, -1 * left, 0);
this.props.onStatusChange("READY", this.isTainted(finalCanvas));
this.props.onSnapshotReady(canvas, null, null, null, this.isTainted(finalCanvas));
});
} else {
this.props.onStatusChange("READY", this.isTainted(finalCanvas));
this.props.onSnapshotReady(canvas, null, null, null, this.isTainted(finalCanvas));
}
};

if (svg) {
Expand Down

0 comments on commit 5400892

Please sign in to comment.