标签:单击 需要 wip ted mod log nbsp 加载 line
前言
前几天,给客户做了一个图片点击放大,很简单,客户说能不能双手指缩放图片呢?
想到了hammer,不管好用不好用,总得试。
网上居然没有像样的中文文档和成熟案例,有的文写的鬼都看不懂。还是自已动手吧。
一 效果演示:
双击或两根手指放大
鼠标或手指拖动
再双击图片复原
二 设计思路:
利用hammer.js 自带的api,监听手指事件,对图像的css样式重新定义来实现
三 hammer.js 实现代码与逻辑
1 图片对像id data-scale属性手动设置,为了js写法方便
2 引入js文件,并初始化实例
js方法经测试,必须写在modelLoad中,否则页面加载只执行一次js,重新返回页面后js不能执行
3 创建监听方法
先说说hammer.js都有哪些方法
hammer.ondragstart =function(ev) { }; // 开始拖动hammer.ondrag = function(ev) { }; // 拖动中hammer.ondragend = function(ev) { }; // 拖动结束hammer.onswipe = function(ev) { }; // 滑动hammer.ontap = function(ev) { }; // 单击hammer.ondoubletap =function(ev) { }; //双击hammer.onhold = function(ev) { }; // 长按hammer.ontransformstart =function(ev) { }; // 双指收张开始hammer.ontransform =function(ev) { }; // 双指收张中hammer.ontransformend =function(ev) { }; // 双指收张结束hammer.onrelease =function(ev) { }; // 手指离开屏幕 在Pinch事件和Rotate事件中,我们用了hammertime.add(new Hammer.Pinch());和hammertime.add(new Hammer.Rotate ());而其他四个事件没有用,而是直接添加了事件的监听程序。原因在于,我们在new Hammer(htmlElement)的时候,Hammer.js默认对Pan、Press、Swipe和Tab事件进行了监听。但没有对Pinch和 Rotate事件进行监听。标签:单击 需要 wip ted mod log nbsp 加载 line
原文地址:http://www.cnblogs.com/fangziffff123/p/6234000.html