{"remainingRequest":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/babel-loader/lib/index.js!/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js??ref--0-0!/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/hevue-img-preview/hevue-img-preview.vue?vue&type=script&lang=js","dependencies":[{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/hevue-img-preview/hevue-img-preview.vue","mtime":1708395147479},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/babel.config.js","mtime":1708395041663},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js","mtime":1708395146433},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/babel-loader/lib/index.js","mtime":1708395147257},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js","mtime":1708395146433},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js","mtime":1708395147382}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "core-js/modules/es.number.constructor.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

export default {
  name: 'hevue-img-preview',
  data: function data() {
    return {
      // imgWidth: 0,
      // imgHeight: 0,
      visible: false,
      // 插件显示，默认为false
      imgScale: 1,
      imgTop: 0,
      imgLeft: 0,
      imgRotate: 0,
      isFull: false,
      maxWH: 'max-width:100%;max-height:100%;',
      clientX: 0,
      clientY: 0,
      imgIndex: 0,
      canRun: true,
      imgurl: '',
      imgState: 1,
      start: [{}, {}],
      mobileScale: 0,
      // 手指离开时图片的缩放比例
      // 以下内容为用户传入配置
      // show: true, // 插件显示，默认为false
      url: '',
      // 预览图片的地址
      nowImgIndex: 0,
      multiple: false,
      imgList: [],
      // 以下为可全局配置
      controlBar: true,
      closeBtn: true,
      arrowBtn: true,
      keyboard: false,
      clickMaskCLose: false,
      // 是否点击遮罩关闭，默认false
      closeFn: null,
      // 关闭回调函数
      changeFn: null // 切换图片回调函数
    };
  },
  mounted: function mounted() {
    this.initImg();
  },
  watch: {
    url: function url() {
      this.initImg();
    },
    visible: {
      handler: function handler(newV) {
        var _this = this;
        if (newV) {
          this.$nextTick(function () {
            var _dom = document.getElementById('hevue-imgpreview-wrap');
            _dom.onmousewheel = _this.scrollFunc;
            // 火狐浏览器没有onmousewheel事件，用DOMMouseScroll代替(滚轮事件)
            document.body.addEventListener('DOMMouseScroll', _this.scrollFunc);
            // 禁止火狐浏览器下拖拽图片的默认事件
            document.ondragstart = function () {
              return false;
            };
            // 判断是否多图
            if (_this.multiple) {
              if (Array.isArray(_this.imgList) && _this.imgList.length > 0) {
                _this.imgIndex = Number(_this.nowImgIndex) || 0;
                // this.url = this.imgList[this.imgIndex]
                _this.changeUrl(_this.imgList[_this.imgIndex], _this.imgIndex);
              } else {
                // console.error("imgList 为空或格式不正确");
              }
            } else {
              _this.changeUrl(_this.url);
            }
            // 判断是否开启键盘事件
            if (_this.keyboard) {
              document.addEventListener('keydown', _this.keyHandleDebounce);
            }
          });
        }
      },
      immediate: true
    }
  },
  methods: {
    show: function show() {
      this.visible = true;
    },
    close: function close(data) {
      this.initImg();
      // this.maxWH = "max-width:100%;max-height:100%;";
      // this.isFull = false;
      // 移除火狐浏览器下的鼠标滚动事件
      document.body.removeEventListener('DOMMouseScroll', this.scrollFunc);
      //恢复火狐及Safari浏览器下的图片拖拽
      document.ondragstart = null;
      // 移除键盘事件
      if (this.keyboard) {
        document.removeEventListener('keydown', this.keyHandleDebounce);
      }
      this.visible = false;
      this.closeFn && this.closeFn(data);
    },
    initImg: function initImg() {
      this.mobileScale = 1;
      this.imgScale = 1;
      this.imgRotate = 0;
      this.imgTop = 0;
      this.imgLeft = 0;
    },
    /**
     * 切换图片
     * true 下一张
     * false 上一张
     */
    toogleImg: function toogleImg(bool, way) {
      var fromIndex = this.imgIndex;
      if (bool) {
        this.imgIndex++;
        if (this.imgIndex > this.imgList.length - 1) {
          this.imgIndex = 0;
        }
      } else {
        this.imgIndex--;
        if (this.imgIndex < 0) {
          this.imgIndex = this.imgList.length - 1;
        }
      }
      this.changeFn && this.changeFn({
        type: bool ? 'next' : 'prev',
        fromImgIndex: fromIndex,
        fromImgUrl: this.imgList[fromIndex],
        toImgIndex: this.imgIndex,
        toImgUrl: this.imgList[this.imgIndex],
        way: way
      });
      // this.url = this.imgList[this.imgIndex]
      this.changeUrl(this.imgList[this.imgIndex], this.imgIndex);
    },
    // 改变图片地址
    /**
     * @description:
     * @param {String} url 要显示的图片的url
     * @param {Number} index 当前显示当图片下标，防止用户点击切换图片过快
     * @return {*}
     */
    changeUrl: function changeUrl(url, index) {
      var _this2 = this;
      this.imgState = 1;
      var img = new Image();
      img.src = url;
      img.onload = function () {
        // 如果加载出来图片当下标不是当前显示图片当下标，则不予显示（用户点击过快当时候，会出现用户点到第三张了，此时第一张图片才加载完当情况）
        if (index != undefined && index == _this2.imgIndex) {
          _this2.imgState = 2;
          _this2.imgurl = url;
        } else if (index == undefined) {
          _this2.imgState = 2;
          _this2.imgurl = url;
        }
      };
      img.onerror = function () {
        if (index != undefined && index == _this2.imgIndex) {
          _this2.imgState = 3;
        } else if (index == undefined) {
          _this2.imgState = 3;
        }
      };
    },
    // 旋转图片
    rotateFunc: function rotateFunc(deg) {
      this.imgRotate += deg;
    },
    // 图片缩放
    scaleFunc: function scaleFunc(num, bool) {
      if (this.imgScale <= 0.2 && num < 0) return;
      if (bool) {
        this.imgScale = num;
      } else {
        this.imgScale += num;
      }
    },
    // 图片原尺寸切换
    imgToggle: function imgToggle() {
      this.initImg();
      if (this.isFull) {
        this.maxWH = 'max-width:100%;max-height:100%;';
      } else {
        this.maxWH = '';
      }
      this.isFull = !this.isFull;
    },
    // 鼠标滚轮缩放
    scrollFunc: function scrollFunc(e) {
      e = e || window.event;
      // e.returnValue = false // ie
      // 火狐下没有wheelDelta，用detail代替，由于detail值的正负和wheelDelta相反，所以取反
      e.delta = e.wheelDelta || -e.detail;
      e.preventDefault();
      if (e.delta > 0) {
        //当滑轮向上滚动时
        this.scaleFunc(0.05);
      }
      if (e.delta < 0) {
        //当滑轮向下滚动时
        this.scaleFunc(-0.05);
      }
    },
    // 鼠标按下
    addMove: function addMove(e) {
      e = e || window.event;
      this.clientX = e.clientX;
      this.clientY = e.clientY;
      this.$refs.heImg.onmousemove = this.moveFunc;
    },
    // 手指按下事件
    addMoveMobile: function addMoveMobile(e) {
      e.preventDefault();
      e = e || window.event;
      if (e.touches.length > 1) {
        this.start = e.touches;
      } else {
        this.clientX = e.touches[0].pageX;
        this.clientY = e.touches[0].pageY;
      }
      // 添加手指拖动事件
      this.$refs.heImg.ontouchmove = this.moveFuncMobile;
    },
    // 鼠标拖动
    moveFunc: function moveFunc(e) {
      e = e || window.event;
      e.preventDefault();
      var movementX = e.clientX - this.clientX;
      var movementY = e.clientY - this.clientY;
      // event.clientY;
      this.imgLeft += movementX * 2;
      this.imgTop += movementY * 2;
      this.clientX = e.clientX;
      this.clientY = e.clientY;
    },
    // 手指拖动
    moveFuncMobile: function moveFuncMobile(e) {
      e = e || window.event;
      if (e.touches.length > 1) {
        var now = e.touches;
        var scale = this.getDistance(now[0], now[1]) / this.getDistance(this.start[0], this.start[1]);
        // 判断是否手指缩放过，如果缩放过，要在上次缩放的比例基础上进行缩放
        if (this.mobileScale) {
          if (scale > 1) {
            // 放大
            this.scaleFunc(scale + this.mobileScale - 1, true);
          } else {
            // 缩小
            this.scaleFunc(scale * this.mobileScale, true);
          }
        } else {
          this.scaleFunc(scale, true);
        }
      } else {
        var touch = e.touches[0];
        e.preventDefault();
        var movementX = touch.pageX - this.clientX;
        var movementY = touch.pageY - this.clientY;
        // event.clientY;
        this.imgLeft += movementX * 2;
        this.imgTop += movementY * 2;
        this.clientX = touch.pageX;
        this.clientY = touch.pageY;
      }
    },
    // 移除拖动事件
    removeMove: function removeMove(type) {
      if (type === 'pc') {
        this.$refs.heImg.onmousemove = null;
      } else {
        this.mobileScale = this.imgScale;
        this.$refs.heImg.ontouchmove = null;
      }
    },
    keyHandleDebounce: function keyHandleDebounce(e) {
      var _this3 = this;
      if (this.canRun) {
        // 如果this.canRun为true证明当前可以执行函数
        this.keyHandle(e);
        this.canRun = false; // 执行函数后一段时间内不可再次执行
        setTimeout(function () {
          _this3.canRun = true; // 等到了我们设定的时间之后，把this.canRun改为true，可以再次执行函数
        }, 300);
      }
    },
    // 键盘事件
    keyHandle: function keyHandle(e) {
      e = window.event || e;
      var key = e.keyCode || e.which || e.charCode;
      switch (key) {
        case 27:
          // esc
          this.close({
            way: 'esc'
          });
          break;
        case 65:
          // a键-上一张
          if (this.multiple) {
            this.toogleImg(false, 'key-a');
          }
          break;
        case 68:
          // d键-下一张
          if (this.multiple) {
            this.toogleImg(true, 'key-d');
          }
          break;
        case 87:
          // w键-放大
          this.scaleFunc(0.15);
          break;
        case 83:
          // s键-缩小
          this.scaleFunc(-0.15);
          break;
        case 81:
          // q键-逆时针旋转
          this.rotateFunc(-90);
          break;
        case 69:
          // e键-顺时针旋转
          this.rotateFunc(90);
          break;
        case 82:
          // r键-复位键
          this.initImg();
          break;
        default:
          break;
      }
    },
    // 点击遮罩层
    clickMask: function clickMask() {
      if (this.clickMaskCLose) {
        this.close({
          way: 'mask'
        });
      }
    },
    //缩放 勾股定理方法-求两点之间的距离
    getDistance: function getDistance(p1, p2) {
      var x = p2.pageX - p1.pageX,
        y = p2.pageY - p1.pageY;
      return Math.sqrt(x * x + y * y);
    },
    /**
     * @description:
     * @param {String} imgsrc
     * @param {*} name
     * @return {*}
     */
    downloadIamge: function downloadIamge() {
      //下载图片地址和图片名
      var image = new Image();
      // 解决跨域 Canvas 污染问题
      image.setAttribute('crossOrigin', 'anonymous');
      image.onload = function () {
        var canvas = document.createElement('canvas');
        canvas.width = image.width;
        canvas.height = image.height;
        var context = canvas.getContext('2d');
        context.drawImage(image, 0, 0, image.width, image.height);
        var url = canvas.toDataURL('image/png'); //得到图片的base64编码数据
        var a = document.createElement('a'); // 生成一个a元素
        var event = new MouseEvent('click'); // 创建一个单击事件
        a.download = 'photo' + +new Date(); // 设置图片名称
        a.href = url; // 将生成的URL设置为a.href属性
        a.dispatchEvent(event); // 触发a的单击事件
      };

      image.onerror = function (err) {
        console.log('图片信息不正确或图片服务器禁止访问');
        console.log(err);
      };
      if (this.multiple) {
        image.src = this.imgList[this.imgIndex];
      } else {
        image.src = this.url;
      }
    }
  }
};"},{"version":3,"names":["name","data","visible","imgScale","imgTop","imgLeft","imgRotate","isFull","maxWH","clientX","clientY","imgIndex","canRun","imgurl","imgState","start","mobileScale","url","nowImgIndex","multiple","imgList","controlBar","closeBtn","arrowBtn","keyboard","clickMaskCLose","closeFn","changeFn","mounted","initImg","watch","handler","newV","_this","$nextTick","_dom","document","getElementById","onmousewheel","scrollFunc","body","addEventListener","ondragstart","Array","isArray","length","Number","changeUrl","keyHandleDebounce","immediate","methods","show","close","removeEventListener","toogleImg","bool","way","fromIndex","type","fromImgIndex","fromImgUrl","toImgIndex","toImgUrl","index","_this2","img","Image","src","onload","undefined","onerror","rotateFunc","deg","scaleFunc","num","imgToggle","e","window","event","delta","wheelDelta","detail","preventDefault","addMove","$refs","heImg","onmousemove","moveFunc","addMoveMobile","touches","pageX","pageY","ontouchmove","moveFuncMobile","movementX","movementY","now","scale","getDistance","touch","removeMove","_this3","keyHandle","setTimeout","key","keyCode","which","charCode","clickMask","p1","p2","x","y","Math","sqrt","downloadIamge","image","setAttribute","canvas","createElement","width","height","context","getContext","drawImage","toDataURL","a","MouseEvent","download","Date","href","dispatchEvent","err","console","log"],"sources":["node_modules/hevue-img-preview/hevue-img-preview.vue"],"sourcesContent":["\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n"],"mappings":"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"}]}