四月夕

导航

 

模拟苹果菜单的js代码是从网上看到的,用来做导航菜单还是蛮好看的。这里借鉴一下。

效果描述:当鼠标移动离哪个图片最近的时候,这个图片最大,鼠标离的图片越远,则图片越小;

原理:主要用到了三角形的勾股定理,可以根据两点的坐标,求到两点的距离,突然发现数学知识和js效果息息相关啊!

步骤:

1.插入大的图片,防止图片放大后失真,图片初始值为它的一半。

2.获取每个图片的中心点;

3.获取鼠标的位置;

4.使用勾股定理求出鼠标离图片中心的的距离;

代码入下:

document.mousemove=function(e){
        var e=window.event||e;
	for (var i = 0; i < oImg.length; i++) {
	        var x = oImg[i].offsetLeft + oImg[0].offsetWidth/2 ;//我这里每个图片都一样宽;
	        var y = oImg[i].offsetTop + oImg[0].offsetHeight/2 + box.offsetTop;	//box是包含图片外面的div,用来定位的;
		var a=e.clientX - x;
		var b=e.clientY - y;
		var c=Math.sqrt(Math.pow(a,2)+Math.pow(b,2)); //数学公式
		var d=1-c/300; //c除以300是用来降低基数的,因为c越大,代表鼠标离图片越远,则图片越小,所以用1-则得到相对应的基数;
		if(d<0.5){
			d=0.5  //图片本身不能小于它的一半
		}	
		oImg[i].style.width=d*128 + 'px';
		oImg[i].style.height=d*128 + 'px';	
	}; 
    
}

看着很难的一个效果,用初中学的知识就解决了,真的很意想不到。

 

posted on 2015-12-30 16:28  四月夕  阅读(530)  评论(0编辑  收藏  举报