Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dmotz/hexaflip
🧊 Visualizes arrays as cube interfaces
https://github.com/dmotz/hexaflip
animation coffeescript javascript jquery
Last synced: 3 days ago
JSON representation
🧊 Visualizes arrays as cube interfaces
- Host: GitHub
- URL: https://github.com/dmotz/hexaflip
- Owner: dmotz
- License: mit
- Created: 2013-03-07T16:03:50.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2018-03-16T17:10:21.000Z (almost 7 years ago)
- Last Synced: 2024-04-27T02:01:14.755Z (8 months ago)
- Topics: animation, coffeescript, javascript, jquery
- Language: CoffeeScript
- Homepage: http://oxism.com/hexaflip
- Size: 3.54 MB
- Stars: 137
- Watchers: 4
- Forks: 30
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![HexaFlip](http://oxism.com/hexaflip/demo/hexaflip.png)
# [HexaFlip](http://oxism.com/hexaflip/)
### Transform arrays of any length into cubes with infinite sides.
### Featuring touch/mouse interaction, getter/setter methods, zero dependencies, and jQuery support.
[Dan Motzenbecker](http://oxism.com), MIT License[@dcmotz](http://twitter.com/dcmotz)
Take a look at the [Codrops article](http://tympanus.net/codrops/2013/03/07/hexaflip-a-flexible-3d-cube-plugin)
for a guide through the process and some [demos](http://tympanus.net/Tutorials/HexaFlip).## Basic Usage
Create an instance by passing a DOM element and a key-value set of arrays:
```javascript
var cubeSet = new HexaFlip(document.getElementById('my-el'),
{
prince: ['For You', 'Prince', 'Dirty Mind', 'Controversy', '1999', 'Around the World in a Day'],
curtis: ['Curtis', 'Roots', 'Super Fly', 'Back to the World', 'Got to Find a Way', 'Sweet Exorcist']
}
);// you can also pass a selector string and HexaFlip will take the first matching element:
var firstDiv = new HexaFlip('div');
```If a value is a URL, HexaFlip will set that side to the image it points to, preloading it automatically.
You can also pass objects as values with `style` and `value` keys
for some meticulous customization of different sides.
Make the former an object literal of CSS properties to customize the styling of that cube face.```javascript
var colorCube = new HexaFlip('#color-cube',
{
chromaSet: [
{
value: 'orange',
style: {
backgroundColor: '#e67e22',
fontWeight: 100
}
},
{
value: 'teal',
style: {
backgroundColor: '#1abc9c',
fontFamily: 'Futura'
}
},
{
value: 'yellow',
style: {
backgroundColor: '#f1c40f',
textDecoration: 'underline'
}
}
]
}
);
```To enable horizontal rotation (like the photos above), pass it in the options:
```javascript
var horizontalCube = new HexaFlip('#my-el2',
{
letters: ['α', 'β', 'γ', 'δ', 'ε', 'ζ', 'η', 'θ', 'ι', 'κ', 'λ', 'μ',
'ν', 'ξ', 'ο', 'π', 'ρ', 'σ', 'τ', 'υ', 'φ', 'χ', 'ψ', 'ω']
},
{
horizontalFlip: true,
size: 300
}
);
```To set and get the values of the cubes:
```javascript
cubeSet.setValue({ prince: '1999', curtis: 'Roots' });
cubeSet.getValue();
```To rotate the cubes to the next or previous sides:
```javascript
cubeSet.flip();
cubeSet.flipBack();
```## Events
To add custom DOM events, simply pass a key value object called `domEvents` to the instance's options:
```javascript
//...
},
{
domEvents: {
mouseover: function(e, face, cube) {
face.style.backgroundColor = 'red';
},
mouseout: function(e, face, cube) {
face.style.backgroundColor = 'blue';
},
click: function(e, face, cube) {
console.log(face.innerHTML);
}
}
}
);
```Every callback is passed the event object, the face element that triggered the event, and the cube
element the face belongs to. The callback is automatically bound to the HexaFlip instance
so `this` works properly.