使用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 ...
随机推荐
- WebSocket基于javaweb+tomcat的简易demo程序
由于项目需要,前端向后台发起请求后,后台需要分成多个步骤进行相关操作,而且不能确定各步骤完成所需要的时间 倘若使用ajax重复访问后台以获取实时数据,显然不合适,无论是对客户端,还是服务端的资源很是浪 ...
- mysql锁死的现象判断
一般发生表锁死这种低级问题,就有两种情况:1.程序员水平太菜,2.程序逻辑错误. 一旦发生系统会出现超时,关键是有可能你看不到正在活动的php进程,而系统的慢查询日志也不会记录,只能通过show fu ...
- JQuery zoom插件学习
jquery zoom是一款图片放大插件,经常用在商城商品页面里. 使用JQuery zoom插件,除了需要引入JQuery.js外,还要引入JQuery.zoom.js文件及jqzoom.css文件 ...
- JDK环境变量配置贺Tomcat环境搭建
一.安装JDK JDK (Java Develpmet kit) Java开发环境(工具包和运行环境jre) 是Java开发的核心,包括:编译程序的命令 javac 运行程序java命令 he jav ...
- PHPCMS二层栏目调用
{pc:content action="category" catid="0" num="25" siteid="$siteid& ...
- day2练习题
#import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { @autoreleasepool { ...
- Objective-C基础 便利构造器 单例模式1-17
Objective-C基础 便利构造器 单例模式1-17 便利构造器 单例模式 1.在声明时指定setter或getter方法,则用点运算符方法调用时默认调用的就是自己指定的方法2.单例:唯一性,如: ...
- Ruby自学笔记(四)— 数组,Hash,正则表达式简介
今天学习的是数组和Hash,数组在很多编程语言中都能常常用到. 数组: 数组是存储数据的一种容器,在Ruby中,数组中存储的数据可以是任何类型的数据:这和JAVA不同,在JAVA中,数组是存储同一类型 ...
- div+css知识点
前端书写规范: 1.所有书写均在英文半角状态下的小写: 2.id,class必须以字母开头: 3.所有标签必须闭合: 4.html标签用tab键缩进: 5.属性值必须带引号: 6.<!-- ht ...
- ExtJS简单的动画效果2(ext js淡入淡出特效)
Ext 开发小组则提供了 Fx 类集中处理了大部分常用的 js 动画特效,减少了我们自己手写代码的复杂度. 面我给出一个简单的实例代码,其中囊括了大部分的 Ext 动画效果: (注意导入js和css文 ...