美文网首页
在vue中使用alloyfinger,实现元素的拖拽,缩放,双击

在vue中使用alloyfinger,实现元素的拖拽,缩放,双击

作者: 他爱在黑暗中漫游 | 来源:发表于2021-09-08 18:57 被阅读0次

    在vue项目中实现拖拽,缩放,双击,长按等功能
    使用的是腾讯开发的AlloyFinger插件

    • 1.下载
    npm install alloyfinger
    // or
    yarn add alloyfinger
    
    • 2.组件中使用
    <template>
      <div class="box">
        <img
          src="https://ns-strategy.cdn.bcebos.com/ns-strategy/upload/fc_big_pic/part-00011-2072.jpg"
          ref="pic"
          :style="{'transform': 'translate('+ posX + 'px,' + posY + 'px) translateZ(0px) scale(' + dis + ')  rotate(' + angle + 'deg)'}"
        />
      </div>
    </template>
    
    <script>
    import AlloyFinger from 'alloyfinger';
    export default {
      data() {
        return {
          posX: 0,
          posY: 0,
          dis: 1,
          angle: 0,}  
      },
      mounted() {
        this.getData();
      },
      methods: {
        getData() {
          let that = this;
          let pic= this.$refs.pic;
            this.af = new AlloyFinger(pic, {
            rotate: function (evt) {
              console.log("实现旋转");
              that.angle += evt.angle;
            },
            pinch: function (evt) {
              console.log("实现缩放");
              that.dis = evt.zoom;
            },
            pressMove: function (evt) {
              console.log("实现移动");
              that.posX += evt.deltaX;
              that.posY += evt.deltaY;
            },
            tap: function (evt) {
              console.log("单击");
              //点按触发
            },
            doubleTap: function (e) {
              console.log("双击");
              //双击屏幕触发
            },
            longTap: function (e) {
              console.log("长按");
              //长按屏幕750ms触发
            },
            swipe: function (e) {
              //e.direction代表滑动的方向
              console.log("swipe" + e.direction);
            },
          });
        }
      }
    }
    </script>
    

    相关文章

      网友评论

          本文标题:在vue中使用alloyfinger,实现元素的拖拽,缩放,双击

          本文链接:https://www.haomeiwen.com/subject/kcavwltx.html