hammer.js 图片拖动

hammer.js是js手势库,他可以完美的实现在移端开发的大多数事件,如:点击、滑动、拖动、多点触控等事件。使用:

<div id="test" class="test"></div>
      <script type="text/javascript">
          //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
          var hammercommend = new Hammer(document.getElementById("test"));
          //为该dom元素指定触屏移动事件
          hammercommend ("pan", function (ev) {
              //控制台输出
              console.log(ev);
          });
 </script>


1、  Pan事件:在指定的dom区域内,一个手指放下并移动事件,即触屏中的拖动事件。这个事件在屏触开发中比较常用,如:左拖动、右拖动等,如手要上使用QQ时向右滑动出现功能菜单的效果。该事件还可以分别对以下事件进行监听并处理:


Panstart:拖动开始、Panmove:拖动过程、Panend:拖动结束、Pancancel:拖动取消、Panleft:向左拖动、Panright:向右拖动、Panup:向上拖动、Pandown:向下拖动


2、  Pinch事件:在指定的dom区域内,两个手指(默认为两个手指,多指触控需要单独设置)或多个手指相对(越来越近)移动或相向(越来越远)移动时事件。该事件事以分别对以下事件进行监听并处理:


Pinchstart:多点触控开始、Pinchmove:多点触控过程、Pinchend:多点触控结束、Pinchcancel:多点触控取消、Pinchin:多点触控时两手指距离越来越近、Pinchout:多点触控时两手指距离越来越远


3、  Press事件:在指定的dom区域内触屏版本的点击事件,这个事件相当于PC端的Click事件,该不能包含任何的移动,最小按压时间为500毫秒,常用于我们在手机上用的“复制、粘贴”等功能。该事件分别对以下事件进行监听并处理:


Pressup:点击事件离开时触发


4、  Rotate事件:在指定的dom区域内,当两个手指或更多手指成圆型旋转时触发(就像两个手指拧螺丝一样)。该事件分别对以下事件进行监听并处理:


Rotatestart:旋转开始、Rotatemove:旋转过程、Rotateend:旋转结束、Rotatecancel:旋转取消


5、  Swipe事件:在指定的dom区域内,一个手指快速的在触屏上滑动。即我们平时用到最多的滑动事件。


Swipeleft:向左滑动、Swiperight:向右滑动、Swipeup:向上滑动、Swipedown:向下滑动


6、Tap事件:在指定的dom区域内,一个手指轻拍或点击时触发该事件(类似PC端的click)。该事件最大点击时间为250毫秒,如果超过250毫秒则按Press事件进行处理。


图片拖动

<div class="index-recommended bg-white w96 m5 p5">
    <div class="recommended">
      <ul id="recommended_list">
        <!--{foreach from=$news item=xw}-->
        <li class="rec"><a href="{$xw.link}">{$xw.img}</a></li>
        <!--{/foreach}-->
        <li class="rec_more">more</li>
      </ul>
    </div>
    <div class="clearfix"> </div>
  </div>


.index-recommended{padding-left: 1%; height: auto;}
.index-recommended .recommended{width: 100%; height: auto; overflow: hidden; position: relative; }
.index-recommended .recommended .rec_more{width: 30px; }
.index-recommended .recommended li{width: 31%; float: left; margin:10px 5px; position: relative;}
.index-recommended .recommended li a{display: block;}
.index-recommended .recommended li img{width: 100%; height: auto;}



 <script type="text/javascript">
         var recommended_width = $("#recommended_list:parent").width(); //总长度
         var recommended_count = $("#recommended_list>li").length; //个数
         //计算显示的li的长度。显示2.5个; 中间相隔5px
         var recommended_li_width = parseFloat(recommended_width/2.5 - 10);
        //计算ul总长度
       var recommended_width_new = parseFloat((recommended_li_width) * recommended_count + 30); //30最后面有更多按钮
      $("#recommended_list .rec").css({width: recommended_li_width+"px"});
      $("#recommended_list").css({width: recommended_width_new+"px"});


    var hammerrecommended = new Hammer(document.getElementById("recommended_list"));
    var trx_length = 0;
    var scrool_length = -(recommended_width_new - recommended_width -30);//滚动的区间
    hammerrecommended.on("pan", function (e) {
                //e.deltaX; 移动距离 left :-, right: +
                trx_length = trx_length + e.deltaX*0.2; //0.2 减慢速度
                if(trx_length < 10 && trx_length > scrool_length)
                {
                    transform = "translate3d(" +  trx_length + "px, 0, 0)";  
                    document.getElementById("recommended_list").style.transform = transform;
                    document.getElementById("recommended_list").style.oTransform = transform;
                    document.getElementById("recommended_list").style.msTransform = transform;
                    document.getElementById("recommended_list").style.mozTransform = transform;
                    document.getElementById("recommended_list").style.webkitTransform = transform;
                }
             });
 </script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hammer.js是一个用于处理触摸手势的JavaScript库,它提供了丰富的手势事件和手势识别功能。而pdf.js是Mozilla开发的一个用于在Web上显示PDF文件的JavaScript库。 要在使用Hammer.js实现手势缩放pdf.js的功能,你可以按照以下步骤进行操作: 1. 引入Hammer.js和pdf.js的库文件到你的HTML页面中。 2. 创建一个用于显示PDF文件的容器元素,例如一个div元素。 3. 使用pdf.js加载并显示PDF文件到容器元素中。 4. 初始化Hammer.js,并将其绑定到PDF容器元素上。 5. 监听Hammer.js的手势事件,例如pinch(缩放)事件。 6. 在手势事件的回调函数中,根据手势的缩放比例来调整PDF的显示大小。 下面是一个简单的示例代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Hammer.js手势缩放PDF.js</title> <script src="path/to/hammer.js"></script> <script src="path/to/pdf.js"></script> </head> <body> <div id="pdfContainer"></div> <script> // 加载并显示PDF文件 pdfjsLib.getDocument('path/to/pdf_file.pdf').promise.then(function(pdf) { pdf.getPage(1).then(function(page) { var canvas = document.createElement('canvas'); var context = canvas.getContext('2d'); var viewport = page.getViewport({ scale: 1 }); canvas.width = viewport.width; canvas.height = viewport.height; page.render({ canvasContext: context, viewport: viewport }); document.getElementById('pdfContainer').appendChild(canvas); }); }); // 初始化Hammer.js并绑定到PDF容器元素 var pdfContainer = document.getElementById('pdfContainer'); var hammer = new Hammer(pdfContainer); // 监听pinch(缩放)事件 hammer.on('pinch', function(event) { var scale = event.scale; // 获取缩放比例 // 根据缩放比例调整PDF的显示大小 var canvas = document.querySelector('#pdfContainer canvas'); var context = canvas.getContext('2d'); var viewport = page.getViewport({ scale: scale }); canvas.width = viewport.width; canvas.height = viewport.height; page.render({ canvasContext: context, viewport: viewport }); }); </script> </body> </html> ``` 希望以上代码能帮助到你实现Hammer.js手势缩放pdf.js的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值