Commit b9b2413b by DmitryBaranovskiy

1.4.0

• Touch events support
• rgba support
• new method drag
• document.onmousemove = f → Raphael.mousemove(f)
• resetScale method
• scaling text will change it position, but not size
• sets now have type “set”
• rect in VML doesn’t recreate itself on change of the R
• pathes are not rounded to the nearby pixels anymore
• Various small bug fixes and improvements
• added preventDefault and stopPropagation to event object
parent 8fedd8a0
...@@ -2476,7 +2476,13 @@ Raphael = (function () { ...@@ -2476,7 +2476,13 @@ Raphael = (function () {
} }
// Events // Events
var addEvent = (function () { var preventDefault = function () {
this.returnValue = false;
},
stopPropagation = function () {
this.cancelBubble = true;
},
addEvent = (function () {
if (doc.addEventListener) { if (doc.addEventListener) {
return function (obj, type, fn, element) { return function (obj, type, fn, element) {
var f = function (e) { var f = function (e) {
...@@ -2501,7 +2507,10 @@ Raphael = (function () { ...@@ -2501,7 +2507,10 @@ Raphael = (function () {
} else if (doc.attachEvent) { } else if (doc.attachEvent) {
return function (obj, type, fn, element) { return function (obj, type, fn, element) {
var f = function (e) { var f = function (e) {
return fn.call(element, e || win.event); e = e || win.event;
e.preventDefault = e.preventDefault || preventDefault;
e.stopPropagation = e.stopPropagation || stopPropagation;
return fn.call(element, e);
}; };
obj.attachEvent("on" + type, f); obj.attachEvent("on" + type, f);
var detacher = function () { var detacher = function () {
...@@ -2544,6 +2553,7 @@ Raphael = (function () { ...@@ -2544,6 +2553,7 @@ Raphael = (function () {
Element[proto].drag = function (onmove, onstart, onend) { Element[proto].drag = function (onmove, onstart, onend) {
this._drag = {}; this._drag = {};
var el = this.mousedown(function (e) { var el = this.mousedown(function (e) {
e.preventDefault();
this._drag.x = e.clientX; this._drag.x = e.clientX;
this._drag.y = e.clientY; this._drag.y = e.clientY;
this._drag.id = e.identifier; this._drag.id = e.identifier;
...@@ -2551,21 +2561,24 @@ Raphael = (function () { ...@@ -2551,21 +2561,24 @@ Raphael = (function () {
Raphael.mousemove(move).mouseup(up); Raphael.mousemove(move).mouseup(up);
}), }),
move = function (e) { move = function (e) {
var x = e.clientX,
y = e.clientY;
if (supportsTouch) { if (supportsTouch) {
for (var i = 0, ii = e.touches.length; i < ii; i++) { var i = e.touches.length,
var touch = e.touches[i]; touch;
while (i--) {
touch = e.touches[i];
if (touch.identifier == el._drag.id) { if (touch.identifier == el._drag.id) {
onmove && onmove.call(el, touch.clientX - el._drag.x, touch.clientY - el._drag.y, touch.clientX, touch.clientY); x = touch.clientX;
y = touch.clientY;
e.preventDefault(); e.preventDefault();
break; break;
} }
} }
} else { } else {
onmove && onmove.call(el, e.clientX - el._drag.x, e.clientY - el._drag.y, e.clientX, e.clientY); e.preventDefault();
e.preventDefault && e.preventDefault();
e.returnValue = false;
return false;
} }
onmove && onmove.call(el, x - el._drag.x, y - el._drag.y, x, y);
}, },
up = function () { up = function () {
el._drag = {}; el._drag = {};
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment