Hammer.js分析(三)——input.js
input.js是所有input文件夹中类的父类,浏览器事件绑定、初始化特定的input类、各种参数计算函数。
Input父类和其子类就是在做绑定事件,各种参数计算、整合、设置等返回自定义事件对象,交给识别器的相关对象使用。
一、Input父类

Input相当于一个抽象类,对象中总共有3个方法
1)handler(ev)
这相当于一个抽象方法,在上图中的6个子对象里,都会实现这个方法。
ev是事件对象(不是自定义的那个),例如触屏事件中就是 TouchEvent。
2)init()与destroy()
绑定事件,在各个子对象都会设置:
evEl、evTarget 或 evWin 事件类型字符串,字符串中有空格就是多个事件。
element、target 或 getWindowForElement(this.element) 就是需要绑定事件的对象。
domHandler 是在构造函数中定义的,就是执行子集重写过的 handler 方法。里面有个判断,“enable” 可以控制是否执行事件。
this.domHandler = function(ev) {
if (boolOrFn(manager.options.enable, [manager])) {
self.handler(ev);
}
};
二、input.js中的函数
1)createInputInstance(manager)
根据特性选择创建对象,可指定也可以根据浏览器特性自动绑定。在Manager的构造函数中会被调用。
var MOBILE_REGEX = /mobile|tablet|ip(ad|hone|od)|android/i;
var SUPPORT_TOUCH = ('ontouchstart' in window);
var SUPPORT_POINTER_EVENTS = prefixed(window, 'PointerEvent') !== undefined;
var SUPPORT_ONLY_TOUCH = SUPPORT_TOUCH && MOBILE_REGEX.test(navigator.userAgent); function createInputInstance(manager) {
var Type;
var inputClass = manager.options.inputClass;//自定义的函数 if (inputClass) {
Type = inputClass;
} else if (SUPPORT_POINTER_EVENTS) {
Type = PointerEventInput;
} else if (SUPPORT_ONLY_TOUCH) {
Type = TouchInput;
} else if (!SUPPORT_TOUCH) {
Type = MouseInput;
} else {
Type = TouchMouseInput;
}
return new(Type)(manager, inputHandler);//inputHandler是input.js中的一个函数
}
2)inputHandler(manager, eventType, input)
a. 在每个子类(touch.js中的TouchInput等)的构造函数中,都会执行“Input.apply(this, arguments);”,调用父类(input.js中的Input)的构造函数。
b. 在上一个函数中会将 inputHandler 传入到子类的构造函数中,这样的话父类中的 callback 就等于是 inputHandler。
c. 每个子类中的 handler 方法都会调用 callback 函数。
在每个子类中都会有类似的Map值,key是事件名,value是整数:
var TOUCH_INPUT_MAP = {
touchstart: INPUT_START,
touchmove: INPUT_MOVE,
touchend: INPUT_END,
touchcancel: INPUT_CANCEL
};
函数内容如下:
function inputHandler(manager, eventType, input) {
var pointersLen = input.pointers.length;
var changedPointersLen = input.changedPointers.length;
var isFirst = (eventType & INPUT_START && (pointersLen - changedPointersLen === 0));
var isFinal = (eventType & (INPUT_END | INPUT_CANCEL) && (pointersLen - changedPointersLen === 0));
//设置自定义事件对象的参数
input.isFirst = !!isFirst;
input.isFinal = !!isFinal;
if (isFirst) {
manager.session = {};
}
//设置 eventType,例如 'touchstart, mouseup, pointerdown'的对应整数,通过上面的Map值获取到
input.eventType = eventType;
//计算旋转、比例、角度、距离等信息
computeInputData(manager, input);
//执行隐藏的事件,这个在会在每个事件中调用,例如 'touchstart, mouseup, pointerdown'等
manager.emit('hammer.input', input);
manager.recognize(input);//执行Manager对象中的recognize方法
manager.session.prevInput = input;
}
3)computeDeltaXY(session, input)
经过计算的X与Y轴坐标,有正数和负数,以某个点为原点,画坐标轴。如下图所示:

