image.js 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. /**
  2. * APP端图片压缩
  3. * 参数说明:
  4. * img 图片url
  5. * scale缩放比例 1-100
  6. * callback 回调设置返回值
  7. */
  8. export function translateapp(img, scale, callback) {
  9. plus.io.resolveLocalFileSystemURL(img, (entry) => { //通过URL参数获取目录对象或文件对象
  10. entry.file((file) => { // 可通过entry对象操作图片
  11. console.log('压缩前图片信息:' + JSON.stringify(file)); //压缩前图片信息
  12. if (file.size > 504800) { // 如果大于500Kb进行压缩
  13. plus.zip.compressImage({ // 5+ plus.zip.compressImage 了解一下,有详细的示例
  14. src: img, //src: 压缩原始图片的路径
  15. dst: img.replace('.png', 'yasuo.png').replace('.PNG',
  16. 'yasuo.PNG').replace('.jpg', 'yasuo.jpg')
  17. .replace('.JPG', 'yasuo.JPG'),
  18. width: '40%', //dst: (String 类型 )压缩转换目标图片的路径,这里先在后面原始名后面加一个yasuo区分一下
  19. height: '40%', //width,height: (String 类型 )缩放图片的宽度,高度
  20. quality: scale, //quality: (Number 类型 )压缩图片的质量
  21. overwrite: true, //overwrite: (Boolean 类型 )覆盖生成新文件
  22. // format:'jpg' //format: (String 类型 )压缩转换后的图片格式
  23. }, (event) => {
  24. console.log('压缩后图片信息:' + JSON.stringify(event));
  25. //返回压缩后的图片路径
  26. callback(event.target);
  27. }, function(err) {
  28. console.log('Resolve file URL failed: ' + err.message);
  29. });
  30. } else { //else小于500kb跳过压缩,直接返回现有的src
  31. callback(img);
  32. }
  33. });
  34. }, (e) => { // 返回错误信息
  35. console.log('Resolve file URL failed: ' + e.message);
  36. });
  37. }
  38. /**
  39. * H5端图片压缩
  40. * 参数说明:
  41. * imgSrc 图片url
  42. * scale缩放比例 0-1
  43. * type 返回图片类型 默认blob
  44. * callback 回调设置返回值
  45. */
  46. export function translate(imgSrc, scale, type, callback) {
  47. var img = new Image();
  48. img.src = imgSrc;
  49. img.onload = function() {
  50. var that = this;
  51. let yasuobi = 700 / that.width
  52. let h = that.height * yasuobi;
  53. let w = that.width * yasuobi;
  54. console.log("宽高", w, h, yasuobi);
  55. var canvas = document.createElement('canvas');
  56. var ctx = canvas.getContext('2d');
  57. var width = document.createAttribute("width");
  58. width.nodeValue = w;
  59. var height = document.createAttribute("height");
  60. height.nodeValue = h;
  61. canvas.setAttributeNode(width);
  62. canvas.setAttributeNode(height);
  63. ctx.drawImage(that, 0, 0, w, h);
  64. var base64 = canvas.toDataURL('image/jpeg', scale); //压缩比例
  65. canvas = null;
  66. if (type == 'base64') {
  67. var blob = base64ToBlob(base64);
  68. var blobUrl = window.URL.createObjectURL(blob); //blob地址
  69. callback(base64, blobUrl);
  70. } else {
  71. var blob = base64ToBlob(base64);
  72. var blobUrl = window.URL.createObjectURL(blob); //blob地址
  73. callback(base64, blobUrl);
  74. }
  75. }
  76. }
  77. export function translateAll(imgSrc, callback) {
  78. translate1(imgSrc, 0.6, 'blob', callback)
  79. }
  80. export function translate1(imgSrc, scale, type, callback) {
  81. var img = new Image();
  82. img.src = imgSrc;
  83. img.onload = function() {
  84. var that = this;
  85. let yasuobi = 700 / that.width
  86. let h = that.height * yasuobi;
  87. let w = that.width * yasuobi;
  88. console.log("宽高", w, h, yasuobi);
  89. var canvas = document.createElement('canvas');
  90. var ctx = canvas.getContext('2d');
  91. var width = document.createAttribute("width");
  92. width.nodeValue = w;
  93. var height = document.createAttribute("height");
  94. height.nodeValue = h;
  95. canvas.setAttributeNode(width);
  96. canvas.setAttributeNode(height);
  97. ctx.drawImage(that, 0, 0, w, h);
  98. var base64 = canvas.toDataURL('image/jpeg', scale); //压缩比例
  99. canvas = null;
  100. if (type == 'base64') {
  101. var blob = base64ToBlob(base64);
  102. var blobUrl = window.URL.createObjectURL(blob); //blob地址
  103. // callback(base64, blobUrl, callback1);
  104. uni.getFileInfo({
  105. filePath: blobUrl,
  106. success: (res) => {
  107. console.log(res);
  108. let size = res.size
  109. let scale = 1
  110. if (size / 1024 / 1024 > 0.12) {
  111. scale = 0.6
  112. translate1(blobUrl, scale, 'blob', callback)
  113. } else {
  114. callback(base64, blobUrl)
  115. }
  116. },
  117. fail: (err) => {
  118. console.log("err:", err);
  119. }
  120. })
  121. } else {
  122. var blob = base64ToBlob(base64);
  123. var blobUrl = window.URL.createObjectURL(blob); //blob地址
  124. // callback(base64, blobUrl, callback1);
  125. uni.getFileInfo({
  126. filePath: blobUrl,
  127. success: (res) => {
  128. console.log(res);
  129. let size = res.size
  130. let scale = 1
  131. if (size / 1024 / 1024 > 0.12) {
  132. scale = 0.6
  133. translate1(blobUrl, scale, 'blob', callback)
  134. } else {
  135. callback(base64, blobUrl)
  136. }
  137. },
  138. fail: (err) => {
  139. console.log("err:", err);
  140. }
  141. })
  142. }
  143. }
  144. }
  145. // base转Blob
  146. export function base64ToBlob(base64) {
  147. var arr = base64.split(','),
  148. mime = arr[0].match(/:(.*?);/)[1],
  149. bstr = atob(arr[1]),
  150. n = bstr.length,
  151. u8arr = new Uint8Array(n);
  152. while (n--) {
  153. u8arr[n] = bstr.charCodeAt(n);
  154. }
  155. return new Blob([u8arr], {
  156. type: mime
  157. });
  158. }
  159. // base转url
  160. export function base64ToUrl(base64) {
  161. var arr = base64.split(',')
  162. let blob = {}
  163. if (arr.length < 2) {
  164. const arrayBuffer = uni.base64ToArrayBuffer(base64);
  165. // 创建Blob对象
  166. blob = new Blob([arrayBuffer], {
  167. type: 'image/jpg'
  168. });
  169. } else {
  170. var mime = arr[0].match(/:(.*?);/)[1]
  171. var bstr = atob(arr[1])
  172. var n = bstr.length
  173. var u8arr = new Uint8Array(n);
  174. while (n--) {
  175. u8arr[n] = bstr.charCodeAt(n);
  176. }
  177. blob = new Blob([u8arr], {
  178. type: mime
  179. });
  180. }
  181. return URL.createObjectURL(blob);
  182. }
  183. // blob 转 base64
  184. export function blobToDataURI(blob, callback) {
  185. var reader = new FileReader();
  186. reader.readAsDataURL(blob);
  187. reader.onload = function(e) {
  188. callback(e.target.result);
  189. };
  190. }
  191. // base64转File
  192. export function base64toFilen(dataurl, filename = 'file') {
  193. let arr = dataurl.split(',')
  194. let mime = arr[0].match(/:(.*?);/)[1]
  195. let suffix = mime.split('/')[1]
  196. let bstr = atob(arr[1])
  197. let n = bstr.length
  198. let u8arr = new Uint8Array(n)
  199. while (n--) {
  200. u8arr[n] = bstr.charCodeAt(n)
  201. }
  202. return new File([u8arr], `${filename}.${suffix}`, {
  203. type: mime
  204. })
  205. }
  206. // File转blob
  207. export function fileToBlob(file, callback) {
  208. var reader = new FileReader();
  209. // 当文件读取完毕后,reader.result就会包含文件的内容
  210. reader.onload = function(event) {
  211. // 在这里,event.target.result就是文件的blob形式
  212. var blob = new Blob([event.target.result], {
  213. type: file.type
  214. });
  215. // 接下来,你可以使用这个blob对象了,例如用它来创建一个URL
  216. var blobURL = URL.createObjectURL(blob);
  217. callback(blobURL)
  218. };
  219. // 以数据URL的形式读取文件
  220. reader.readAsArrayBuffer(file);
  221. }