在iOS平台上有不少实用的辅助功能,其中小编最爱的功能就非“放大镜”莫属了。在浏览的时候iOS的“放大镜”可是派的上大用场呢。在这期的<毛毛分享>中,毛毛为大家介绍的是一款利用CSS和JS制作的iOS风格放大镜。闲话少说,我们先看看效果如何!
放大镜效果
看完效果小编拉你们看看代码:
HTML
<div class="magnify">
<div class="large"></div>
<!—此处放原图 -->
<img class="small" src="XXXXX.jpg" width="400"/>
</div>
CSS
* {margin: 0; padding: 0;}
.magnify {width: 400px; margin: 50px auto; position: relative; cursor: none}
.large {
width: 175px; height: 175px;
position: absolute;
border-radius: 100%;
box-shadow: 0 0 0 7px rgba(255, 255, 255, 0.85),
0 0 7px 7px rgba(0, 0, 0, 0.25),
inset 0 0 40px 2px rgba(0, 0, 0, 0.25);
display: none;
}
.small { display: block; }
JavaScript
$(document).ready(function(){
var native_width = 0;
var native_height = 0;
$(".large").css("background","url('" + $(".small").attr("src") + "') no-repeat");
$(".magnify").mousemove(function(e){
if(!native_width && !native_height)
{
var image_object = new Image();
image_object.src = $(".small").attr("src");
native_width = image_object.width;
native_height = image_object.height;
}
else
{
var magnify_offset = $(this).offset();
var mx = e.pageX - magnify_offset.left;
var my = e.pageY - magnify_offset.top;
if(mx < $(this).width() && my < $(this).height() && mx > 0 && my > 0)
{
$(".large").fadeIn(100);
}
else
{
$(".large").fadeOut(100);
}
if($(".large").is(":visible"))
{
var rx = Math.round(mx/$(".small").width()*native_width - $(".large").width()/2)*-1;
var ry = Math.round(my/$(".small").height()*native_height - $(".large").height()/2)*-1;
var bgp = rx + "px " + ry + "px";
var px = mx - $(".large").width()/2;
var py = my - $(".large").height()/2;
$(".large").css({left: px, top: py, backgroundPosition: bgp});
}
}
})
})})
本文由慕课网编辑:慕课网(http://www.imooc.com) 转载请注明出处。