下のjsfiddleでは、カーソルの最初の想定位置に移動するのではなく、黄色と赤の円を最初に中央に表示しようとしています。これは、カーソルがまだ実際の画面にないため、(0,0)ですページ(私が正しく推測している場合)。
http://jsfiddle.net/fhmkf/220/
カーソルの最初の配置を定義できる方法はありますか?つまり、計算時です。(window).mousemove(function(e){...
特にe.pageX
and e.pageY
?
js は次のようになります。
var Circle = function(container, follower, r){
var center = {
x: $(container).width()/2 - r,
y: $(container).height()/2 - r
};
var distanceThreshold = $(container).width()/2 - r;
var mouseX = 0, mouseY = 0;
$(window).mousemove(function(e){
var d = {
x: e.pageX - center.x,
y: e.pageY - center.y
};
var distance = Math.sqrt(d.x*d.x + d.y*d.y);
if (distance < distanceThreshold) {
mouseX = e.pageX;
mouseY = e.pageY;
} else {
mouseX = d.x / distance * distanceThreshold + center.x;
mouseY = d.y / distance * distanceThreshold + center.y;
}
});
// cache the selector
var follower = $(follower);
var xp = 0, yp = 0;
var loop = setInterval(function(){
// change 12 to alter damping higher is slower
xp += (mouseX - xp) / 2;
yp += (mouseY - yp) / 2;
follower.css({left:xp, top:yp});
}, 30);
};
var c1 = new Circle(".container", "#follower", 15);
var c2 = new Circle(".container2", "#follower2", 25);