translate-image.js 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /**
  2. * 压缩
  3. * @param {Object} imgSrc 图片url
  4. * @param {Object} callback 回调设置返回值
  5. */
  6. export function translate(imgSrc) {
  7. var img = new Image();
  8. img.src = imgSrc;
  9. img.onload = function() {
  10. var that = this;
  11. var h = that.height;
  12. // 默认按比例压缩
  13. var w = that.width;
  14. var canvas = document.createElement('canvas');
  15. var ctx = canvas.getContext('2d');
  16. var anw = document.createAttribute("width");
  17. anw.nodeValue = w;
  18. var anh = document.createAttribute("height");
  19. anh.nodeValue = h;
  20. canvas.setAttributeNode(anw);
  21. canvas.setAttributeNode(anh);
  22. ctx.drawImage(that, 0, 0, w, h);
  23. //压缩比例
  24. var quality = 0.7;
  25. var base64 = canvas.toDataURL('image/jpeg', quality);
  26. canvas = null;
  27. var blob=base64ToBlob(base64);
  28. // console.log(blob)
  29. //Blob对象转blob地址
  30. var blobUrl=window.URL.createObjectURL(blob);
  31. return blobUrl;
  32. }
  33. }
  34. /**
  35. * base转Blob对象
  36. * @param {Object} base64 base64地址
  37. */
  38. export function base64ToBlob(base64) {
  39. var arr = base64.split(','),
  40. mime = arr[0].match(/:(.*?);/)[1],
  41. bstr = atob(arr[1]),
  42. n = bstr.length,
  43. u8arr = new Uint8Array(n);
  44. while (n--) {
  45. u8arr[n] = bstr.charCodeAt(n);
  46. }
  47. return new Blob([u8arr], {
  48. type: mime
  49. });
  50. }