ktouch移动端事件库
最近闲来无事,写了个移动端的事件库,代码贴在下面,大家勿拍。
/**
@version 1.0.0
@author gangli
@deprecated 移动端触摸事件库
*/
(function () {
"use strict";
var util = {
$: function (selector) {
return document.querySelector(selector);
},
getEventInfo: function (e) {
var _e = {};
_e.pageX = e.changedTouches[0].pageX;
_e.pageY = e.changedTouches[0].pageY;
_e.target = e.target;
return _e;
}
};
var _tap = function (callback) {
this.addEventListener('touchstart', function (e) {
var _e = util.getEventInfo(e);
_e.type = 'tap';
callback.call(this, _e);
}, false);
};
var _longtap = function (callback) {
var interval = 800 , s , e , timer , el;
this.addEventListener('touchstart', function (e) {
var _e = util.getEventInfo(e);
el = _e.target;
s = Date.now();
timer = setTimeout(function () {
_e.type = 'longtap';
callback.call(el, _e);
}, interval);
}, false);
this.addEventListener('touchend', function (e) {
clearTimeout(timer);
}, false);
};
var _swipe = function (callback) {
var s = {}, e = {}, d = {}, distance = 50,
angle = 0,
type;
this.addEventListener('touchstart', function (evt) {
var _e = util.getEventInfo(evt);
s.x = _e.pageX;
s.y = _e.pageY;
evt.preventDefault();
}, false);
this.addEventListener('touchend', function (evt) {
var _e = util.getEventInfo(evt);
e.x = _e.pageX;
e.y = _e.pageY;
d.x = e.x - s.x;
d.y = e.y - s.y;
if (Math.abs(d.x) < distance && Math.abs(d.y) < distance) return false;
angle = Math.abs(Math.atan((e.y - s.y) / (e.x - s.x)) / Math.PI * 180);
if (angle > 45) {
type = d.y < 0 ? 'swipe-up' : 'swipe-down';
} else {
type = d.x < 0 ? 'swipe-left' : 'swipe-right';
}
callback.call(this, {
type: type,
start: s,
end: e,
distance: d,
target: _e.target
});
evt.preventDefault();
}, false);
}
var _drag = function (callback) {
var dragStart = false, s = {}, e = {}, o = {};
this.addEventListener('touchstart', function (evt) {
dragStart = true;
var _e = util.getEventInfo(evt);
s.x = _e.pageX;
s.y = _e.pageY;
evt.preventDefault();
}, false);
this.addEventListener('touchmove', function (evt) {
if (!dragStart) return;
var _e = util.getEventInfo(evt);
o.x = _e.pageX - s.x;
o.y = _e.pageY - s.y;
callback.call(this, {
type: "drag-move",
start: s,
offset: o,
target: _e.target
});
}, false);
this.addEventListener('touchend', function (evt) {
dragStart = false;
var _e = util.getEventInfo(evt);
e.x = _e.pageX;
e.y = _e.pageY;
callback.call(this, {
type: "drag-end",
start: s,
offset: o,
end: e,
target: _e.target
});
}, false);
}
var eventMap = {
tap: _tap,
swipe: _swipe,
longtap: _longtap,
drag: _drag
}
var ktouch = {
ver: '1.0.0',
on: function (el, type, fn) {
try {
var el = util.$(el);
eventMap[type].call(el, fn);
return this;
} catch (e) {
console.error('type error : %s is not allowed', type);
}
}
}
window.ktouch = ktouch;
})();
github网址:https://github.com/kbqncf/ktouch
ktouch移动端事件库的更多相关文章
- cocos2d-x开发:服务端基础库封装
元旦前面几天都在忙着面试,随后的几天也就一直在做服务端基础库开发方面的工作.对于服务端开发,是很久之前的事情了.那时候我还在大学读书,一直都是在倒腾服务端开发方面的东西,毕业后参加公司工作就是一直从事 ...
- touch.js - 移动设备上的手势识别与事件库
Touch.js 是移动设备上的手势识别与事件库, 由百度云Clouda团队维护,也是在百度内部广泛使用的开发工具.Touch.js手势库专为移动设备设计.Touch.js对于网页设计师来说,是一款不 ...
- 利用epoll写一个"迷你"的网络事件库
epoll是linux下高性能的IO复用技术,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率.另一点原因就是获取 ...
- Yarn的服务库和事件库使用方法
事件类型定义: package org.apache.hadoop.event; public enum JobEventType { JOB_KILL, JOB_INIT, JOB_START } ...
- Threejs 的场景查看 - 几个交互事件库助你方便查看场景
Threejs 的场景查看 - 几个交互事件库助你方便查看场景 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业用途-保持一致&q ...
- 服务端事件EventSource揭秘
服务端推 服务端推,指的是由服务器主动的向客户端发送消息(响应).在应用层的HTTP协议实现中,"请求-响应"是一个round trip,它的起点来自客户端,因此在应用层之上无法实 ...
- Hadoop服务库与事件库的使用及其工作流程
Hadoop服务库与事件库的使用及其工作流程 Hadoop服务库: YARN采用了基于服务的对象管理模型,主要特点有: 被服务化的对象分4个状态:NOTINITED,INITED,STARTED, ...
- Hadoop2源码分析-YARN 的服务库和事件库
1.概述 在<Hadoop2源码分析-YARN RPC 示例介绍>一文当中,给大家介绍了YARN 的 RPC 机制,以及相关代码的演示,今天我们继续去学习 YARN 的服务库和事件库,分享 ...
- 值得收藏的8个Web端组件库
值得收藏的8个Web端组件库 Ant Design 介绍:一个服务于企业级产品的设计体系,基于『确定』和『自然』的设计价值观和模块化的解决方案,让设计者专注于更好的用户体验. 组件库地址:https: ...
随机推荐
- Windows 8及以上系统安装好SQL Server 2008之后找不到SQL Server配置管理器的问题
直接的方法: 打开[运行]->输入[C:\Windows\SysWOW64\mmc.exe /32 C:\Windows\SysWOW64\SQLServerManager10.msc]即可. ...
- MVC3项目依赖文件错误解决
MVC3的项目依赖分为两大类: 1.ASP.NET Web Pages 2.ASP.NET MVC 3 如果没有正确引入,或者项目的版本有错误会出现程序集引用错误. 在服务器上部署时,解决思路如下: ...
- Scala可变长度参数
可变长度参数 Scala 允许你指明函数的最后一个参数可以是重复的.这可以允许客户向函数传入可变长度参数列表.想要标注一个重复参数,在参数的类型之后放一个星号.例如: scala> def ec ...
- 海边直播目标2017全国初中数学竞赛班课堂测试题解答-The Final
1. 设函数 $f(x) = 2^x(ax^2 + bx + c)$ 满足等式 $f(x+1) - f(x) = 2^x\cdot x^2$, 求 $f(1)$. 解答: 由 $f(x) = 2^x( ...
- hdu 2010 - 水仙花数
题意: 数学上有个水仙花数,他是这样定义的:"水仙花数"是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3.现在要求输出所有在m和n范围内的水仙花 ...
- Linux操作系统发展史
1984年,面对美国电话电报公司启动的UNIX商业化计划和程序开发的封闭模式,麻省理工学院的RichardM.Stallman发起了一项国际性的源代码开放的GNU(GNU's Not Unix)计划, ...
- ES6之let(理解闭包)和const命令
ES6之let(理解闭包)和const命令 最近做项目的过程中,使用到了ES6,因为之前很少接触,所以使用起来还不够熟悉.因此购买了阮一峰老师的ES6标准入门,在此感谢阮一峰老师的著作. 我们知道,E ...
- 机器学习笔记--KNN算法1
前言 Hello ,everyone. 我是小花.大四毕业,留在学校有点事情,就在这里和大家吹吹我们的狐朋狗友算法---KNN算法,为什么叫狐朋狗友算法呢,在这里我先卖个关子,且听我慢慢道来. 一 K ...
- mybatis 传递参数的方法总结
有三种mybatis传递参数的方式: 第一种 mybatis传入参数是有序号的,可以直接用序号取得参数 User selectUser(String name,String area); 可以在xml ...
- coreseek 中文搜索和高亮
配置文件 # # Minimal Sphinx configuration sample (clean, simple, functional) # source post { type = mysq ...