- TypeScript support
- Uses relative and not absolute position ( keep same place, just make zoomable )
- Enable zoom for any HTML Element you want, not just images
- Boundings
- Fully controlable via functions and data-* attributes
Install via NPM:
npm i zoom-any-js
Or via CDN:
CSS: https://cdn.jsdelivr.net/npm/zoom-any-js@latest/dist/zoom-any-js.css
JS: https://cdn.jsdelivr.net/npm/zoom-any-js@latest/dist/zoom-any-js.js
To get started, add the class "zoomable" to the element you want to enable zoom on:
<img class="zoomable" src="public/img.png">
Then create a new instance in JavaScript, and import the CSS:
import ZoomAnyJs from "zoom-any-js";
import "zoom-any-js/dist/zoom-any-js.css";
const zoom = new ZoomAnyJs()
<link type="text/css" rel="stylesheet" href="https://cdn.jsdelivr.net/npm/zoom-any-js@latest/dist/zoom-any-js.css">
<script type="module">
import ZoomAnyJs from "https://cdn.jsdelivr.net/npm/zoom-any-js@latest/dist/zoom-any-js.js"
const zoom = new ZoomAnyJs()
</script>
Now try to zoom into your image, it should start to zoom! 🎉
Go to center on click:
document.getElementById("img").addEventListener("click", () => {
zoom.center()
zoom.apply()
})
Zoom into the screen center:
zoom.zoomAt(1.1, { x: window.innerWidth / 2, y: window.innerHeight / 2 })
zoom.apply()
Using the wrapper class:
<div class="wrapper">
<button class="zoomable" data-max-zoom="2000" data-min-zoom="20" data-bounds style="background-color: red; color: white; width: 500px; height: 300px; font-size: 30px;">TEEEEEEST</button>
</div>
This keeps it inside the wrapper div and makes you zoom into it without any overflow.
Whatsapp or Windows Photos like Image Zoom:
<img class="zoomable" data-bounds src="test/img/1.png">
Multiple images: Each gets their own instance, and you pass a css selector into the constructor like this:
const zoom1 = new ZoomAnyJs()
const zoom2 = new ZoomAnyJs(".zoom2")
const zoom3 = new ZoomAnyJs("#zoom3")
<img class="zoomable" data-bounds src="test/img/1.png">
<img class="zoom2" data-bounds src="test/img/2.png">
<img id="zoom3" data-bounds src="test/img/3.png">
Basic options can be set by using data-* attributes on the element you zoom:
- data-max-zoom: Set maximimum zoom. Default: 4000
- data-min-zoom: Set minimum zoom. Default: 10
- data-bounds: Enable fit to bounding. Default: false
- data-origin-parent: Use the offsetParent as origin for fitting bounding. Else it uses window. Default: false
The default zoom level is 100, which is the original size and represents a scale of 1.0
The instance, so in this case const zoom, has many functions which you can use to fully control the libary.
You need to call .apply() to update the view to the changes!!!
All available functions:
- center(): Moves the image to the center of the window or the offsetParent when using data-origin-parent
- fitToBounds(): Fits into the bounds when using data-bounds, else it just returns void
- zoomAt(amplitude: number, pos: {x: number, y: number}): Move to the position by the amplitude. Amplitude > 1 zooms in and amplitude < 1 zooms out
- addListeners(): Adds the event listeners
- removeListeners(): Removes the event listeners
- apply(): Has to be callen to update the view. Without calling it, you cant see any change
- destroy(): Makes the element "normal" again, as before running the zoom library
- reset(): Resets position and zoom to default values
- getZoom(): Returns the zoom
- setZoom(value: number): Sets the zoom
- getPos(): Returns the position
- setPos(value: {x: number, y: number}): Sets the position