使用iScroll和photoswipe写手机浏览图片的插件的几点经验
首先,当我知道我得到一个任务需要写一个在手机上能浏览图片的插件时,我第一想到了iScroll。它的左右滑动,上下滑动的效果在安卓手机上也能让用户有良好的体验,自己写也能方便控制。
我的需求是,插件要能左右滑动图片,当图片很长的时候要能上下滑动浏览全部图片,还要支持手势缩放,特别是较长或者较宽的图片。
1.
当最开始的时候,我做了一个本地缓存,把图片保存起来,为了加载滑动图片能更加流畅。
js代码:var json=new Array(); for(var i=0;i<4;i++){//4张图 json.push({id:i,url:"images/"+i+".jpg"}); } localStorage.setItem("imgList",JSON.stringify(json));
使用iScroll的结构是这样的:
<div id="wrapper1"> <div id="scroller1"> <ul id="thelist"> </ul> </div> </div> <!-- Mask layer -->
其中的li为动态加载生成,然后将li标签设置屏幕宽度,让li中的img标签宽度为100%,这样就可以全宽展示图片,实现左右一滑一张图。缩放的话,iScroll中有个属性,zoom:true就行。
这样一来,左右滑动、图片手势缩放没问题,可是当有的图片长度超过屏幕长度的时候,它就无法上下滑动显示被遮罩的部分了。
我试图对li用height:auto;也没效果。
后来查阅资料才知道,是iScroll为了能有更好的滑动效果,在它左右滑动的时候,禁用了上下滑动。
比如说iScroll.js中的这句:onBeforeScrollStart: function (e) { e.preventDefault(); }。
我曾想过在每张图片load之前判断图片的长度,如果图片长度大于屏幕长度,则对它限制height为屏幕高,否则就限制width为屏幕宽。
但是如果图片数量很大的话,这样的代价显然是不合理的。
再经过大量查找,我发现了这个:
http://oklai.name/
2013/03/%e8%a7%a3%e5%86%b3iscroll%e6%a8%aa%e5%90%91%e6%bb%9a%e5%8a%a8%e5%8c%ba%e5%9f%9f%e6%97%a0%e6%b3%95%
e6%8b%89%e5%8a%a8%e9%a1%b5%e9%9d%a2%e7%9a%84%e9%97%ae%e9%a2%98/
http://oklai.name/
2013/03/%e8%a7%a3%e5%86%b3iscroll%e6%a8%aa%e5%90%91%e6%bb%9a%e5%8a%a8%e5%8c%ba%e5%9f%9f%e6%97%a0%e6%b3%95%
e6%8b%89%e5%8a%a8%e9%a1%b5%e9%9d%a2%e7%9a%84%e9%97%ae%e9%a2%98/
经过修改,确实可以实现左右滑动图片的同时,若图片长度超出屏幕长度,则可以上下滑动浏览。但是用户体验十分不好,图片变成了上下左右等8个方向都能滑动了。
于是我放弃了iScroll。(在这里求大神有更好的解决方法~)
总结为:iScroll在横向滚动区域的上下滑动问题。
2.
然后,我开始使考虑用photoswipe插件。
代码:
<div id="MainContent"> <ul id="Gallery" class="gallery" style="display:none"> </ul> </div>
使用photoswipe的过程很顺利,它支持左右滑动,若是图片是超长图片的话也能将图片高度缩至屏幕高度从而能看到整张图。
但是,它仅支持iOS下的缩放功能(也是设置allowUserZoom:true),对于android操作系统,文档给出的话是it is compatible with Android(它能兼容android),但是其实是在android下不支持缩放功能的。
我在github上找到了一位大神的解决方案。
给出截图:
附上demo下载链接:https://github.com/agliottone/PhotoSwipe
总结为:photoswipe在安卓下的手势缩放问题。
然后我的图片插件问题得到圆满解决。iOS上能轻松滑动缩放,android上也能滑动缩放。happy!
(以上android仅指4.0或以上版本)
使用iScroll和photoswipe写手机浏览图片的插件的几点经验的更多相关文章
- wpf 模拟3D效果(和手机浏览图片效果相似)(附源码)
原文 wpf 模拟3D效果(和手机浏览图片效果相似)(附源码) pf的3D是一个很有意思的东西,类似于ps的效果,类似于电影动画的效果,因为动画的效果,(对于3D基础的摄像机,光源,之类不介绍,对于依 ...
- 手机浏览PC版页面出现背景图片显示不全的问题解决方案
手机浏览PC版页面出现背景图片显示不全 给定宽高的值
- 手机端网页技术--使自己做的asp.net网页适应手机浏览
使自己做的asp.net网页适应手机浏览 特别提醒: 对于文本框和其他控件,无法自适应,只有纯粹的文本和table的单元格可以自适应,其他的只有设置为具体的宽度,或者在一个表格中(本来在电脑中显示一行 ...
- 会写网页 就会写手机APP -- Hybrid Mobile Apps for ASP.NET Developers
您好,这篇文章是我的BLOG发出,原始出处在此: 会写网页 就会写手机APP -- Hybrid Mobile Apps for ASP.NET Developers http://www.dotbl ...
- js检测是否手机浏览的函数
原文:js检测是否手机浏览的函数 查看一个web应用的时候查看源代码无意发现的,记录一下,万能什么时候能用得着呢! function isMobile() { var mobile = navigat ...
- 移动端 H5 拍照 从手机选择图片,移动端预览,图片压缩,图片预览,再上传服务器
前言:最近公司的项目在做全网营销,要做非微信浏览器的wap 站 的改版,其中涉及到的一点技术就是采用H5 选择手机相册中的图片,或者拍照,再将获取的图片进行压缩之后上传. 这个功能模块主要有这5点比较 ...
- jQuery弹出窗口浏览图片
效果预览:http://keleyi.com/keleyi/phtml/jqtexiao/3.htm HTML文件代码: <!DOCTYPE HTML> <html> < ...
- ios学习-制作一个浏览图片的Demo
一.项目要求:制作一个浏览图片的Demo,要求包含夜间模式,以及改变图片大小,能够显示不同的图片描述 二.开发步骤: 1.在storyboard上添加一个空白的View,然后添加”设置“按钮,添加im ...
- Chrome模拟手机浏览网页
用Chrome模拟手机浏览网页,只需要编辑一个命令就可以实现 C:\Users\xxx\AppData\Local\Google\Chrome\Application\chrome.exe --use ...
随机推荐
- npm的镜像替换成淘宝
1.得到原本的镜像地址 npm get registry > https://registry.npmjs.org/ 设成淘宝的 npm config set registry http://r ...
- Servlet(三)
重定向 服务器向浏览器发送一个302状态码以及一个Location消息头(该消息头的值是一个地址,称之为重定向地址),浏览器收到后会立即向重定向的地址发出请求,使用相应对象的API方法实现(respo ...
- 英语学习[ZZ]
本文作者三年间从四级勉强及格到高级口译笔试210,口试232.找工作面试时给其口试的老外考官听了一分钟就说你的英语不用考了.虽不敢说方法一定是最好的,但从现在开始随便谁不要再去找学习资料,每天花两个钟 ...
- 哈哈,CSDN又支持Windows Live Writer了
从10年开始写CSDN博客,后面不支持WLW了,就不怎么写了,话说自带的编辑器确实不怎么样,不过又支持了,那就哈哈,重新开工了. 关于如何配置的,跟以前一样,详情如下所示: http://blog.c ...
- 转:理解 PHP 中的 Streams
本文转自:开源中国社区 [http://www.oschina.net]本文标题:理解 PHP 中的 Streams 本文地址:http://www.oschina.net/translate/und ...
- Unity3D Quaternion各属性和函数测试
Quaternion属性与方法 一,属性: x.y.z就不说了,只看一个eulerAngles,代码如下: public Quaternion rotation = Quaternion.identi ...
- python Hbase Thrift pycharm 及引入包
cp -r hbase/ /usr/lib/python2.7/site-packages/ 官方示例子http://code.google.com/p/hbase-thrift/source/bro ...
- TF-IDF与余弦相似性的应用
类似的算法已经被写成了工具,比如基于Java的Classifier4J库的SimpleSummariser模块.基于C语言的OTS库.以及基于classifier4J的C#实现和python实现.
- BZOJ 1049 数字序列
Description 现在我们有一个长度为n的整数序列A.但是它太不好看了,于是我们希望把它变成一个单调严格上升的序列.但是不希望改变过多的数,也不希望改变的幅度太大. Input 第一行包含一个数 ...
- [BZOJ 3172] [Tjoi2013] 单词 【AC自动机】
题目链接:BZOJ - 3172 题目分析: 题目要求求出每个单词出现的次数,如果把每个单词都在AC自动机里直接跑一遍,复杂度会很高. 这里使用AC自动机的“副产品”——Fail树,Fail树的一个性 ...