hammer.js方法总结(只做了一个简单的demo)

2023-02-17,,,,

html

<!DOCTYPE html>
<html> <head>
<meta charset="UTF-8">
<title></title>
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
<style>
.demo-box {
width: 300px;
height: 300px;
overflow: hidden;
position: relative;
} .demo-box img {
height: 500px;
width: 1900px;
position: absolute;
margin-left: -950px;
pointer-events: none;
margin-top: -220px;
left: 50%;
top: 50%;
max-width: none;
} .demo-box img.active {
display: block;
} .demo-box .page-num {
position: absolute;
bottom: 5px;
left: 50%;
margin-left: -20px;
color: white;
z-index: 999;
background: rgba(170, 170, 170, 0.5);
padding: 3px;
border-radius: 5px;
border: 1px solid black;
pointer-events: none;
} .page-num .active {
color: red;
} .demo-box .page-num {
color: white;
pointer-events: none;
} .demo img {
display: inline-block;
} .box img {
display: none;
} .demo-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(70, 70, 70, 0.8);
display: none;
} .demo-overlay img {
width: 50px;
height: 50px;
position: absolute;
top: 50%;
left: 50%;
margin-left: -25px;
margin-top: -25px;
}
</style>
</head> <body class="homepage">
<div class="pan demo-box demo">
<img src="img/box.png" />
</div>
<br />
<br />
<br />
<br />
<div class="pinch demo-box demo">
<img src="img/box.png" />
</div>
<br />
<br />
<br />
<br />
<div class="rotate demo-box demo">
<img src="img/box.png" />
</div>
<br />
<br />
<br />
<br />
<div class="swipe demo-box box">
<img src="img/xsqy.png" class="active" />
<img src="img/jfsc.png" />
<img src="img/fx.png" />
<div class="page-num">
<span class="active">1</span>
<span class="">2</span>
<span class="">3</span>
</div>
</div>
<br />
<br />
<br />
<br />
<div class="tap demo-box box">
<img src="img/xsqy.png" class="active" />
<img src="img/jfsc.png" />
<img src="img/fx.png" />
<div class="page-num">
<span class="active">1</span>
<span class="">2</span>
<span class="">3</span>
</div>
</div>
<br />
<br />
<br />
<br />
<div class="press demo-box demo">
<img src="img/box.png" />
<div class="demo-overlay">
<img src="img/shouhuodizhicheckz.png">
</div>
</div>
</body>
<script type="text/javascript" src="js/jquery.min.js"></script> //自行下载
<script type="text/javascript" src="js/hammer.js"></script> //自行下载
<script type="text/javascript" src="js/hammer-index.js"></script> //以下代码 </html>

hammer-index.js

$(function() {
(function() {
var img, margin;
new Hammer($(".pan")[0], {
domEvents: true
});
$(".pan").on("panstart", function(e) {
img = $(".pan img");
margin = parseInt(img.css("margin-left"), 10);
});
$(".pan").on("pan", function(e) {
var delta = margin + e.originalEvent.gesture.deltaX;
console.log(delta);
if(delta >= -1750 && delta <= -150) {
img.css({
"margin-left": margin + e.originalEvent.gesture.deltaX
});
}
});
})();
// pinch
(function() {
var ham = new Hammer($(".pinch")[0], {
domEvents: true
});
var width = $(window).width();
var height = $(window).height();
var left = 950;
var top = 220;
ham.get('pinch').set({
enable: true
});
$(".pinch").on("pinch", function(e) {
console.log("pinch");
if(width * e.originalEvent.gesture.scale >= 300) {
$(this).find("img").css({
width: width * e.originalEvent.gesture.scale,
"margin-left": -left * e.originalEvent.gesture.scale,
height: height * e.originalEvent.gesture.scale,
"margin-top": -top * e.originalEvent.gesture.scale
});
}
console.log(e.originalEvent.gesture.scale);
});
$(".pinch").on("pinchend", function(e) {
width = width * e.originalEvent.gesture.scale;
height = height * e.originalEvent.gesture.scale;
left = left * e.originalEvent.gesture.scale;
top = top * e.originalEvent.gesture.scale;
console.log(width);
});
})(); // rotate
(function() {
var ham = new Hammer($(".rotate")[0], {
domEvents: true
});
var liveScale = 1;
var currentRotation = 0; ham.get('rotate').set({
enable: true
});
$(".rotate").on("rotate", function(e) {
alert(1)
var rotation = currentRotation + Math.round(liveScale * e.originalEvent.gesture.rotation);
$(this).find("img").css("transform", "rotate( " + rotation + "deg)");
});
$(".rotate").on("rotateend", function(e) {
currentRotation += Math.round(e.originalEvent.gesture.rotation);
});
})(); (function() {
new Hammer($(".swipe")[0], {
domEvents: true
});
var current = 0;
var imgs = $(".demo-box.swipe img");
var pages = $(".swipe .page-num span");
$(".swipe").on("swipeleft", function(e) {
if(imgs[current + 1]) {
imgs.removeClass("active");
imgs.eq(++current).addClass("active");
pages.removeClass("active");
pages.eq(current).addClass("active");
}
});
$(".swipe").on("swiperight", function(e) {
if(imgs[current - 1]) {
imgs.removeClass("active");
imgs.eq(--current).addClass("active");
pages.removeClass("active");
pages.eq(current).addClass("active");
}
});
})(); // tap
(function() {
new Hammer($(".tap")[0], {
domEvents: true
});
var current = 0;
var imgs = $(".demo-box.tap img");
var pages = $(".tap .page-num span");
$(".tap").on("tap", function(e) {
console.log("tap");
if(imgs[current + 1]) {
current++;
} else {
current = 0;
}
console.log(current);
imgs.removeClass("active");
imgs.eq(current).addClass("active");
pages.removeClass("active");
pages.eq(current).addClass("active");
});
})(); // press
(function() {
new Hammer($(".press")[0], {
domEvents: true
});
$(".press").on("press", function(e) {
$(".demo-overlay").toggle();
});
})();
})

hammer.js方法总结(只做了一个简单的demo)的相关教程结束。

《hammer.js方法总结(只做了一个简单的demo).doc》

下载本文的Word格式文档,以方便收藏与打印。