Skip to content

ZoomAny.js - Zoom anything, using Vanilla JavaScript. Also supports TypeScript

License

Notifications You must be signed in to change notification settings

jurrevanderschaaf/zoom-any-js

 
 

Repository files navigation

ZoomAny.js

Zoom literally ANY HTML Element using pure vanilla JavaScript.

*Supports TypeScript

Features

  • 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

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

Basic Usage

To get started, add the class "zoomable" to the element you want to enable zoom on:

<img class="zoomable" src="public/img.png">

NPM + Bundler:

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()

CDN:

<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! 🎉

Examples

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>

Wrapper Zoomed Out

Wrapper Zoomed In

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">

Bounded Zoomed Out

Bounded Zoomed In

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">

Options

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

Control via JavaScript

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

About

ZoomAny.js - Zoom anything, using Vanilla JavaScript. Also supports TypeScript

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 91.6%
  • HTML 4.8%
  • CSS 1.9%
  • JavaScript 1.7%