jQuery功能强大的图片查看器插件
简要教程
viewer是一款功能强大的图片查看器jQuery插件。它可以实现ACDsee等看图软件的部分功能。它可以对图片进行移动,缩放,旋转,翻转,可以前后浏览一组图片。该图片查看器还支持移动设备,支持键盘控制,功能十分强大。

安装
可以通过nmp或bower来安装该图片查看器插件。
- npm install imageviewer
- bower install imageviewer
复制代码
使用方法
使用该幻灯片插件需要引入jQuery,viewer.css和viewer.js文件。
- <link rel="stylesheet" href="css/viewer.css" type="text/css">
- <script type="text/javascript" src="js/jquery.min.js"></script>
- <script type="text/javascript" src="js/viewer.js"></script>
复制代码
HTML结构
该图片查看器需要一个块级元素来作为包裹元素,可以只有一张图片,直接使用<img> 元素,或者是一组图片,使用无序列表来制作:
- <!--单张图片-->
- <div>
- <img class="image" src="picture.jpg" alt="Picture">
- </div>
- <!--一组图片-->
- <div>
- <ul class="images">
- <li><img src="picture.jpg" alt="Picture"></li>
- <li><img src="picture-2.jpg" alt="Picture 2"></li>
- <li><img src="picture-3.jpg" alt="Picture 3"></li>
- </ul>
- </div>
复制代码
初始化插件
在页面DOM元素加载完毕之后,可以通过下面的方法来初始化该图片查看器插件。
- // View one image
- $('.image').viewer();
- // View some images
- $('.images').viewer();
复制代码
键盘控制
在模态窗口模式下,可以使用键盘来控制查看图片:
- Esc:退出全屏并停止播放。
- ←:查看前一张图片。
- →:查看下一张图片。
- ↑:放大图片。
- ↓:缩小图片。
- Ctrl + 0:缩小到初始大小。
- Ctrl + 1:放大到自然尺寸。
配置参数
你可以通过$().viewer(options)来设置这个图片查看器的参数。如果你要修改全局配置参数,你需要使用$.fn.viewer.setDefaults(options)。
- inline:类型:Boolean,默认值:false。使用内联模式来查看图片。
- button:类型:Boolean,默认值:true。在图片查看器的右上角显示按钮。
- navbar:类型:Boolean,默认值:true。显示导航条。
- title:类型:Boolean,默认值:true。显示图片标题。标题来自图片的alt属性或从URL解析的图片名称。
- toolbar:类型:Boolean,默认值:true。显示工具栏。
- tooltip:类型:Boolean,默认值:true。在放大缩小图片的时候显示图片的百分比比例。
- movable:类型:Boolean,默认值:true。图片是否可以移动。
- zoomable:类型:Boolean,默认值:true。图片是否可以放大缩小。
- rotatable:类型:Boolean,默认值:true。图片是否可以旋转。
- scalable:类型:Boolean,默认值:true。图片是否可以翻转。
- transition:类型:Boolean,默认值:true。是否为某些指定的元素使用CSS3 Transition效果。
- fullscreen:类型:Boolean,默认值:true。是否允许全屏模式。该功能需要浏览器支持Full Screen API。
- keyboard:类型:Boolean,默认值:true。是否可以使用键盘控制。
- interval:类型:Number,默认值:5000。自动播放时图片的切换时间间隔。
- zoomRatio:类型:Number,默认值:0.1。在使用鼠标缩放图片时的缩放比例。
- minZoomRatio:类型:Number,默认值:0.01。图片缩小的最小比例。
- maxZoomRatio:类型:Number,默认值:100。图片放大的最小比例。
- zIndex:类型:Number,默认值:2015。定义图片查看器模态窗口的CSS z-index属性的值。
- zIndexInline:类型:Number,默认值:0。定义图片查看器在内联模式中CSS z-index属性的值。
- url:类型:String 或 Function,默认值:'src'。定义原始图片的URL地址。
- build:类型:Function,默认值:null。"build.viewer"事件的快捷方式。
- built:类型:Function,默认值:null。"built.viewer"事件的快捷方式。
- show:类型:Function,默认值:null。"show.viewer"事件的快捷方式。
- shown:类型:Function,默认值:null。"shown.viewer"事件的快捷方式。
- hide:类型:Function,默认值:null。"hide.viewer"事件的快捷方式。
- hidden:类型:Function,默认值:null。"hidden.viewer"事件的快捷方式。
方法
由于该图片查看器插件使用的是异步加载图片的方式,所以你需要在shown(模态窗口模式)或built(内联模式)之后才能调用下面的方法,除了模态窗口模式的show方法和destroy方法之外。
- // Modal mode
- $().viewer({
- shown: function () {
- $().viewer('method', argument1, , argument2, ..., argumentN);
- }
- }
- // Inline mode
- $().viewer({
- built: function () {
- $().viewer('method', argument1, , argument2, ..., argumentN);
- }
- }
复制代码
- show():显示图片查看器。只在模态窗口模式中有效。
- hide():隐藏图片查看器。只在模态窗口模式中有效。
- view([index]):
index (optional):
- 类型:Number
- 默认值:0
- 在查看的图片的index
通过图片的index来查看某张图片。
- $().viewer('view', 1); // 查看第二张图片
复制代码
- prev():查看前一张图片。
- next():查看下一张图片。
- move(offsetX[, offsetY]):移动图片。
offsetX:
- 类型:Number
- 默认值:0
- 水平方向上移动的距离,单位像素。
offsetY(optional):
- 类型:Number
- 垂直方向上移动的距离,单位像素。
- 如果没有提供,默认值是offsetX。
- $().viewer('move', 1);
- $().viewer('move', -1, 0); // 向左移动图片
- $().viewer('move', 1, 0); // 向有移动图片
- $().viewer('move', 0, -1); // 向上移动图片
- $().viewer('move', 0, 1); // 向下移动图片
复制代码
- zoom(ratio[, hasTooltip]):缩放图片。
ratio:
- 类型:Number
- Zoom in(放大):需要一个正数(ratio > 0)。
- Zoom out(缩小):需要一个负数(ratio < 0)
hasTooltip (optional):
- 类型:Boolean
- 默认值:false
- 显示tooltip。
- $().viewer('zoom', 0.1);
- $().viewer('zoom', -0.1);
复制代码
- zoomTo(ratio[, hasTooltip]):缩放图片到指定的比例。
ratio:
- 类型:Number
- 需要一个正数(ratio > 0)
hasTooltip (optional):
- 类型:Boolean
- 默认值:false
- 显示tooltip。
- $().viewer('zoomTo', 0); // Zoom to zero size (0%)
- $().viewer('zoomTo', 1); // Zoom to natural size (100%)
复制代码
- rotate(degree):旋转图片。
degree:
- 类型:Number
- 向右旋转需要一个正数(ratio > 0)
- 向左旋转需要一个负数(ratio < 0)
该方法需要浏览器支持CSS3 2D Transforms(IE9+)。
- $().viewer('rotate', 90);
- $().viewer('rotate', -90);
复制代码
- rotateTo(degree):将图片旋转到指定的角度。
degree: 类型:Number 该方法需要浏览器支持CSS3 2D Transforms(IE9+)。
- $().viewer('rotateTo', 0); // 将图片重置到0度
- $().viewer('rotateTo', 360); // 将图片旋转一周
复制代码
- scale(scaleX[, scaleY]):翻转图片。
scaleX:
- 类型:Number
- 默认值:1
- 图片横坐标方向上的缩放比例。
- 当值为1时不做任何事情。
scaleY:(optional
- 类型:Number
- 图片纵坐标方向上的缩放比例。
- 如果未指定,默认值为scaleX。
- 该方法需要浏览器支持CSS3 2D Transforms(IE9+)。
- $().viewer('scale', -1); // 在垂直和水平方向上翻转图片
- $().viewer('scale', -1, 1); // 水平翻转
- $().viewer('scale', 1, -1); // 垂直翻转
复制代码
- scaleX(scaleX):水平翻转图片。
scaleX:
- 类型:Number
- 默认值:1
- 图片横坐标方向上的缩放比例。
- 当值为1时不做任何事情。
该方法需要浏览器支持CSS3 2D Transforms(IE9+)。
- $().viewer('scaleX', -1); // 水平翻转
复制代码
- scaleY(scaleY):垂直翻转。
scaleY:
- 类型:Number
- 默认值:1
- 图片纵坐标方向上的缩放比例。
- 当值为1时不做任何事情。
该方法需要浏览器支持CSS3 2D Transforms(IE9+)。
- $().viewer('scaleY', -1); // 水平翻转
复制代码
- play():播放图片。
- stop():停止播放。
- full():进入模态窗口模式。仅在内联模式中有效。
- exit():退出模态窗口模式。仅在内联模式中有效。
- tooltip():以百分比显示当前图片的比例。需要tooltip参数设置为true。
- toggle():在原始尺寸和当前尺寸之间切换图片尺寸。
- reset():重置图片到元素状态。
- destroy():销毁图片查看器实例。
事件
- build.viewer:当图片查看器实例开始创建时触发。
- built.viewer:当图片查看器实例被创建之后触发。
- show.viewer:当图片查看器元素开始显示时触发。仅在模态窗口模式有效。
- shown.viewer:当图片查看器元素显示之后触发。仅在模态窗口模式有效。
- hide.viewer:当图片查看器元素开始隐藏时触发。仅在模态窗口模式有效。
- hidden.viewer:当图片查看器元素隐藏之后触发。仅在模态窗口模式有效。
No conflict
如果你使用了和这个图片查看器具有相同名称空间的其它插件,可以通过$.fn.viewer.noConflict方法来恢复它。
- <script src="other-plugin.js"></script>
- <script src="viewer.js"></script>
- <script>
- $.fn.viewer.noConflict();
- // Code that uses other plugin's "$().viewer" can follow here.
- </script>
复制代码
浏览器兼容
- Chrome (latest 2)
- Firefox (latest 2)
- Internet Explorer 8+
- Opera (latest 2)
- Safari (latest 2)
本文版权属于jQuery之家,转载请注明出处:http://www.htmleaf.com/jQuery/Image-Effects/201509032517.html
jQuery功能强大的图片查看器插件的更多相关文章
- 分享一款强大的图片查看器插件,手机PC 通吃,功能超级齐全!
一款强大的图片查看器插件,手机PC 通吃,功能超级齐全! 地址:http://photoswipe.com/
- 强大的jQuery图片查看器插件Viewer.js
简介 Viewer.js 是一款强大的图片查看器 Viewer.js 有以下特点: 支持移动设备触摸事件 支持响应式 支持放大/缩小 支持旋转(类似微博的图片旋转) 支持水平/垂直翻转 支持图片移动 ...
- viewer.js图片查看器插件(可缩放/旋转/切换)
<!doctype html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- Viewer.js – 强大的JS/jQuery图片查看器
简介 Viewer.js 是一款强大的图片查看器,像门户网站一般都会有各自的图片查看器,如果您正需要一款强大的图片查看器,也许 Viewer.js 是一个很好的选择.Viewer.js 有以下特点: ...
- angularjs1 自定义图片查看器(可旋转、放大、缩小、拖拽)
笔记: angularjs1 制作自定义图片查看器(可旋转.放大.缩小.拖拽) 2018-01-12 更新 可以在我的博客 查看我 已经封装好的 纯 js写的图片查看器插件 博客链接 懒得把 ...
- 网页中的图片查看器viewjs使用
需求分析: 对于网页中的图片进行连续放大(便于用户清晰查看内容).缩小,旋转等操作,可以使用viewjs图片查看器插件实现. viewjs官方网址:https://github.com/fengyua ...
- vue图片查看器
vue 安装图片查看器插件安装cnpm install v-viewer引用 import 'viewerjs/dist/viewer.css' import Viewer from 'v-viewe ...
- 插件介绍 :cropper是一款使用简单且功能强大的图片剪裁jQuery插件。
简要教程 cropper是一款使用简单且功能强大的图片剪裁jQuery插件.该图片剪裁插件支持图片放大缩小,支持鼠标滚轮操作,支持图片旋转,支持触摸屏设备,支持canvas,并且支持跨浏览器使用. c ...
- 发布两款JQ小插件(图片查看器 + 分类选择器),开源
图片查看器,github地址:https://github.com/VaJoy/imgViewer 效果如下: 这款当初大概写了2小时,有点匆忙地赶出来的,使用的接口很简单: $.bindViewer ...
随机推荐
- float浮动的学习
很早以前就接触过CSS,然后就在也没有深入了解过.今天突然遇到有人问了关系浮动的问题,碰巧没事就将内容整理下,与大家交流学习. 首先大家也应该都知道,div是块级元素,在页面中独占一行,自上而下排列, ...
- JS当中利用&&和||简化代码
; ){ add_level = ; } ){ add_level = ; } ){ add_level = ; } ){ add_level = ; } else { add_level = ; } ...
- C# 图像旋转代码
方法一: public static Bitmap rotateImage(Bitmap b, float angle) { //create a new empty bitmap to hold r ...
- C#中DataTable中Rows.Add 和 ImportRow 对比
最近参加项目中,数据操作基本都是用DataTable的操作,老代码中有些地方用到DataTable.Rows.Add又有些代码用的DataTable.ImportRow,于是就对比了一下 VS查询说明 ...
- Java面试进阶部分集合
框架基础 反射:反射是Java开发的一类动态相关机制.因为本身Java语言并不是一款动态语言,如果我们想要得到程序动态的效果,因此便引入了反射机制这一概念. 怎么表达反射? 能用反射做什么? PS:某 ...
- 【kindeditor】KindEditor获取多个textarea文本框的值并判断非空
kindeditor官网:http://kindeditor.net/demo.php 如何获取多个KindEditor中textarea文本框的值,方式很多种(带有HTML标签). var intr ...
- 【MFC】MFC中使对话框变成圆角矩形的代码(转)
原文转自 http://blog.csdn.net/cracent/article/details/48274469 BOOL CLoginDlg::OnInitDialog() { CDialog: ...
- vue v-on:click传递动态参数
最近项目中要为一个循环列表动态传送当前点击列的数据,查了很久资料也没有一个完美的解决方案, 新手只能用vue的事件处理器与jquery的选择器做了一个不伦不类的方案,居然也能解决这个问题,作此记录留待 ...
- 教你写Linux设备驱动程序:一个简短的教程
教你写Linux设备驱动程序:一个简短的教程 http://blog.chinaunix.net/uid-20799298-id-99675.html
- Java中PO、BO、VO、DTO、POJO、DAO概念及其作用和项目实例图(转)
PO(bean.entity等命名): Persistant Object持久对象,数据库表中的记录在java对象中的显示状态 最形象的理解就是一个PO就是数据库中的一条记录. 好处是可以把一条记录作 ...