- Автор темы
- #1
Здравствуйте.Есть скрипт для увеличения изображения при наведении мышки.Но есть одна проблема.Не получается заставить его сдвигать изображение влево ,а ни вправо при увеличении.
Кто может подскажите как исправить.
if (document.images){
(function(){
var cos, a = /Apple/.test(navigator.vendor), times = a? 20 : 40, speed = a? 40 : 20;
var expConIm = function(im){
im = im || window.event;
if (!expConIm.r.test (im.className))
im = im.target || im.srcElement || null;
if (!im || !expConIm.r.test (im.className))
return;
var e = expConIm,
widthHeight = function(dim){
return dim[0] * cos + dim[1] + 'px';
},
resize = function(){
cos = (1 - Math.cos((e.ims.jump / times) * Math.PI)) / 2;
im.style.width = widthHeight (e.ims.w);
im.style.height = widthHeight (e.ims.h);
if (e.ims.d && times > e.ims.jump){
++e.ims.jump;
e.ims.timer = setTimeout(resize, speed);
} else if (!e.ims.d && e.ims.jump > 0){
--e.ims.jump;
e.ims.timer = setTimeout(resize, speed);
}
}, d = document.images, i = d.length - 1;
for (i; i > -1; --i)
if(d == im) break;
i = i + im.src;
if (!e.ims){
e.ims = {im : new Image(), jump : 0};
e.ims.im.onload = function(){
e.ims.w = [e.ims.im.width - im.width, im.width];
e.ims.h = [e.ims.im.height - im.height, im.height];
e (im);
};
e.ims.im.src = im.src;
return;
}
if (e.ims.timer) clearTimeout(e.ims.timer);
e.ims.d = !e.ims.d;
resize ();
};
expConIm.ims = {};
expConIm.r = new RegExp('\\bexpando\\b');
if (document.addEventListener){
document.addEventListener('mouseover', expConIm, false);
document.addEventListener('mouseout', expConIm, false);
}
else if (document.attachEvent){
document.attachEvent('onmouseover', expConIm);
document.attachEvent('onmouseout', expConIm);
}
})();
}
Кто может подскажите как исправить.
if (document.images){
(function(){
var cos, a = /Apple/.test(navigator.vendor), times = a? 20 : 40, speed = a? 40 : 20;
var expConIm = function(im){
im = im || window.event;
if (!expConIm.r.test (im.className))
im = im.target || im.srcElement || null;
if (!im || !expConIm.r.test (im.className))
return;
var e = expConIm,
widthHeight = function(dim){
return dim[0] * cos + dim[1] + 'px';
},
resize = function(){
cos = (1 - Math.cos((e.ims.jump / times) * Math.PI)) / 2;
im.style.width = widthHeight (e.ims.w);
im.style.height = widthHeight (e.ims.h);
if (e.ims.d && times > e.ims.jump){
++e.ims.jump;
e.ims.timer = setTimeout(resize, speed);
} else if (!e.ims.d && e.ims.jump > 0){
--e.ims.jump;
e.ims.timer = setTimeout(resize, speed);
}
}, d = document.images, i = d.length - 1;
for (i; i > -1; --i)
if(d == im) break;
i = i + im.src;
if (!e.ims){
e.ims = {im : new Image(), jump : 0};
e.ims.im.onload = function(){
e.ims.w = [e.ims.im.width - im.width, im.width];
e.ims.h = [e.ims.im.height - im.height, im.height];
e (im);
};
e.ims.im.src = im.src;
return;
}
if (e.ims.timer) clearTimeout(e.ims.timer);
e.ims.d = !e.ims.d;
resize ();
};
expConIm.ims = {};
expConIm.r = new RegExp('\\bexpando\\b');
if (document.addEventListener){
document.addEventListener('mouseover', expConIm, false);
document.addEventListener('mouseout', expConIm, false);
}
else if (document.attachEvent){
document.attachEvent('onmouseover', expConIm);
document.attachEvent('onmouseout', expConIm);
}
})();
}