jquery 图片缩放拖动的简单实例


Posted in Javascript onJanuary 08, 2014

一、不使用jquery,简单的缩放:

<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<TITLE>onMouseWheel</TITLE> 
<SCRIPT> 
var count = 10; 
function Picture() 
{ 
count = Counting(count); 
Resize(count); 
return false; 
} 
function Counting(count){ 
if (event.wheelDelta >= 120) 
count++; 
else if (event.wheelDelta <= -120) 
count--; 
return count; 
} 
function Resize(count){ 
oImage.style.zoom = count + '0%'; 
oCounter.innerText = count + '0%'; 
} 
</SCRIPT> 
</HEAD> 
<BODY> 
<div align=center> 
<span style="font-weight:bold">Size = 
<span id="oCounter" style="color:red;">100%</span></span> 
<img id="oImage" src="images/aaa.gif" onmousewheel="return Picture();" > 
</div> 
</BODY> 
</HTML>

一、使用jquery,实现缩放和拖动:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title></title>
    <style type="text/css">
        #imgBox
        {
            width: 200px;
            height: 200px;
            background: red;
            overflow: hidden;
            margin: auto;
            position: relative;
        }
        #imgMain
        {
            position: relative;
            top: -200px;
        }
    </style>
    <script src="js/jquery-1.2.6.js" type="text/javascript"></script>
    <script type="text/javascript" language="javascript">
        $(function () {
            var event;
            if ($.browser.mozilla) {
                event = "DOMMouseScroll";
            }
            else {
                event = "mousewheel";
            }
            $("#divBlock").bind(event,
        function (e) {
            var evt = window.event || e;
            var newWidth;
            var newHeight;
            var newLeft;
            var newTop;
            var overHeight = $("#divBlock").height();
            if (evt.detail > 0 || evt.wheelDelta < 0) {
                newWidth = $("#imgMain").width() - 20;
                newHeight = $("#imgMain").height() - 20;
                newLeft = $("#imgMain").position().left + 10;
                newTop = $("#imgMain").position().top + 10 - overHeight;
            }
            else {
                newWidth = $("#imgMain").width() + 20;
                newHeight = $("#imgMain").height() + 20;
                newLeft = $("#imgMain").position().left - 10;
                newTop = $("#imgMain").position().top - 10 - overHeight;
            }
            $("#imgMain").css({ left: newLeft + "px", top: newTop + "px" });
            $("#imgMain").width(newWidth);
            $("#imgMain").height(newHeight);
        }
        );
            $("#divBlock").bind("mousedown", function (e) {
                var xo = e.pageX;
                var yo = e.pageY;
                var imgLeft = $("#imgMain").position().left;
                var imgTop = $("#imgMain").position().top;
                var overHeight = $("#divBlock").height();
                $("#divBlock").bind("mousemove", function (e) {
                    window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();
                    var x = e.pageX;
                    var y = e.pageY;
                    var bX = $("#imgBox").offset().left;
                    var bY = $("#imgBox").offset().top;
                    $("#imgMain").css("left", x - bX - (xo - bX) + imgLeft);
                    $("#imgMain").css("top", y - bY - (yo - bY) - overHeight + imgTop);
                });
            });
            $("#divBlock").bind("mouseup mouseout", function () {
                $("#divBlock").unbind("mousemove");
            });
        });
    </script>
</head>
<body>
    <div id="imgBox">
        <div style="width: 200px; height: 200px; cursor: pointer; position: relative; left: 0;
            top: 0; filter: alpha(opacity=0); opacity: 0; -moz-opacity: 0; background: blue;
            z-index: 999;" id="divBlock">
        </div>
        <img src="test.jpg" width="200" height="200" alt="" id="imgMain" />
    </div>
