现在的位置: 首页 > 综合 > 正文

实现鼠标移在图片上出现渐现的效果

2013年12月05日 ⁄ 综合 ⁄ 共 2036字 ⁄ 字号 评论关闭
实现鼠标移在图片上出现渐现的效果

解决思路:

首先需要明确和鼠标事件相关,效果的实现主要是靠鼠标事件来驱动,而图片的渐现主要是与图片的透明度有关。

具体步骤:

方法一: 利用alpha滤镜和blendTrans滤镜实现
1.在类中定义所需要的两个滤镜。

<style>
.alpha{filter:alpha(opacity=20) blendTrans(duration=0.5)}
</style>

2.插入图片,并应用定义了滤镜的类。

<img src="demo.gif" class="alpha">

3.编写脚本。完整代码:

以下是引用片段:
<style>  
.alpha{filter:alpha(opacity=20) blendTrans(duration=0.5)}  
</style>  
<script>  
function fade(){  
//如果是onmouseover事件触发的函数,设置变量v的值为100,否则(为//onmouseout所触发时)为20  
var v=(event.type=="mouseover"?100:20)  
if(event.srcElement.tagName=="IMG"&&event.srcElement.className=="alpha")//如果对象是class为alpha的图片,执行下面的代码  
with(event.srcElement){  
filters[1].apply()//捕获对象内容的初始显示,为转换做必要的准备。  
//设置alpha滤镜参数opacity的值为变量v的值  
filters[0].opacity=v  
filters[1].play() //开始转换。  
}  
}  
document.onmouseover=fade//鼠标移上时触发fade函数  
document.onmouseout=fade //鼠标移开时触发fade函数  
</script>  
<img src="demo.gif" class="alpha">  

方法二:直接改变alpha滤镜参数opacity的值,以达到渐变的效果
1.在类中定义alpha滤镜。

<style>
.alpha{filter:alpha(opacity=20)}
</style>

2. 插入图片,并应用定义了滤镜的类。

<img src="demo.gif" class="alpha">

3. 编写脚本。完整代码:

以下是引用片段:
<style>  
.alpha{filter:alpha(opacity=20)}  
</style>  
<script>  
var obj,step  
function init(){  
if(!(event.srcElement.tagName=="IMG"&&event.srcElement.className=="alpha") ) //如果对象不是class为alpha的图片,退出函数  
return  
obj=event.srcElement.filters.alpha  
step=10 //alpha滤镜参数opacity的值的改变量  
if(event.type=="mouseout") //鼠标移开时step值为负  
step*=-1  
fade() //调用fade()函数  
}  
function fade(){  
//鼠标移上时alpha滤镜参数opacity的值小于100或 鼠标移开时alpha滤//镜参数opacity的值大于20,执行下面的代码  
if((step>0&&obj.opacity<100)||(step<0&&obj.opacity>20)){  
//alpha滤镜参数opacity的值以step为步长递增或减  
obj.opacity+=step  
setTimeout("fade()",10) //10毫秒后再次执行fade()函数  
}  
}  
document.onmouseover=init //鼠标移上时触发init()函数  
document.onmouseout=init //鼠标移开时触发init()函数  
</script>  
<img src="demo.gif" class="alpha">  

注意:方法一中的样式表里两滤镜的定义顺序不要改变,否则代码中的filters[1]要与filters[0] 交换,0表示对象的第一个滤镜,1表示对象的第二个滤镜,以此类推。
提示:
l event.type返回发生的事件,如本例中的"mouseover","mouseout"。
l 也可以在img元素内加入onmouseover="init()" onmouseout="init()"。
试一试:读者可以试着实现文本框背景的渐变
特别提示
本例代码运行后,图片的默认透明度为20%,而在鼠标移到图片上时图片将逐渐清晰(透明度从20%到100%逐渐变化),而鼠标移开后图片又渐渐恢复20%的透明度。

抱歉!评论已关闭.