使用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 ...
随机推荐
- 18 4Sum(寻找四个数之和为指定数的集合Medium)
题目意思:给一个乱序数组,在里面寻找三个数之和为target的所有情况,这些情况不能重复,增序排列 思路:采用3Sum的做法 ps:有见一种用hash的,存任意两个元素的和,然后变成3sum问题,需要 ...
- ThinkPHP框架下,给jq动态添加的标签添加点击事件移除标签
jq移除标签主要就是$("#要移除的id").remove();不再赘述,这里要提醒的是jq中动态添加标签后怎样添加点击事件.一般的jq添加点击事件是用这种方法$("#i ...
- ios+oc面试题
ios+oc面试题 浅复制和深复制的区别?//浅拷贝和深拷贝答案:浅层复制(copy):只复制指向对象的指针,而不复制引用对象本身.//通过对象的指针来访问这个对象深层复制(mutableCo ...
- go程序性能优化
性能优化总结: 1 尽量避免频繁创建对象,即减少&{},new,make的使用2 数组可当切片用,当需要使用切片时,可考虑能使用数组来减少切片的创建3 当某类临时对象被多个协频繁程使用时,可用 ...
- 看奢侈品Prada如何使用物联网
这是峰哥在一家国际顶级商学院听课的笔记.这是个巨变的时代,有趣的时代. 一 PRADA在纽约的旗舰店.每件衣服上都有RFID码.每当一个顾客拿起一件PRADA进试衣间,RFID会被自动识别,试衣间里的 ...
- 非主窗体在任务栏显示按钮(简单好用)good
非主窗体在任务栏显示按钮 type TForm2 = class(TForm) private { Private declarations } public { Public declaration ...
- ASCII是指128个字符(不是256个)和ASCII Extended Characters(就是那些奇怪的外文字符)
ASCII第一次以规范标准的型态发表是在1967年,最后一次更新则是在1986年,至今为止共定义了128个字元:其中33个字元无法显示(一些终端提供了扩展,使得这些字符可显示为诸如笑脸.扑克牌花式等8 ...
- C++中强制变换之const_cast
今天学习了一下C++中的强制转换,看了const_cast,我发现了这个转换关键字的奇怪之处,于是把它记录一下,废话不说,先看一个程序: #include <iostream> using ...
- 数据结构(线段树):SPOJ GSS3 - Can you answer these queries III
GSS3 - Can you answer these queries III You are given a sequence A of N (N <= 50000) integers bet ...
- Count Primes ——LeetCode
Description: Count the number of prime numbers less than a non-negative number, n. 题目大意:给一个int,返回小于它 ...