</body>
</html>
Javascript 相关文章推荐
javascript编程起步(第六课)
Jan 10 Javascript
location.href语句与火狐不兼容的问题
Jul 04 Javascript
JavaScript类型转换方法及需要注意的问题小结(挺全面)
Nov 11 Javascript
jquery实现点击消失的代码
Mar 03 Javascript
原生JavaScript+LESS实现瀑布流
Dec 12 Javascript
js实现仿百度瀑布流的方法
Feb 05 Javascript
zepto.js中tap事件阻止冒泡的实现方法
Feb 12 Javascript
js针对ip地址、子网掩码、网关的逻辑性判断
Jan 06 Javascript
JavaScript常用数学函数用法示例
May 14 Javascript
解决Angular2 router.navigate刷新页面的问题
Aug 31 Javascript
微信小程序引用iconfont图标的方法
Oct 22 Javascript
Vue-axios-post数据后端接不到问题解决
Jan 09 Javascript
document.execCommand()的用法小结
Jan 08 #Javascript
js window.onload 加载多个函数和追加函数详解
Jan 08 #Javascript
js字符串转换成数字与数字转换成字符串的实现方法
Jan 08 #Javascript
JS获取计算机mac地址以及IP的实现方法
Jan 08 #Javascript
JavaScript+CSS控制打印格式示例介绍
Jan 07 #Javascript
jquery实现非叠加式的搜索框提示效果
Jan 07 #Javascript
使用JQUERY进行后台页面布局控制DIV实现左右式
Jan 07 #Javascript
You might like
使用GDB调试PHP代码,解决PHP代码死循环问题
2015/03/02 PHP
浅谈php中urlencode与rawurlencode的区别
2016/09/05 PHP
php实现用户登陆简单实例
2017/04/04 PHP
javascript打印html内容功能的方法示例
2013/11/28 Javascript
JavaScript严格模式禁用With语句的原因
2014/10/20 Javascript
浅谈Javascript如何实现匀速运动
2014/12/19 Javascript
jQuery实现表格颜色交替显示的方法
2015/03/09 Javascript
jquery 全选、全不选、反选效果的实现代码【推荐】
2016/05/05 Javascript
javascript中JSON.parse()与eval()解析json的区别
2016/05/19 Javascript
JavaScript自学笔记(必看篇)
2016/06/23 Javascript
浅谈jQuery中的eq()与DOM中element.[]的区别
2016/10/28 Javascript
jQuery实现字符串全部替换的方法
2016/12/12 Javascript
jQuery实现弹窗居中效果类似alert()
2017/02/27 Javascript
从零开始做一个pagination分页组件
2017/03/15 Javascript
vue中使用vue-router切换页面时滚动条自动滚动到顶部的方法
2017/11/28 Javascript
JS实现不用中间变量temp 实现两个变量值得交换方法
2018/02/04 Javascript
vue将后台数据时间戳转换成日期格式
2019/07/31 Javascript
原生js实现的移动端可拖动进度条插件功能详解
2019/08/15 Javascript
Vue项目vscode 安装eslint插件的方法(代码自动修复)
2020/04/15 Javascript
Python3中lambda表达式与函数式编程讲解
2019/01/14 Python
PyQt5组件读取参数的实例
2019/06/25 Python
python实现桌面气泡提示功能
2019/07/29 Python
Django 自动生成api接口文档教程
2019/11/19 Python
Python PyInstaller库基本使用方法分析
2019/12/12 Python
Django多层嵌套ManyToMany字段ORM操作详解
2020/05/19 Python
拿来就用!Python批量合并PDF的示例代码
2020/08/10 Python
Python操控mysql批量插入数据的实现方法
2020/10/27 Python
Manjaro、pip、conda更换国内源的方法
2020/11/17 Python
Django vue前后端分离整合过程解析
2020/11/20 Python
HTML+CSS3 模仿Windows7 桌面效果
2010/06/17 HTML / CSS
html5 application cache遇到的严重问题
2012/12/26 HTML / CSS
Hoka One One法国官网:美国专业跑鞋品牌
2018/12/29 全球购物
课外小组活动总结
2014/08/27 职场文书
单位综合评价意见
2015/06/05 职场文书
致创业的您:这类人不适合餐饮创业
2019/08/19 职场文书
2019年关于小学生课外阅读情况的分析报告
2019/12/02 职场文书