smartJQueryZoom(smartZoom) 的使用方法
smartZoom 是一个我很喜欢用的库。
但是这个库有一些不完善的地方。
比如BUG。
比如使用上可能遇到的问题。
<article>
<div id="zoom_box" class="zoom-box" style="display: none">
<img>
</div>
</article>
比如说,我们想用 smartZoom 渲染这个img。
前提条件:这个库依赖 jQuery.
首先,它的父元素的宽高必须是个像素值。设 100% 可能会出问题。
可以用 jquery 计算并赋值宽高。
// 加数字值和项目样式有关 不通用
$("#zoom_box").css({
width: $("article").width() + 40 + 'px',
height: $("article").height() + 25 + 'px',
})
其次。
不要给你想渲染的 img 设宽高。像素值和 100% 什么的都不需要。
最后调用渲染一下就好。
$("#zoom_box img").smartZoom({
'dblClickEnabled': false,
'containerBackground': "#000"
});
渲染时的参数,github 上有说明。
options = {'top' : '0', // top 像素值 一般用不上
'left' : '0', // left 像素值 一般用不上
'width' : '100%', // 宽度 如果你不希望图片的显示区域是这个DIV全部区域,那么需要设置一下
'height' : '100%', // 高度 同上
'easing' : 'smartZoomEasing', // jquery easing 函数 如果浏览器不支持CSS3 那么需要写一下
'maxScale' : 3, // 最大放大倍率
'dblClickMaxScale' : 1.8, // 双击时的最大放大倍率
'mouseEnabled' : true, // 是否可以用鼠标与渲染区域交互
'scrollEnabled' : true, // 是否可以用滚轮缩放图片
'dblClickEnabled' : true, // 是否可以双击放大图片
'mouseMoveEnabled' : true, // 是否支持鼠标移动交互
'moveCursorEnabled' : true, // 是否可以鼠标拖动图片
'touchEnabled' : true, // 是否支持触摸交互(触摸屏)
'dblTapEnabled' : true, // 是否支持触摸双击(触摸屏)
'pinchEnabled' : true, // enable zoom when user pinch on target
'touchMoveEnabled' : true, // 是否可以通过触摸事件拖动图片
'containerBackground' : '#FFFFFF', // 如果不用样式表,那么可以设置背景色,透明背景需要设为 transparent
'containerClass' : ''// 用的样式表 定制化样式时会用到
}
以上。
2019.08.16 更新:
实际上,想给 img 设宽高100%也是可以的。但是DOM结构要改一下。
<div id="zoom_box" class="zoom-box" style="display: none">
<div id="inner" class="inner">
<img>
</div>
</div>
此时,现在的 div#inner 相当于以前的 img。现在的 img 宽高是 100% ,永远和 div#inner 一样大。
// inner 的宽度用 inner 的高度和图片比例去计算
$("#inner").css({
width: ($("article").height() + 25) * (1440 / 810) + 'px',
height: ($("article").height() + 25) + 'px',
})
渲染方法也需要改一下。
$("#zoom_box #inner").smartZoom({
'dblClickEnabled': false,
'containerBackground': "#000"
});
也就是说,以前 smartzoom 渲染绑在 img 上,现在绑在 div#inner 上。
OVER。
smartJQueryZoom(smartZoom) 的使用方法的更多相关文章
- smartJQueryZoom(smartZoom) 存在的兼容性BUG,以及解决方法
smartJQueryZoom 是一个很好用的库. 它基于jQuery,可以对某个元素(比如 img)进行渲染,渲染之后可以放大这个区域,在做图片浏览时很好用. 但它有一个兼容性BUG: 当浏览器不是 ...
- javaSE27天复习总结
JAVA学习总结 2 第一天 2 1:计算机概述(了解) 2 (1)计算机 2 (2)计算机硬件 2 (3)计算机软件 2 (4)软件开发(理解) 2 (5) ...
- mapreduce多文件输出的两方法
mapreduce多文件输出的两方法 package duogemap; import java.io.IOException; import org.apache.hadoop.conf ...
- 【.net 深呼吸】细说CodeDom(6):方法参数
本文老周就给大伙伴们介绍一下方法参数代码的生成. 在开始之前,先补充一下上一篇烂文的内容.在上一篇文章中,老周检讨了 MemberAttributes 枚举的用法,老周此前误以为该枚举不能进行按位操作 ...
- IE6、7下html标签间存在空白符,导致渲染后占用多余空白位置的原因及解决方法
直接上图:原因:该div包含的内容是靠后台进行print操作,输出的.如果没有输出任何内容,浏览器会默认给该空白区域添加空白符.在IE6.7下,浏览器解析渲染时,会认为空白符也是占位置的,默认其具有字 ...
- 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例
前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...
- [C#] C# 基础回顾 - 匿名方法
C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...
- ArcGIS 10.0紧凑型切片读写方法
首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...
- [BOT] 一种android中实现“圆角矩形”的方法
内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ...
随机推荐
- 代码规范与计划(Beta阶段)
这个作业属于哪个课程 软件工程 (福州大学至诚学院 - 计算机工程系) 团队名称 WeChair 这个作业要求在哪里 Beta冲刺 这个作业的目标 代码规范与计划 作业正文 如下 其他参考文献 代码规 ...
- Java并发编程-深入探讨synchronized实现原理
synchronized这个关键字对应Java程序猿来说是非常的熟悉,只要遇到要解决线程安全问题的地方都会使用这个关键字.接下来一起来探讨一下synchronized到底时怎么实现线程同步,使用syn ...
- python 类的内置函数2
必须明确创建对象的过程: 先创建空对象,执行初始化将属性存储到对象的名称空间中! 所以在__call__函数中必须完成这两步操作,同时将初始化完成的对象返回给调用者 一旦覆盖了__call__函数,就 ...
- BOM问题-对于php的影响
甲.BOM说明 BOM(Byte Order Mark),是UTF编码方案里用于标识编码的标准标记.这个标记是可选的,UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明当前编码方式.但如果文件 ...
- Flask04-SQL
from flask import render_template, flash, redirect from app import app from app import db, models fr ...
- JDK8--03:lambda表达式语法
对于lambda表达式的基础语法,一个是要了解lambda表达式的基础语法,另外一个是需要了解函数式接口 一.lambda表达式基础语法描述 java8中引入了新的操作符 -> ,可以称为l ...
- node+ajax实战案例(5)
6.添加客户 6.1.点击添加按钮,弹出表单框 // 添加用户 显示对话框 var addBtn = document.getElementById('add-btn'); var addUser = ...
- Linux命令查勘进程:ps -ef |grep java
一.ps -ef |grep java 查看包含“java”的所有进程 二.涉及命令详解 ps命令将某个进程显示出来(是LINUX下最常用的也是非常强大的进程查看命令) grep命令是查找(是一种强大 ...
- 哈希传递攻击利用(Pass The Hash)
最近又复习了一下内网的相关知识,把以前的整理了一下发出来做个记录. 0x01 哈希传递攻击概念 有一点内网渗透经验的都应该听说过哈希传递攻击,通过找到相应账户相关的密码散列值(LM Hash,NTLM ...
- 洛谷 P1186 【玛丽卡】
这道题题目真的想吐槽一下...是在机房同学的解释下才看懂的.就是让你求在可以删一条边的情况下,并且删后保证可以到达终点时,求删了后的最大的最短路径. 70分暴力思路: 枚举删边,然后跑一下最短路即可, ...