Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

cropbox

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cropbox

jQuery plugin for in-place image cropping (zoom & pan, as opposed to select and drag). This plugin depends only on jQuery. If either `Hammer.js` or `jquery.hammer.js` is loaded, the cropbox plugin will support gestures for panning and zooming the cro

  • 0.1.9
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
842
increased by15.18%
Maintainers
1
Weekly downloads
 
Created
Source

jquery-cropbox plugin.

jQuery plugin for in-place image cropping (zoom & pan, as opposed to select and drag).

This plugin depends only on jQuery. If either Hammer.js or jquery.hammer.js is loaded, the cropbox plugin will support gestures for panning and zooming the cropbox. Similary, if the jquery.mousewheel.js plugin is loaded, then the cropbox plugin will support zoom in & out using the mousewheel. All dependencies on third party libraries (other than jQuery) are strictly optional. Support for CommonJS and AMD loading is built in.

In browsers that support the HTML5 FIle API and Canvas API, the cropbox plugin provides mehtods to crop the image on the client and obtain the resulting cropped image as a Data URL or a binary blob to upload it to the server.

Check out the plugin in action here http://acornejo.github.io/jquery-cropbox/

History: This plugin started as a fork of jQcrop, and added touch support, mousewheel support and client resize support through the canvas api.

Install with Bower: bower install cropbox

Usage

	$('yourimage').cropbox({
	    width: 200,
		height: 200
	}, function() {
		//on load
		console.log('Url: ' + this.getDataURL());
	}).on('cropbox', function(e, data) {
        console.log('crop window: ' + data);
	});

Options

OptionTypeDefaultRequiredDescription
widthinteger200noWidth in pixels of the cropping window
heightinteger200noHeight in pixels of the cropping window
zoominteger10noNumber of incremental zoom steps. With the default of 10, you have to click the zoom-in button 9 times to reach 100%.
maxZoomnumber1.0noMaximum zoom value. With the default of 1.0 users can't zoom beyond the maximum image resolution.
controlsstring/jquerynullnoIf not null, this is the entire html block that should appear on hover over the image for instructions and/or buttons (could include the zoom in/out buttons for example). If null, the default html block is used which has the text "Click to drag" and the zoom in/out buttons. Use false to disable controls.
result{cropX:number, cropY:number, cropW:number, cropH:number}nullnoSet the initial cropping area
showControlsnever, always, hover, autoautonoThis flag is used to determine when to display the controls. Never, always and hover do exactly what you would expect (never show them, always show them, show them on hover). The auto flag is the same as the hover flag, except that on mobile devices it always shows the controls (since there is no hover event).

Methods

NameParametersDescription
zoomIn(none)Increase image zoom level by one step
zoomOut(none)Decrease image zoom level by one step
zoompercentSet zoom leevl to a value between 0 and 1. Need to call update to reflect the changes.
drag{startX: integer, startY: integer, dx: integer, dy: integer}Simulate image dragging, starting from (startX,startY) and moving a delta of (dx,dy). Need to call update to reflect the changes.
setCrop{cropX: number, cropY: number, cropW: number, cropH: number}Set crop window.
update(none)Update the cropped result (must call after zoom and drag).
getDataURL(none)Generate a URL for the cropped image on the client (requires HTML5 compliant browser).
getBlob(none)Generate a Blob with the cropped image (requires HTML5 compliant browser).
remove(none)Remove the cropbox functionality from the image.

Event

To get the crop results, bind a function on the cropbox event or read the object's result property .

    $('yourimage').cropbox({width: 250, height: 250})
    .on('cropbox', function (e, result) {
        console.log(result);
    });

A reference to the cropbox object can be accessed like so:

	var crop = $('yourimage').data('cropbox');
	console.log(crop.result);

or inside the onload function:

	var crop = $('yourimage').cropbox({}, function() {
		console.log(this.result);
	});

You then have access to all the properties and methods used for that specific element.

Bug Reporting

Use the issues section to report any problems or questions regarding jquery-cropbox.

Please understand that I develop this plugin in my spare time, which is limited. To make the best use of my time, I ask that you submit a detailed bug report and include a jsfiddle that exhibits the problem, otherwise I won't be able to offer much help.

A sample jsfiddle is provided here, fork it and create a minimal example that recreates the problem you are having and provide a link to it in the issue.

FAQs

Package last updated on 18 Oct 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc