Изображение меняется в зависимости от положения мыши
Как я могу добиться изменения изображения в зависимости от положения мыши: слева, сверху слева, сверху, сверху справа, справа, снизу справа, снизу, снизу слева и при щелчке.
Вот пример того, что я пытаюсь сделать:
http://z6creation.net/fr/accueil
Я попытался поиграть с похожей темой, которую я нашел в stackru, но я не могу заставить работать слева, справа, сверху и снизу для правильной работы:
изменение изображения с помощью позиций мыши
вот код, который я использовал
> [jsfiddle][1]
>
>
> [1]: http://jsfiddle.net/hhy5N/43/
1 ответ
Решение
Вы можете увидеть, как он это делает, посмотрев его файлы js. У него есть файл js с именем site.faces.js
$.extend(Site, {
Faces: {
/* Attributes */
center: {
'left': 0,
'top': 0
},
config: {
'persons': ['eric', 'fabian', 'lievin', 'nicolas', 'pascale', 'fred'],
'nbpositions': 8
},
currentImage: null,
/* Methods */
angle: function (cursor) {
var angle = Math.atan2(0-cursor.y,0-cursor.x)*(180 / Math.PI);
if(angle < 0) { angle += 360;}
return angle;
},
distance: function(cursor) {
return Math.sqrt( Math.pow((0 - cursor.y),2) + Math.pow((0 - cursor.x),2) );
},
setCenterFace: function() {
Site.Faces.center = $("#face").offset();
if (parseInt($('#face').css('padding-top'))==0) {
Site.Faces.center.left += 720/2;
Site.Faces.center.top += 480/2;
} else {
Site.Faces.center.left += $("#face").width()/2;
Site.Faces.center.top += parseInt($('#face').css('padding-top'))/2;
}
},
init: function(config) {
if (typeof config!='undefined') {
$.extend(this.config, config);
}
if (typeof this.config.person=='undefined') {
this.config.person = this.config.persons[Math.floor(Math.random()*this.config.persons.length)];
}
/*
To force a face, use this...
this.config['person'] = 'fabian';
*/
$('#face').addClass('face-'+this.config['person']);
if ($('html').hasClass('touch')) {
$('#face').css({
'background-image': 'url('+Shin.href(';img/site/faces/'+this.config['person']+'.jpg')+')'
});
$('.face-'+this.config['person']).fadeIn();
$(window).resize(function(){
var bgPositionX = '0px';
if ($('#face').css('padding-top')!='0px') {
bgPositionX = "center";
}
$('#face').css('background-position', bgPositionX+' 0px');
});
$(window).resize();
} else {
$(window).resize(function(){
Site.Faces.setCenterFace();
Site.Faces.showImage(9);
});
Site.Faces.preloadImage(Shin.href(';img/site/faces/'+this.config['person']+'_mixed.jpg'), function() {
$(window).resize();
var offset = null;
var cursor = {
x: 0,
y: 0
};
$('body').mousemove(function(e) {
cursor.x = (e.pageX - Site.Faces.center.left);
cursor.y = (e.pageY - Site.Faces.center.top);
Site.Faces.manageImage(cursor, 'mousemove');
});
$('a, #face').bind('mousedown',function() {
Site.Faces.showImage(10)
});
});
}
},
manageImage: function(cursor, event) {
if (event == 'mousemove') {
var centerDistance = 100
if ($('#face').css('padding-top')!='0px') {
centerDistance = 50
}
if (this.distance(cursor)<centerDistance) {
if(Site.Faces.currentImage != 9 && Site.Faces.currentImage != 10) {
Site.Faces.showImage(9);
}
} else {
var angleByPosition = 360/this.config['nbpositions'];
var numImage = Math.ceil(( this.angle(cursor) + (angleByPosition/2))/angleByPosition);
numImage = (numImage>this.config['nbpositions'])?1:numImage;
if (Site.Faces.currentImage != numImage) {
Site.Faces.showImage(numImage);
}
}
}
},
preloadImage: function(src, callback) {
var img = new Image();
img.src = src;
img.onload = function () {
$('#face').css('background-image','url('+src+')');
$('.face-'+Site.Faces.config['person']).fadeIn();
if (typeof callback=="function") callback();
};
},
showImage: function(num) {
Site.Faces.currentImage = num;
var height = (480*(10-num));
var bgPositionX = '0px';
if ($('#face').css('padding-top')!='0px') {
height = (200*(10-num));
bgPositionX = "center";
}
$('#face').css({
backgroundPosition: bgPositionX+' -'+height+'px'
});
}
}
});