Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/repp/BalancedGallery
A balanced photo gallery plugin for jQuery.
https://github.com/repp/BalancedGallery
image-gallery javascript jquery jquery-plugin linear-parition
Last synced: 3 months ago
JSON representation
A balanced photo gallery plugin for jQuery.
- Host: GitHub
- URL: https://github.com/repp/BalancedGallery
- Owner: repp
- License: wtfpl
- Created: 2013-08-20T16:56:37.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2017-09-16T12:30:07.000Z (over 7 years ago)
- Last Synced: 2024-08-02T16:42:48.643Z (6 months ago)
- Topics: image-gallery, javascript, jquery, jquery-plugin, linear-parition
- Language: JavaScript
- Homepage:
- Size: 229 KB
- Stars: 155
- Watchers: 13
- Forks: 34
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-jquery - BalancedGallery - A balanced photo gallery plugin for jQuery. (Images / Data Table)
README
Balanced Gallery
=========
Balanced Gallery is a jQuery plugin that evenly distributes photos across rows or columns, making the most of the space provided.
Photos are scaled based on the size of the 'container' element by default, making Balanced Gallery a great choice for responsive websites.Demos
-------
[Horizontal Gallery Demo](http://www.ryanepp.com/demos/balanced_gallery/horizontal)[Vertical Gallery Demo](http://www.ryanepp.com/demos/balanced_gallery/vertical)
Quick Start
----------
Import JQuery and the Plugin:
``` html```
Call the plugin on the element containing the gallery's images:
``` javascript
// wait for the page to load
$(window).load(function() {
$('#myGallery').BalancedGallery({ /* options */ });
});
```Options
-------
``` javascript
var defaults = {
autoResize: true, // re-partition and resize the images when the window size changes
background: null, // the css properties of the gallery's containing element
idealHeight: null, // ideal row height, only used for horizontal galleries, defaults to half the containing element's height
idealWidth: null, // ideal column width, only used for vertical galleries, defaults to 1/4 of the containing element's width
maintainOrder: true, // keeps images in their original order, setting to 'false' can create a slightly better balance between rows
orientation: 'horizontal', // 'horizontal' galleries are made of rows and scroll vertically; 'vertical' galleries are made of columns and scroll horizontally
padding: 5, // pixels between images
shuffleUnorderedPartitions: true, // unordered galleries tend to clump larger images at the begining, this solves that issue at a slight performance cost
viewportHeight: null, // the assumed height of the gallery, defaults to the containing element's height
viewportWidth: null // the assumed width of the gallery, defaults to the containing element's width
};
```Browser Compatibility
------------
Tested and working in:
* Chrome
* Safari
* FireFox
* IE 9+
* Mobile Safari
* Mobile ChromeContributing
------------
If you'd like to contribute a feature or bugfix, that's awesome. Go for it. As of right now I don't have a specific set of guidelines for contributions but try to follow the plugin's current coding style.License
---------
Copyright (c) 2013 [Ryan Epp](https://twitter.com/ryanEpp) Licensed under the WTFPL license.Acknowledgements
----------------
Inspired by [crispymtn](http://www.crispymtn.com/stories/the-algorithm-for-a-perfectly-balanced-photo-gallery).
Linear partitioning algorithm ported from [Óscar López](http://stackoverflow.com/questions/7938809/dynamic-programming-linear-partitioning-please-help-grok/7942946#7942946)