Skip to content

daxhns/zooming

 
 

Repository files navigation

Zooming

Image zoom that makes sense. Demo

  • Pure JavaScript & built with mobile in mind.
  • Smooth animations with intuitive gestures.
  • Zoom into a hi-res image if supplied.
  • Easy to integrate & customizable.

Install

Install with your package manager:

yarn add zooming

npm install zooming --save

bower install zooming --save

Then load this module:

// e.g., via Browserify
var Zooming = require('zooming')

// or with ES6 syntax
import Zooming from 'zooming'

Alternatively, download and include build/zooming.js in your page.

Usage

Any image with attribute data-action="zoom" is zoomable by default, for example:

<img src="img/journey.jpg" data-action="zoom" />

You can also define zoomable images in JavaScript:

Zooming.listen('.selector') // or
Zooming.listen(element)

Add data-original attribute to supply a hi-res image when zooming in:

<img src="img/journey_thumbnail.jpg" data-action="zoom" data-original="img/journey.jpg" />

Development

Install yarn if haven't already.

Fork and clone it.

Under project folder:

yarn

yarn watch

Now open up index.html and play around with it!

Methods

.listen(selector | element)

Attach click listeners to all matched images.

.open(selector | element [, callback])

Open (zoom in) the matched image. Fires optional callback when the transition is done.

.close([callback])

Close (zoom out) if currently zoomed-in.

.grab(x, y [, start] [, callback])

Grab the current image given a mouse/touch position and apply extra zoom in.

  • x, y: Number. The point where the press happened.
  • start: Boolean. Indicate whether this is the initial grab (press mouse/finger down) or not.

.release([callback])

Release the current image.

.config(options)

Takes an options object. Available options:

Option Type Default Description
defaultZoomable String or Object 'img[data-action="zoom"]' Zoomable elements by default. It can be a css selector or an element.
enableGrab Boolean true To be able to grab and drag the image for extra zoom-in.
transitionDuration String '.4s' Transition duration. More
transitionTimingFunction String 'cubic-bezier(.4,0,0,1)' Transition timing function. More
bgColor String '#fff' Overlay background color.
bgOpacity Number 1 Overlay background capacity.
scaleBase Number 1.0 The base scale factor for zooming. By default scale to fit the window.
scaleExtra Number 0.5 The extra scale factor when grabbing the image.
scrollThreshold Number 40 How much scrolling it takes before closing out.
onOpen Function null A callback function that will be called when a target is opened and transition has ended. It will get the target element as the argument.
onClose Function null Same as above, except fired when closed.
onGrab Function null Same as above, except fired when grabbed.
onRelease Function null Same as above, except fired when released.
onBeforeOpen Function null A callback function that will be called before open.
onBeforeClose Function null A callback function that will be called before close.
onBeforeGrab Function null A callback function that will be called before grab.
onBeforeRelease Function null A callback function that will be called before release.

Credit

Inspired by zoom.js and zoomerang. First demo image from Journey. Second demo image source unknown.

About

Custom fork of zooming.js

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 77.6%
  • HTML 20.1%
  • CSS 2.3%