You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Dave Lasley 112eba3e12 web_widget_darkroom: Add o2m DarkroomJS widget 9 years ago
..
lib web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
.editorconfig web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
.gitignore web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
CHANGELOG.md web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
LICENSE web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
README.md web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
bower.json web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
gh-pages.sh web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
gulpfile.js web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago
package.json web_widget_darkroom: Add o2m DarkroomJS widget 8 years ago

README.md

DarkroomJS

DarkroomJS is a JavaScript library which provides basic image editing tools in your browser, such as rotation or cropping. It is based on the awesome FabricJS library to handle images in HTML5 canvas.

Demo

Try the online demo at http://mattketmo.github.io/darkroomjs

The library is currently work in progress. I know there is some bug especially when resizing the crop zone. Feel free to fork the project or report issues on GitHub. All ideas are also welcome.

Building

  • Install Node & npm.
  • Run npm install to build dependencies.
  • Run npm start to build the assets and start the demo webserver.

Usage

Simply instanciate a new Darkroom object with a reference to the image element:

<img src="some-image.jpg" id="target">
<script>
  new Darkroom('#target');
</script>

You can also pass some options:

new Darkroom('#target', {
  // Canvas initialization size
  minWidth: 100,
  minHeight: 100,
  maxWidth: 500,
  maxHeight: 500,

  // Plugins options
  plugins: {
    crop: {
      minHeight: 50,
      minWidth: 50,
      ratio: 1
    },
    save: false // disable plugin
  },

  // Post initialization method
  initialize: function() {
    // Active crop selection
    this.plugins['crop'].requireFocus();

    // Add custom listener
    this.addEventListener('core:transformation', function() { /* ... */ });
  }
});

Why?

It's easy to get a javascript script to crop an image in a web page. But if your want more features like rotation or brightness adjustment, then you will have to do it yourself. No more jQuery plugins here. It only uses the power of HTML5 canvas to make what ever you want with your image.

The concept

The library is designed to be easily extendable. The core script only transforms the target image to a canvas with a FabricJS instance, and creates an empty toolbar. All the features are then implemented in separate plugins.

Each plugin is responsible for creating its own functionality. Buttons can easily be added to the toolbar and binded with those features.

Contributing

Run npm develop to build and watch the files while developing.

License

DarkroomJS is released under the MIT License. See the bundled LICENSE file for details.