官方网站
http://www.photoswipe.com/

源码示例
http://github.com/downloads/codecomputerlove/PhotoSwipe/code.photoswipe-3.0.5.zip

Github
https://github.com/codecomputerlove/PhotoSwipe

在线demo
http://www.photoswipe.com/latest/examples/04-jquery-mobile.html

类库引用

  1. <!-- photoswipe 之前先引用klass,如果需要提高加载速度,可以给 script 加上 defer 标记/属性-->
  2. <script type="text/javascript" src="klass.min.js"></script>
  3. <!-- 重要提示,如果不使用jQuery版本,在IE下面会出错,当然,使用jQuery版本,则需要引入jQuery-->
  4. <script type="text/javascript" src="code.photoswipe-3.0.5.min.js"></script>

调用代码

  1. /* 添加DOMContentLoaded 事件监听,类似于jQuery的 ready函数.
  2. 默认方式 examples/01-default.html
  3. 无缩略图模式请查看.examples/09-exclusive-mode-no-thumbnails.html
  4. */
  5. // PhotoSwipe.attach 方法接收3个参数(HTML元素集合,可选配置信息,可选多实例时string类型的ID)
  6. document.addEventListener('DOMContentLoaded', function(){
  7. //设置 PhotoSwipe绑定为 id为Gallery的容器下的所有<a>标签.点击就会激活
  8. // 此处的对象,就是PhotoSwipe实例,可以使用相应的方法,例如 show(0),hide()等.
  9. var myPhotoSwipe = Code.PhotoSwipe.attach( window.document.querySelectorAll('#Gallery a'), { enableMouseWheel: false , enableKeyboard: false } );
  10. }, false);

如果使用jQuery,则调用代码如下:

  1. //jQuery 版,对应的js文件也需要变化
  2. // 示例详见examples/02-jquery.html
  3. $(document).ready(function(){
  4. // 此处的对象,就是PhotoSwipe实例,可以使用相应的方法,例如 show(0),hide()等.
  5. var myPhotoSwipe = $("#Gallery a").photoSwipe({ enableMouseWheel: false , enableKeyboard: false });
  6. });  

HTML代码

  1. <!-- ul li 之类是用于显示缩略图的,也可以根据需要调整.<a>下面的<img> 元素,即为缩略图,如果不需要,则src设置为空即可 -->
  2. <ul id="Gallery">
  3. <li><a href="images/full/01.jpg"><img src="data:images/thumb/01.jpg" alt="Image 01" /></a></li>
  4. <li><a href="images/full/02.jpg"><img src="data:images/thumb/02.jpg" alt="Image 02" /></a></li>
  5. <li><a href="images/full/03.jpg"><img src="data:images/thumb/03.jpg" alt="Image 03" /></a></li>
  6. <li><a href="images/full/04.jpg"><img src="data:images/thumb/04.jpg" alt="Image 04" /></a></li>
  7. <li><a href="images/full/05.jpg"><img src="data:images/thumb/05.jpg" alt="Image 05" /></a></li>
  8. <li><a href="images/full/06.jpg"><img src="data:images/thumb/06.jpg" alt="Image 06" /></a></li>
  9. </ul>  

