-
Notifications
You must be signed in to change notification settings - Fork 387
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Allow canceling pan and zoom from beforePan and beforeZoom. Closes #37
- Loading branch information
Showing
4 changed files
with
153 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
<!DOCTYPE html> | ||
<html> | ||
<head> | ||
<meta name="viewport" content="user-scalable=no, width=device-width, initial-scale=1, maximum-scale=1"> | ||
<script src="../dist/svg-pan-zoom.js"></script> | ||
</head> | ||
|
||
<body> | ||
<div id="limit-div" style="width: 602px; height: 420px; border:1px solid black; "> | ||
<svg id="limit-svg" xmlns="http://www.w3.org/2000/svg" style="display: inline; width: inherit; min-width: inherit; max-width: inherit; height: inherit; min-height: inherit; max-height: inherit;" version="1.1"> | ||
<defs> | ||
<linearGradient id="linear-gradient" x1="0%" y1="0%" x2="0%" y2="100%"> | ||
<stop offset="0%" style="stop-color:rgb(56,121,217);stop-opacity:1" /> | ||
<stop offset="100%" style="stop-color:rgb(138,192,7);stop-opacity:1" /> | ||
</linearGradient> | ||
</defs> | ||
<g fill="none"> | ||
<g stroke="#000" fill="#FFF"> | ||
<rect x="5" y="5" width="240" height="240" fill="url(#linear-gradient)"/> | ||
<path d="M 5 5 L 245 245 Z"/> | ||
</g> | ||
</g> | ||
</svg> | ||
</div> | ||
|
||
<script> | ||
// Don't use window.onLoad like this in production, because it can only listen to one function. | ||
window.onload = function() { | ||
var beforePan | ||
|
||
beforePan = function(oldPan, newPan){ | ||
var stopHorizontal = false | ||
, stopVertical = false | ||
, gutterWidth = 100 | ||
, gutterHeight = 100 | ||
// Computed variables | ||
, sizes = this.getSizes() | ||
, leftLimit = -((sizes.viewBox.x + sizes.viewBox.width) * sizes.realZoom) + gutterWidth | ||
, rightLimit = sizes.width - gutterWidth - (sizes.viewBox.x * sizes.realZoom) | ||
, topLimit = -((sizes.viewBox.y + sizes.viewBox.height) * sizes.realZoom) + gutterHeight | ||
, bottomLimit = sizes.height - gutterHeight - (sizes.viewBox.y * sizes.realZoom) | ||
|
||
// If over left limit and panning to the left | ||
if (newPan.x < leftLimit && newPan.x <= oldPan.x) { | ||
stopHorizontal = true | ||
} | ||
|
||
// If over right limit and panning to the right | ||
if (newPan.x > rightLimit && newPan.x >= oldPan.x) { | ||
stopHorizontal = true | ||
} | ||
|
||
// If over top limit and panning to the top | ||
if (newPan.y < topLimit && newPan.y <= oldPan.y) { | ||
stopVertical = true | ||
} | ||
|
||
// If over bottom limit and panning to the bottom | ||
if (newPan.y > bottomLimit && newPan.y >= oldPan.y) { | ||
stopVertical = true | ||
} | ||
|
||
|
||
if (stopHorizontal && stopVertical) { | ||
// Fully prevent panning | ||
return false | ||
} else if (stopHorizontal || stopVertical) { | ||
// Prevent panning only on X or Y axys | ||
return {x: !stopHorizontal, y: !stopVertical} | ||
} | ||
} | ||
|
||
// Expose to window namespace for testing purposes | ||
window.panZoom = svgPanZoom('#limit-svg', { | ||
zoomEnabled: true | ||
, controlIconsEnabled: true | ||
, fit: 1 | ||
, center: 1 | ||
, beforePan: beforePan | ||
}); | ||
|
||
// panZoom.setBeforePan(beforePan) | ||
}; | ||
</script> | ||
|
||
</body> | ||
|
||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters