jQuery chili图片远处放大插件


Posted in Javascript onNovember 30, 2009

为了让本地图片、远程图片、过小的图片都适应此插件,有很多细节问题要处理。

首先定义结构:
<div class="imgMagnifierWrap"> 
<div class="overlay"><!--覆盖层,鼠标的感应区域,位于小图上最方--></div> 
<div class="tipboxHover"><!--小图上方的悬停提示方框--></div> 
<div class="imgOriginal"><!--装载大图的容器,绝对定位<img src="bigOne.jpg" /><!--前景大图,绝对定位--></div> 
</div>
<!--样式--> 
<style type="text/css"> 
.imgMagnifierWrap *{position:absolute;background:#fff;} 
.imgMagnifierWrap .tipboxHover{width:80px; height:60px; filter:alpha(opacity=30);opacity:.3;display:none;} 
.imgMagnifierWrap .imgOriginal{display:none;z-index:9999;overflow:hidden; width:400px; height:400px; 
    background-color:#cdf; background-repeat:no-repeat; text-align:center;border:1px solid #555; } 
.imgMagnifierWrap .overlay{cursor:crosshair;filter:alpha(opacity=0);opacity:0;} 
<style>
然后考虑图片预加载:
$.imgPreloader=function(url,eventLists){ 
var img=new Image(); 
var $img=$(img); 
img.src=url; 
$.each(eventLists,function(type,fn){ 
$img.bind(type,fn); 
}); 
$img.trigger(img.complete?'load':'begin'); 
return $img; 
};
再计算感应区域:
小图所处感应区域四边各减去指示方框各四边的1/2大小的矩形,在此之外的区域则显示到大图边界:
var borderLeft =thumbInfo.left+tipboxInfo.width/2; 
var ratioX=(mouseInfo.x-borderLeft)/(thumbInfo.width-tipboxInfo.width);
用大图用做背景图片引发的问题:
用隐藏的前景图片预加载,load事件判断时机,ie,chrome正常,ff请求了两次图片,图片未缓存;
换一种方式,不预载大图。改成直接在大图位置用覆盖层做“loading”后,chrome下表现为渐进加载图片,非chrome是直接显示,略有遗憾。
最终结果,把大图用做前景图片:
优势在于,大图的load和error事件都可以正常工作:
$.imgPreloader($anchor.attr('href'),{ 
load:function(){ 
isImageReady=true; 
$o.empty().append(this); 
setTimeout(autoFitPicture,0); 
}, 
begin:function(){ 
$o.text('loading...'); 
}, 
error:function(){ 
isImageReady=true; 
$o.text('invalid picture!'); 
} 
});

大图预载的load事件和小图mousemove事件不同步的解决办法:实时存储鼠标坐标,把提示方框定位和大图定位的方法分离。

//鼠标位置存储 
var mouseInfo={x:0,y:0}; 
//指示框定位 
var setTipboxPosition=function(e){ 
mouseInfo.x=e.pageX; 
mouseInfo.y=e.pageY; 
$tipbox.css({ 
top:mouseInfo.y<thumbInfo.width/2+thumbInfo.top 
?Math.max(mouseInfo.y-tipboxInfo.height/2,thumbInfo.top) 
:Math.min(mouseInfo.y-tipboxInfo.height/2,thumbInfo.top+thumbInfo.height-tipboxInfo.height), 
left:mouseInfo.x<thumbInfo.width/2+thumbInfo.left 
?Math.max(mouseInfo.x-tipboxInfo.width/2,thumbInfo.left) 
:Math.min(mouseInfo.x-tipboxInfo.width/2,thumbInfo.left+thumbInfo.width-tipboxInfo.width) 
});   
setImgPosition(); 
};

随便一提,如果有一种浏览器,也许会很幸运。
演示代码
打包下载 https://3water.com/jiaoben/22866.html

Javascript 相关文章推荐
基于Jquery的回车成tab焦点切换效果代码(Enter To Tab )
Nov 14 Javascript
微信小程序 教程之列表渲染
Oct 18 Javascript
jQuery图片切换动画特效
Nov 02 Javascript
Javascript oop设计模式 面向对象编程简单实例介绍
Dec 13 Javascript
vue调用高德地图实例代码
Apr 28 Javascript
vue.js实现价格格式化的方法
May 23 Javascript
微信小程序使用picker实现时间和日期选择框功能【附源码下载】
Dec 11 Javascript
JavaScript代码调试方法实例小结
Jan 05 Javascript
用Vue.js在浏览器中实现裁剪图像功能
Jun 18 Javascript
Element Rate 评分的使用方法
Jul 27 Javascript
微信小程序将页面按钮悬浮固定在底部的实现代码
Oct 29 Javascript
vue3使用vue-router的完整步骤记录
Jun 20 Vue.js
document.body.scrollTop 值总为0的解决方法 比较常见的标准问题
Nov 30 #Javascript
javascript 设置某DIV区域内的checkbox复选框
Nov 30 #Javascript
Javascript 构造函数,公有,私有特权和静态成员定义方法
Nov 30 #Javascript
javascript &amp;&amp;和||运算法的另类使用技巧
Nov 28 #Javascript
javascript showModalDialog 多层模态窗口实现页面提交及刷新的代码
Nov 28 #Javascript
JavaScript 闭包在封装函数时的简单分析
Nov 28 #Javascript
extJs 文本框后面加上说明文字+下拉列表选中值后触发事件
Nov 27 #Javascript
You might like
php 读取shell管道传输过来的内容
2010/03/01 PHP
ajax完美实现两个网页 分页功能的实例代码
2013/04/16 PHP
解析php中session的实现原理以及大网站应用应注意的问题
2013/06/17 PHP
php利用scws实现mysql全文搜索功能的方法
2014/12/25 PHP
php通过Chianz.com获取IP地址与地区的方法
2015/01/14 PHP
php实现的mongodb操作类
2015/05/28 PHP
用js写了一个类似php的print_r输出换行功能
2013/02/18 Javascript
JS随机漂浮广告代码具体实例
2013/11/19 Javascript
js判断60秒以及倒计时示例代码
2014/01/24 Javascript
jQuery学习总结之jQuery事件
2014/06/30 Javascript
深入学习AngularJS中数据的双向绑定机制
2016/03/04 Javascript
AngularJS之自定义服务详解(factory、service、provider)
2017/04/14 Javascript
vue.js父组件使用外部对象的方法示例
2017/04/25 Javascript
vue中的router-view组件的使用教程
2018/10/23 Javascript
vue-cli3.0 环境变量与模式配置方法
2018/11/08 Javascript
详解easyui 切换主题皮肤
2019/04/04 Javascript
Node.js实现简单管理系统
2019/09/23 Javascript
修改vue源码实现动态路由缓存的方法
2020/01/21 Javascript
Vue+Openlayers自定义轨迹动画
2020/09/24 Javascript
[01:28:31]《加油DOTA》真人秀 第五期
2014/09/01 DOTA
[03:27]《辉夜杯》线下训练营 导师CU和海涛指点迷津
2015/10/23 DOTA
Python3使用requests包抓取并保存网页源码的方法
2016/03/15 Python
Python引用模块和查找模块路径
2016/03/17 Python
详解Python操作RabbitMQ服务器消息队列的远程结果返回
2016/06/30 Python
Php多进程实现代码
2018/05/07 Python
pandas.dataframe中根据条件获取元素所在的位置方法(索引)
2018/06/07 Python
python使用ddt过程中遇到的问题及解决方案【推荐】
2018/10/29 Python
Python绘制热力图示例
2019/09/27 Python
Python+numpy实现矩阵的行列扩展方式
2019/11/29 Python
使用python+poco+夜神模拟器进行自动化测试实例
2020/04/23 Python
Python中Qslider控件实操详解
2021/02/20 Python
压铸汽车模型收藏家:Diecastmodelswholesale.com
2016/12/21 全球购物
创业计划实施的7大步骤
2014/02/05 职场文书
银行职员个人的工作自我评价
2014/02/15 职场文书
2014院党委领导班子对照检查材料思想汇报
2014/09/24 职场文书
Matplotlib绘制混淆矩阵的实现
2021/05/27 Python