参数说明

  1. allowUserZoom: 允许用户双击放大/移动方式查看图片. 默认值 = true
  2. autoStartSlideshow: PhotoSwipe激活后,自动播放幻灯片. 默认值 = false
  3. allowRotationOnUserZoom: 只有 iOS 支持 - 允许用户在缩放/平移模式下 用手势旋转图像. 默认值 = false
  4. backButtonHideEnabled: 按返回键隐藏相册幻灯片. 主要是 Android Blackberry使用. 支持 BB6, Android v2.1, iOS 4 以及更新版本. 默认值 = true
  5. captionAndToolbarAutoHideDelay: 标题栏和工具栏自动隐藏的延迟时间. 默认值为 = 5000(毫秒). 如果设为 0 则不会自动隐藏(tap/单击切换显隐)
  6. captionAndToolbarFlipPosition: 标题栏和工具栏切换位置(让 caption显示在底部而 toolbar显示在顶部). 默认值 = false
  7. captionAndToolbarHide: 隐藏 标题栏和工具栏. 默认值 = false
  8. captionAndToolbarOpacity: 标题栏和工具栏 的透明度(0-1). 默认值 = 0.8
  9. captionAndToolbarShowEmptyCaptions: 即使当前图片的标题是空,也显示标题栏. 默认值 = true
  10. cacheMode: 缓存模式,Code.PhotoSwipe.Cache.Mode.normal (默认,正常) 或者 Code.PhotoSwipe.Cache.Mode.aggressive(激进,积极). 决定 PhotoSwipe 如何管理图片缓存 cache.
  11. Aggressive 模式将会积极地地设置非 "当前,上一张,下一张"的图片为空的类型. 对于老版本iOS 浏览器下的大图片内存溢出将会很有用. 大多数情况下,normal模式就可以了。
  12. doubleTapSpeed: 双击的最大间隔. 默认值 = 300(毫秒)
  13. doubleTapZoomLevel: 当用户双击的时候,放大的倍数, 默认的 "zoom-in"(拉近) 级别. 默认值 = 2.5
  14. enableDrag: 允许拖动上一张/下一张图片到当前界面. 默认值 = true
  15. enableKeyboard: 允许键盘操作(左右箭头切换,Esc退出,Enter自动播放,空格键 显/隐标题栏/退出). 默认 = true
  16. enableMouseWheel: 允许鼠标滚轮操作. 默认 = true
  17. fadeInSpeed: 淡入效果元素的速度(持续时间),毫秒. 默认 = 250
  18. fadeOutSpeed: 淡出效果元素的速度(持续时间),毫秒. 默认 = 250
  19. imageScaleMethod: 图片缩放方法(模式). 可选值: "fit", "fitNoUpscale" "zoom". 模式"fit" 保证图像适应屏幕. "fitNoUpscale" "fit"类似但是不会放大图片. "zoom"将图片全屏, 但有可能图片缩放不是等比例的. 默认 = "fit"
  20. invertMouseWheel: 反转鼠标滚轮。默认情况下,鼠标向下滚动将切换到下一张,向上切换到上一张 . 默认 = false
  21. jQueryMobile: 指示 PhotoSwipe 是否集成进了 jQuery Mobile 项目. 默认情况下, PhotoSwipe will try and work this out for you
  22. jQueryMobileDialogHash: jQuery Mobilewindow,dialog页面 所使用的hash标签。 默认值 = "&ui-state=dialog"
  23. loop: 相册是否自动循环. 默认 = true
  24. margin: 两张图之间的间隔,单位是像素. 默认 = 20
  25. maxUserZoom: 最大放大倍数. 默认 = 5.0 (设置为0将被忽略)
  26. minUserZoom: 图像最小的缩小倍数. 默认 = 0.5 (设置为0将会忽略)
  27. mouseWheelSpeed: 响应鼠标滚轮的灵敏度. 默认 = 500(毫秒)
  28. nextPreviousSlideSpeed: 当点击上一张,下一张按钮后,延迟多少毫秒执行切换. 默认 = 0 (立即切换)
  29. preventHide: 阻止用户关闭 PhotoSwipe. 同时也会隐藏 工具栏上的"close"关闭按钮. 在独享的页面使用 (示例是源码中的 examples/08-exclusive-mode.html). 默认 = false
  30. preventSlideshow: 阻止自动播放模式. 同时也会隐藏工具栏里的播放按钮. 默认 = false
  31. slideshowDelay: 自动播放模式下,多长时间播放下一张. Default = 3000(毫秒)
  32. slideSpeed: 图片滑进视图的时间. 默认 = 250(毫秒)
  33. swipeThreshold: 手指滑动多少像素才触发一个 swipe 手势事件. 默认 = 50
  34. swipeTimeThreshold: 定义触发swipe(滑动)手势的最大毫秒数,太慢了则不会触发滑动,只会拖动当前照片的位置. 默认 = 250
  35. slideTimingFunction: 滑动时的 Easing function . 默认 = "ease-out"
  36. zIndex: 初始的zIndex值. 默认 = 1000
  37. enableUIWebViewRepositionTimeout: 检查设备的方向是否改变。默认 = false
  38. uiWebViewResetPositionDelay: 定时检查设备的方向是否改变的时间 默认 = 500(毫秒)
  39. preventDefaultTouchEvents: 阻止默认的touch事件,比如页面滚动。 默认 = true
  40. target: 必须是一个合法的DOM元素(如DIV)。默认是window(全页面)。而如果是某个低级别的DOM,则在DOM内显示,可能非全屏。

自定义函数

  1. getToolbar: function(){
  2. /*返回 要在Toolbar之中显示的HTML字符串*/
  3. },
  4. getImageSource: function(el){
  5. /* 告诉 gallery如何获取图片的src,
  6. 默认情况下,gallery假设你使用<a>标签包装了<img>缩略图,而<a>标签的href属性即为完整图片的URL。
  7. 此时可以使用本方法来返回对应元素的图片的路径。可以是各种各样的。比如rel属性什么的。有jQuery那就更简单了。
  8. */
  9. return el.getAttribute('rel');
  10. },
  11. getImageCaption: function(el){
  12. /**
  13. 如同 getImageSource 方法一样,此方法返回图片的标题,默认情况下gallery查找图片的alt 属性。
  14. */
  15. },
  16. getImageMetaData: function(el){
  17. /**
  18. 如果你监听了 onDisplayImage,那么你可以通过此函数获取额外的元信息.并在 onDisplayImage中使用
  19. */
  20. return {
  21. longDescription: el.getAttribute(el, 'data-long-description')
  22. }
  23. }

针对Android 手机一次点按,会引起一层关闭后,底上的层依然会触发点击事件的问题,我们的解决方案如下:

  1. // 在android 手机上多个层次触发点击,我们采用的是用定时器进行拦截
  2.  
  3. var event_timeout = 500;// 预防多次事件触发
  4. // 阻止短时间内连续事件
  5. var multiClickPrevent = false;
  6. function preventMultiClick(){
  7. if(multiClickPrevent){
  8. return false;
  9. }
  10. multiClickPrevent = true;
  11. window.setTimeout(function(){
  12. multiClickPrevent = false;
  13. },event_timeout);
  14. return true;
  15. };
  16.  
  17. // 适配浏览器
  18. var useragent = navigator.userAgent;
  19. var likeIOS = useragent.match(/iPad|iPhone|iPod/i);
  20. var likeAndroid = useragent.match(/android/i);
  21. var specialClick = "click";
  22. if(likeIOS){
  23. specialClick = "touchstart click";
  24. } else if(likeAndroid){
  25. specialClick = "touchstart click";
  26. }
  27.  
  28. / 示例
  29. $(".t_right").live(specialClick,function(){
  30. if(preventMultiClick()){
  31. // 执行其他操作
  32. } else {
  33. // else 就是拒绝操作啦,可以直接返回 false 之类的
  34. return false;
  35. }
  36. });
  37. // 示例
  38. $("body").live(specialClick,function(){
  39. if(preventMultiClick()){
  40. // 执行其他操作
  41. }
  42. });

  

 