以prevDelta的X和Y作为原点,center中的X和Y会随着移动而改变,offset就是第一次接触屏幕的点的clientX与clientY。
center是通过函数“getCenter(pointers)”获得的。
4)其他技术函数
1. getCenter(pointers):通过clientX和clientY,以及点的个数,计算所有点的中心坐标,没有负数
2. getVelocity(deltaTime, x, y):计算两个点之间的移动速度
3. getDirection(x, y):判断一个点到另外一个点的移动方向
4. getDistance(p1, p2, props):计算两个点之间的直线距离
5. getAngle(p1, p2, props):计算两个点之间的夹角
6. getRotation(start, end):计算两个点集之间的旋转度
7. getScale(start, end):计算两个点集之间的比例
三、自定义的input事件对象
在前面一篇“manager.js”的分析中,提到了自定义事件对象,里面还包括各种计算过的参数。
1)事件对象

2)移动方向常量
之所以是1,2,4,8,16是为了方便位运算。
var DIRECTION_NONE = 1;
var DIRECTION_LEFT = 2;
var DIRECTION_RIGHT = 4;
var DIRECTION_UP = 8;
var DIRECTION_DOWN = 16;
3)事件类型常量
var INPUT_START = 1;
var INPUT_MOVE = 2;
var INPUT_END = 4;
var INPUT_CANCEL = 8;
4)具体说明
|
Name |
Value |
|
angle |
移动角度 |
|
center |
多点触控的中心位置,或者单点的坐标 |
|
changedPointers |
改变了的触摸点数组,例如touchend中的事件中的事件对象TouchEvent里的changedTouches |
|
deltaTime |
交互过程的总时长(ms) |
|
deltaX |
经过计算后的X轴坐标点(参考computeDeltaXY) |
|
deltaY |
经过计算后的Y轴坐标点(参考computeDeltaXY) |
|
direction |
移动方向(参考移动方向常量) |
|
distance |
移动距离 |
|
eventType |
事件类型(参考事件类型常量) |
|
isFinal |
当前交互是否为最后一次(boolean) |
|
isFirst |
当前交互是否为首次(boolean) |
|
maxPointers |
最大触摸点数量 |
|
offsetDirection |
从起始点算起的移动方向(参考移动方向常量) |
|
overallVelocityX |
deltaX坐标点的移动速度 |
|
overallVelocityY |
deltaY坐标点的移动速度 |
|
overallVelocity |
比较overallVelocityX与overallVelocityY,选取绝对值大的那个 |
|
pointerType |
触摸点类型(touch、pen、mouse 或 kinect) |
|
pointers |
触摸点数组,例如touchend中事件对象TouchEvent里的touches属性 |
|
rotation |
多点触摸结束时的旋转数值,若为单点触摸则为0 |
|
scale |
多点触摸结束时的缩放比例,若为单点触摸则为1 |
|
srcEvent |
源事件对象(类型为TouchEvent、MouseEvent或PointerEvent) |
|
target |
接收事件的目标,上图中就是 document.getElementById('layer') |
|
timeStamp |
当前时间戳 |
|
velocityX |
(input.deltaX - last.deltaX)计算后X坐标点的移动速度 |
|
velocityY |
(input.deltaY - last.deltaY)计算后Y坐标点的移动速度 |
|
velocity |
比较velocityX与velocityY,选取绝对值大的那个 |
demo源码下载:
http://download.csdn.net/download/loneleaf1/9429375
参考资料:
http://tech.gilt.com/2014/09/23/five-things-you-need-to-know-about-hammer-js-2-0/
FIVE THINGS YOU NEED TO KNOW ABOUT HAMMER.JS 2.0
http://www.cnblogs.com/iamlilinfeng/p/4239957.html Hammer.js
http://colinued.leanote.com/post/%E7%A7%BB%E5%8A%A8%E7%AB%AF%E6%89%8B%E5%8A%BF%E5%BA%93hammerJS-2.0.4%E5%AE%98%E6%96%B9%E6%96%87%E6%A1%A3%E7%BF%BB%E8%AF%91 移动端手势库hammerJS-2.0.4
Hammer.js分析(三)——input.js的更多相关文章
- js分析 快速定位 js 代码, 还原被混淆压缩的 js 代码
-1.目录 0.参考 1.页面表现 2. 慢镜头观察:低速网络请求 3. 从头到尾调试:Fiddler 拦截 index.html 并添加 debugger; 4. 快速定位 js 代码 5. 还原被 ...
- Hammer.js分析(二)——manager.js
“Manager”是所有识别器实例的容器,它为你设置的元素安装了交互事件监听器,并设置了触摸事件特性. manager.js中的代码会涉及到input.js和recoginzer.js中的内容,这里会 ...
- angular源码分析:injector.js文件分析——angular中的依赖注入式如何实现的(续)
昨天晚上写完angular源码分析:angular中jqLite的实现--你可以丢掉jQuery了,给今天定了一个题angular源码分析:injector.js文件,以及angular的加载流程,但 ...
- 【转】关于URL编码/javascript/js url 编码/url的三个js编码函数
来源:http://www.cnblogs.com/huzi007/p/4174519.html 关于URL编码/javascript/js url 编码/url的三个js编码函数escape(),e ...
- 关于URL编码/javascript/js url 编码/url的三个js编码函数
关于URL编码/javascript/js url 编码/url的三个js编码函数escape(),encodeURI(),encodeURIComponent() 本文为您讲述关于js(javasc ...
- 前端总结·基础篇·JS(三)arguments、callee、call、apply、bind及函数封装和构造函数
前端总结系列 前端总结·基础篇·CSS(一)布局 前端总结·基础篇·CSS(二)视觉 前端总结·基础篇·CSS(三)补充 前端总结·基础篇·JS(一)原型.原型链.构造函数和字符串(String) 前 ...
- 初学node.js有感三
WebStorm下的node.js 一.回顾与继续 在前面,我们知道了node.js的基本框架和思路,在这些原生环境下我们对node.js的设计思想有了比较深刻的认识,并且具有了编写大型程 ...
- HTML5结合CSS的三种方法+结合JS的三种方法
HTML5+CSS: HTML中应用CSS的三种方法 一.内联 内联样式通过style属性直接套进HTML中去. 示例代码 <pstylepstyle="color:red" ...
- js分析 汽_车_之_家 js生成css伪元素 hs_kw44_configUS::before
0.参考 https://developer.mozilla.org/zh-CN/docs/Web/CSS/Pseudo-elements https://developer.mozilla.org/ ...
随机推荐
- Unity之CharacterController 碰撞问题总结
CharacterController 不会受到scene的重力影响,自带物理碰撞检测,在脱离导航网格的应用场景下(比如飞行),是很有优势的Unity原生工具组件.如果在复杂的应用场景里,会有多种CC ...
- 谢欣伦 - OpenDev原创教程 - 蓝牙设备查找类CxBthRemoteDeviceFind
这是一个精练的蓝牙设备查找类,类名.函数名和变量名均采用匈牙利命名法.小写的x代表我的姓氏首字母(谢欣伦),个人习惯而已,如有雷同,纯属巧合. CxBthRemoteDeviceFind的使用如下: ...
- You are attempting to run the 32-bit installer on a 64-bit version of Window
您正试图在64位版本的窗口中运行32位安装程序. 系统有32位操作系统和64位操作系统的分别,相同的软件的安装也需要区分操作操作系统的位数. 解决办法:查看自己系统类型,根据类型下载安装相应位数的软件 ...
- Visual Studio 2015 CTP6 发布
微软发布ASP.NET 5 支持在Windows.Mac和Linux上构建程序,Visual Studio 2015 CTP6(社区预览版)现已发布了.感兴趣的朋友们可以登录官网下载[http://w ...
- 架构之路(七)MVC点滴
我们目前正在开发中的是任务管理系统,一个前端复杂的项目,所以我们先从MVC讲起吧. WebForm 随着ASP.NET MVC的兴起,WebForm已成昨日黄花,但我其实还很想为WebForm说几句. ...
- Linux RAID卡优化
200 ? "200px" : this.width)!important;} --> 介绍 我们的生产服务器经常会做raid存储,但是单单做了raid就能保证性能高效和数据 ...
- AngularJs项目文件以及文件夹结构
app/ ----- Libs/ // references for all libs ---------- angular.js ---------- angular-route.js ----- ...
- InstallShield2013 error 6109
InstallShield在没添加打包文件时是可以编译生成安装包的,在增加打包文件之后就报以下错误: ISEXP : error : -6109: Internal build error ISEXP ...
- Atitit 分区后的查询 mysql分区记录的流程与原理
Atitit 分区后的查询 mysql分区记录的流程与原理 1.1.1. ibd是MySQL数据文件.索引文件1 1.2. 已经又数据了,如何分区? 给已有的表加上分区 ]1 1.3. 分成4个区, ...
- dede在php7上空白
最近想看一本小说,想采集回来看,结果发现除了dedecms支持php7.0,其他主流cms基本上都不支持php7.0 在本地win7上调试了一遍,没有问题,放到linux服务器上的时候,发现打开任何页 ...