OS X like dock implemented in CSS only. This example is written as a Meteor project. It's based on my prototype jsfiddle.
This is a demo of an OSX dock using the magnification effect. I didn't see a whole lot of great examples - a few using javascript, etc... but I wanted to use CSS animations only. It's my first take on it, so it's not refined and I'm sure it can be simplified and improved.
The animation is OK but not perfect; the transition between elements could be modified (in the CSS animation code timing) so that there is a little longer persistence when moving from item to item.
I'm running the demo as a Meteor application, so button clicks, etc... are handled by the .js file. When you click on a dock element, it lets you know whch one it was. The id is set in the HTML code.
Dock elements are added in HTML (in the 'dock' template) as follows:
<div class="dock-wrapper"> <--- main wrapper for dock (top and bottom)
<div class="dock">
<div class="app" id="1" data-id="1"> <--- Set each element id and data-id
<div class="top"></div>
<div class="bottom-wrapper"> <--- This is the dock item reflection
<div class="bottom"></div>
</div>
</div>
<div class="app" id="2" data-id="2">
...
</div>
...
</div>
<div class="dock-shelf-wrapper">
<div class="dock-shelf"></div> <--- This is the shelf that everything sits on
</div>
</div>
All the work happens in the SASS file dock.scss
file.
The same image is used for all the dock items; it's loaded in 2 locations in the CSS file:
div.dock {
...
& > .app {
...
background-image:url('webdragon-icon.png');
...
}
& > .app > .bottom-wrapper > .bottom {
...
background:url('webdragon-icon.png');
...
}
}
You'll have to take care of this by pulling it out of the CSS and placing it back in the HTML code, referencing it by the id or data-id parameters OR better yet, use the nth-of-type selector in your CSS code:
& > .app:nth-of-type(2) {
background: url('kitchen-sink.png');
}
The former will let you create dock elements dynamically as you need them; the latter if you have a fixed dock layout ahead of time.