为了账号安全,请及时绑定邮箱和手机立即绑定

<毛毛分享>在网页中制作iOS风格放大镜

标签:
iOS C

在iOS平台上有不少实用的辅助功能,其中小编最爱的功能就非“放大镜”莫属了。在浏览的时候iOS的“放大镜”可是派的上大用场呢。在这期的<毛毛分享>中,毛毛为大家介绍的是一款利用CSS和JS制作的iOS风格放大镜。闲话少说,我们先看看效果如何!
图片描述

    放大镜效果

看完效果小编拉你们看看代码:

HTML

<div class="magnify">

    <div class="large"></div>

    <!—此处放原图 -->
    <img class="small" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="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) 转载请注明出处。

点击查看更多内容
22人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
学生
手记
粉丝
8
获赞与收藏
1131

关注作者,订阅最新文章

阅读免费教程

感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消