uniapp实现图片压缩:


1.思路:
发现uniapp自带图片压缩功能 ,但是并不通用,会出现下面的错误

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.案例:
/**
* H5端图片压缩
*  参数说明:
*  imgSrc 图片url
*  scale缩放比例 0-1
*  返回base64
*  callback 回调设置返回值 
*/
translate(imgSrc, scale, callback) {
	var img = new Image();
	img.src = imgSrc;
	img.onload = function() {
		var that = this;
		var h = that.height; // 默认按比例压缩
		var w = that.width;
		var canvas = document.createElement('canvas');
		var ctx = canvas.getContext('2d');
		var width = document.createAttribute("width");
		width.nodeValue = w;
		var height = document.createAttribute("height");
		height.nodeValue = h;
		canvas.setAttributeNode(width);
		canvas.setAttributeNode(height);
		ctx.drawImage(that, 0, 0, w, h);
		var base64 = canvas.toDataURL('image/jpeg', scale); //压缩比例
		canvas = null;
		callback(base64);
	}
},
//选择图片、视频
//选择图片、视频
selectFileFun(e) {
	const that = this
	console.log('压缩前', e.tempFiles[0].size)
	e.tempFilePaths.forEach(item => {
		that.imageList.push({
			name: 'imageList',
			uri: imgUrl
		})
	})
},
//上传
uploadFile(){
	const that = this
	if (this.imageList.length > 0) {
		this.imageList.forEach(item => {
			that.translate(item.uri, 0.5, imgURL => {
				//查看压缩后的大小
				uni.getFileInfo({
					filePath: imgUrl,
					success: imgInfo => {
						console.log('压缩后', imgInfo.size);
					}
				})
				item.uri = imgURL
			})
		})
	}
	...
}
3.效果:

在这里插入图片描述

  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sun Peng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值