Skip to content

junishanghai/jquery-cropbox

 
 

Repository files navigation

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.

Usage

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

Options

Option Type Default Required Description
width integer 200 no Width in pixels of the cropping window
height integer 200 no Height in pixels of the cropping window
zoom integer 10 no Number of incremental zoom steps. With the default of 10, you have to click the zoom-in button 9 times to reach 100%.
controls string/jquery null no If 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 '' (or false) if you don't want anything to appear.

Methods

Name Parameters Description
zoomIn (none) Increase image zoom level by one step
zoomOut (none) Decrease image zoom level by one step
zoom percent Set 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.
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);

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

About

jQuery Cropbox plugin

Resources

License

Stars

Watchers

Forks

Packages

No packages published