Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/louisremi/jquery.transform.js

jQuery cssHooks adding a cross browser transform property to $.fn.css() and $.fn.animate()
https://github.com/louisremi/jquery.transform.js

Last synced: 9 days ago
JSON representation

jQuery cssHooks adding a cross browser transform property to $.fn.css() and $.fn.animate()

Awesome Lists containing this project

README

        

jquery.transform2d.js adds 2d transform capabilities to jQuery `css()` and `animate()` functions.

[Demo](http://louisremi.github.com/jquery.transform.js/index.html)

Usage:
======

Set transform with a string
---------------------------

$(elem).css('transform', 'translate(50px, 30px) rotate(25deg) scale(2,.5) skewX(-35deg)');
$(elem).animate({transform: 'translateY(-100px) rotate(1rad) scaleX(2) skewY(42deg)'});

You can use the following list of transform functions:
- `translateX(px)`
- `translateY(px)`
- combined: `translate(px, px)` *the second number is optional and defaults to 0*
- `scaleX()`
- `scaleY()`
- combined: `scale(, )` *the second number is optional and defaults to the value of the first one*
- `rotate()` *units for angles are *rad* (default), *deg* or *grad*.*
- `skewX()`
- `skewY()`
- `matrix(, , , , , )`*

*`matrix` gives you more control about the resulting transformation, using a [matrix construction set](http://www.useragentman.com/matrix/).
When using it in animations however, it makes it impossible to predict how the current and target transformations are going to be interpolated; there is no way to tell whether elements are going to rotate clockwise or anti-clockwise for instance.

Get transform
-------------

returns a computed transform matrix.

$(elem).css('transform') == 'matrix(0,1,-1,0,100,50)';

Relative animations
-------------------

Relative animations are possible by prepending "+=" to the transform string.

$(elem).css('transform', 'rotate(45deg)');
// using the following syntax, elem will always rotate 90deg anticlockwise
$(elem).animate({transform: '+=rotate(-90deg)'});

Limitations:
============

- requires jQuery 1.4.3+,
- Should you use the *translate* property, then your elements need to be absolutely positionned in a relatively positionned wrapper **or it will fail in IE**,
- transformOrigin is not accessible.

Why such restrictions with 'translate'?
---------------------------------------

Since translate is unavailable in IE<9, we have to emulate it using *top* and *left* properties of the element style.
This can, of course, only work if the elements are absolutely positionned in a relatively positionned wrapper.

Other plugins position the elements and wrap them transparently.
I think that transparently messing with the DOM often introduces unpredictible behavior.
Unpredictible behavior leads developpers to fear plugins.
*Fear leads to anger. Anger leads to hate. Hate leads to suffering.*
I prefer leaving this up to you.

License
=======

Dual licensed under GPL and MIT licenses.

Copyright (c) 2010 [Louis-Rémi Babé](http://twitter.com/louis_remi).