PhotoSwipe简介的更多相关文章

  1. PhotoSwipe简介(PhotoSwipe是一个适合在触摸屏手机上使用的相册展示包)

    官方介绍PhotoSwipe 是专为移动触摸设备设计的相册/画廊.兼容所有iPhone.iPad.黑莓6+,以及桌面浏览器.底层实现基于HTML/CSS/JavaScript,是一款免费开源的相册产品 ...

  2. PhotoSwipe 图片浏览插件使用方法

    一.简介 PhotoSwipe 是专为移动触摸设备设计的相册/画廊.兼容所有iPhone.iPad.黑莓6+,以及桌面浏览器.底层实现基于HTML/CSS/JavaScript,是一款免费开源的相册产 ...

  3. ASP.NET Core 1.1 简介

    ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...

  4. MVVM模式和在WPF中的实现(一)MVVM模式简介

    MVVM模式解析和在WPF中的实现(一) MVVM模式简介 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在 ...

  5. Cassandra简介

    在前面的一篇文章<图形数据库Neo4J简介>中,我们介绍了一种非常流行的图形数据库Neo4J的使用方法.而在本文中,我们将对另外一种类型的NoSQL数据库——Cassandra进行简单地介 ...

  6. REST简介

    一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式.”但是在要求详细讲述它所提出的各个约束,以及如何开始搭建REST服务时,却很少有人能够清晰地说出它到底是什么,需要遵守什么样的准则. ...

  7. Microservice架构模式简介

    在2014年,Sam Newman,Martin Fowler在ThoughtWorks的一位同事,出版了一本新书<Building Microservices>.该书描述了如何按照Mic ...

  8. const,static,extern 简介

    const,static,extern 简介 一.const与宏的区别: const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽成宏,推荐我们使用const常量. 执行时刻:宏是预编 ...

  9. HTTPS简介

    一.简单总结 1.HTTPS概念总结 HTTPS 就是对HTTP进行了TLS或SSL加密. 应用层的HTTP协议通过传输层的TCP协议来传输,HTTPS 在 HTTP和 TCP中间加了一层TLS/SS ...

随机推荐

  1. 2013 多校联合 2 A Balls Rearrangement (hdu 4611)

    Balls Rearrangement Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Othe ...

  2. C#操作AD及Exchange Server总结

    C#操作AD及Exchange Server总结 这篇博客的目的:根据亲身项目经历,总结对AD及Exchange Server的操作,包括新建AD用户,设置密码,为AD用户创建邮箱等. 本文完全原创, ...

  3. Arduino 各种模块篇 摇杆模块

    Arduino的另外几种模块,我们常见的joystick摇杆模块. 用起来很爽,摇杆 有X,Y轴可调 这里有一篇非常想尽的示例代码: http://www.geek-workshop.com/foru ...

  4. 用友CDM系统,将货位间商品移库单(一步)修改为内调出入库单(一步)方法使用

    客户一般只购买CDM供应链系统,但是只买供应链模块不能进行内调等操作,据说插件将近15万(坑爹~~~) 货位间商品移库单和内调差不多,区别是货位间移库默认只能选择登陆账号所属机构的货位. 解决方案:分 ...

  5. [置顶] 遵循Java EE标准体系的开源GIS服务平台之二:平台部署

    传送门 ☞ 系统架构设计 ☞ 转载请注明 ☞ http://blog.csdn.net/leverage_1229 传送门 ☞ GoF23种设计模式 ☞ 转载请注明 ☞ http://blog.csd ...

  6. 使用Maven管理依赖JAR文件,自定义项目布局,利用ANT生成不同的发布包

    <?xml version="1.0" encoding="GB2312"?> <project name="CardInfo-We ...

  7. Mysql连表查询

    http://blog.csdn.net/qmhball/article/details/8000003 可以参考这篇文章

  8. 觉得VR头显太笨重?轻便的VR“神器”来了

    一直以来需要搭配手机才能使用的VRBOX(VR眼镜盒子)都被大家诟病携带不便.比较笨重.不透气等等问题.大家也一直期待能够有轻便的搭配手机的VR设备出现,最好是可以随身携带的.另外一方面,作为手机最常 ...

  9. Texture的渲染及截屏功能

    我们今天就简单说下 cocos2d的Texture的简单用法,并将一张大图裁剪成小图并保存起来 我们先准备一张大图,如下: 只看图,表太在意内容啊. 我们的目的就是将这张大图裁剪成一张张的小图并保存下 ...

  10. C语言考试可能会涉及到的内容

    以下是汽院下属科院C(B)考试范围,C(A)的话,不考的内容应该都会涉及到,重点内容会延伸至三.四章. 一.教材上的两套自测题 二.C语言实验与实训教程 第一章.第二章.第三章.第四章的典型练习及解释 ...