hammer.js實(shí)現(xiàn)圖片手勢(shì)放大效果
本文實(shí)例為大家分享了hammer.js實(shí)現(xiàn)圖片手勢(shì)放大效果的具體代碼,供大家參考,具體內(nèi)容如下
//圖片手勢(shì)放大
var reqAnimationFrame = (function() {
return window[Hammer.prefixed(window, 'requestAnimationFrame')] || function(callback) {
window.setTimeout(callback, 1000 / 60);
};
})();
var el = $('img');
var ticking = false;
var transform;
var initScale = 1;
var _eImg = '';
for (var m = 0; m < el.length; m++) {
var mc = new Hammer.Manager(el[m]);
mc.add(new Hammer.Pan({
threshold: 0,
pointers: 0
}));
mc.add(new Hammer.Swipe()).recognizeWith(mc.get('pan'));
mc.add(new Hammer.Pinch({
threshold: 0
})).recognizeWith(mc.get('pan'));
mc.on('panstart panmove', onPan);
mc.on('pinchstart pinchmove', onPinch);
mc.on('swipe', onSwipe);
}
function resetElement() {
el.addClass('animate');
transform = {
translate: {
x: 0,
y: 0
},
scale: 1,
angle: 0,
rx: 0,
ry: 0,
rz: 0
};
requestElementUpdate();
}
function updateElementTransform() {
var value = ['translate3d(' + transform.translate.x + 'px, ' + transform.translate.y + 'px, 0)', 'scale(' + transform.scale + ', ' + transform.scale + ')', 'rotate3d(' + transform.rx + ',' + transform.ry + ',' + transform.rz + ',' + transform.angle + 'deg)'];
value = value.join(' ');
if (_eImg != '') {
_eImg.style.webkitTransform = value;
_eImg.style.mozTransform = value;
_eImg.style.transform = value;
//_eImg.css({ 'transform': value }, { '-webkit-transform': value });
}
ticking = false;
}
function requestElementUpdate() {
if (!ticking) {
reqAnimationFrame(updateElementTransform);
ticking = true;
}
}
function onPan(ev) {
el.removeClass('animate');
transform.translate = {
x: ev.deltaX,
y: ev.deltaY
};
}
function onPinch(ev) {
if (ev.type == 'pinchstart') {
initScale = transform.scale || 1;
}
el.removeClass('animate');
transform.scale = initScale * ev.scale;
requestElementUpdate();
_eImg = ev.target;
return _eImg;
}
function onSwipe(ev) {
var angle = 10;
transform.ry = (ev.direction & Hammer.DIRECTION_HORIZONTAL) ? 1 : 0;
transform.rx = (ev.direction & Hammer.DIRECTION_VERTICAL) ? 1 : 0;
transform.angle = (ev.direction & (Hammer.DIRECTION_RIGHT | Hammer.DIRECTION_UP)) ? angle : -angle;
requestElementUpdate();
_eImg = ev.target;
return _eImg;
}
resetElement();
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- javascript實(shí)現(xiàn)商品圖片放大鏡
- js實(shí)現(xiàn)點(diǎn)擊圖片在屏幕中間彈出放大效果
- JavaScript實(shí)現(xiàn)圖片放大鏡效果
- JavaScript實(shí)現(xiàn)多張圖片放大鏡效果示例【不限定圖片尺寸,rem單位】
- JavaScript實(shí)現(xiàn)圖片的放大縮小及拖拽功能示例
- js實(shí)現(xiàn)圖片局部放大效果詳解
- js實(shí)現(xiàn)圖片放大并跟隨鼠標(biāo)移動(dòng)特效
- JS滾輪控制圖片縮放大小和拖動(dòng)的實(shí)例代碼
- JS與CSS3實(shí)現(xiàn)圖片響應(yīng)鼠標(biāo)移動(dòng)放大效果示例
- JS實(shí)現(xiàn)圖片放大鏡插件詳解
- js實(shí)現(xiàn)圖片放大展示效果
- JavaScript實(shí)現(xiàn)圖片放大預(yù)覽效果
相關(guān)文章
javascript實(shí)現(xiàn)禁止右鍵和F12查看源代碼
這篇文章主要介紹了javascript實(shí)現(xiàn)禁止右鍵和F12查看源代碼的代碼,需要的朋友可以參考下2014-12-12
iOS和Android用同一個(gè)二維碼實(shí)現(xiàn)跳轉(zhuǎn)下載鏈接的方法
這篇文章給大家分享的是iOS和Android掃描同一個(gè)二維碼,分別跳到各自的下載鏈接的實(shí)現(xiàn)方法,文中給出了實(shí)例代碼,有需要的朋友們可以參考借鑒。2016-09-09
javascript removeChild 使用注意事項(xiàng)
removeChild的注意事項(xiàng)。大家可以參考下。2009-04-04
JS實(shí)現(xiàn)按鈕添加背景音樂(lè)示例代碼
這篇文章主要介紹了JS實(shí)現(xiàn)按鈕添加背景音樂(lè)示例代碼,需要的朋友可以參考下2017-10-10
JavaScript canvas繪制圓形加載進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了JavaScript canvas繪制圓形加載進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
JS動(dòng)態(tài)高度虛擬列表實(shí)現(xiàn)原理解析
這篇文章將和大家一起探討一下動(dòng)態(tài)高度虛擬列表原理并指出常見(jiàn)虛擬列表采用累計(jì)高度方式存在缺點(diǎn),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-11-11
javascript將非數(shù)值轉(zhuǎn)換為數(shù)值
parseInt()不能轉(zhuǎn)換浮點(diǎn)型數(shù)值,我們用parseFloat()來(lái)解決。這篇文章主要介紹了javascript將非數(shù)值轉(zhuǎn)換為數(shù)值,需要的朋友可以參考下2018-09-09
IE瀏覽器不支持getElementsByClassName的解決方法
這篇文章主要介紹了IE瀏覽器不支持getElementsByClassName的解決方法,本文的方法比較完美的解決了這個(gè)問(wèn)題,需要的朋友可以參考下2014-08-08

