首页 > 其他分享 >直播电商平台开发,实现图片压缩上传(base64格式)

直播电商平台开发,实现图片压缩上传(base64格式)

时间:2022-11-04 14:11:47浏览次数:52  
标签:originWidth canvas originHeight res base64 电商 上传 图片

直播电商平台开发,实现图片压缩上传(base64格式)

1.从本地相册或者相机拍照选择图片;

 


chooseImage (){
wx.chooseImage({
  count: 1,
  //图片尺寸原图和压缩图
  sizeType: ['original', 'compressed'],
  //从相册选图和使用相机
  sourceType: ['album', 'camera'],
  success (res) {
    // tempFilePath可以作为img标签的src属性显示图片
    const tempFilePaths = res.tempFilePaths
  }
})
}

 

2.将图片转换为base64格式;

 


//img_url为选择图片得到的临时路径
imgBase64(img_url) {
        let res = wx.getFileSystemManager().readFileSync(img_url, 'base64')
        console.log("输出base64",res)
        return res
    },
 

 

3.将图片上传;

 


upLoad(){
wx.request({
  url: '你的接口', 
  data: {
   img:'',//转base64后的字符串
  },
  header: {
    'content-type': 'application/json' 
  },
  success (res) {
    console.log(res.data)
  }
})
}

 

 

但在实际开发中,用户上传的图片有可能很大,上传时间就会变长,这样就会影响用户体验,这个时候就需要我们对图片进行压缩。本文采用canvas压缩图片,步骤如下:

 

创建canvas;

取得图片临时路径;

取得图片的原始尺寸;

对图片原始尺寸进行等比例缩放;

将缩放后的图片画到canvas上;

导出canvas画出的图片资源url;

将url转为base64上传;

创建canvas,注意canvas标签中对于id的定义(刚开始尝试了2d写法,在画图片时候失败了)

 


//wxml
<canvas   style="width: {{cwidth}}px;height: {{cheight}}px;" canvas-id="mycanvas" class="canvas-compress"></canvas>
//js
data:{
cwidth:'',
cheight:'',
}
//wxss
//此处是为了保证画出的图片不出现在视野中
.canvas-compress {
position: absolute;
top: -1000px;

 

压缩画出canvas,得到临时路径:

 


 get_img(url) {
        let that = this
        console.log("选择图片返回的路径", url)
        wx.getImageInfo({
            src: url,
            success(res) {
                console.log("路径", res.path)
                console.log('获得原始图片大小', res.width, res.height)
                var originWidth, originHeight;
                originHeight = res.height;
                originWidth = res.width;
                // 最大尺寸限制   //压缩比例
                var maxWidth = originWidth >= originHeight ? 300 : 600,
                    maxHeight = originWidth >= originHeight ? 600 : 300;
                // 目标尺寸
                var targetWidth = originWidth,
                    targetHeight = originHeight;
                //等比例压缩,如果宽度大于高度,则宽度优先,否则高度优先
                if (originWidth > maxWidth || originHeight > maxHeight) {
                    if (originWidth / originHeight > maxWidth / maxHeight) {
                        // 要求宽度*(原生图片比例)=新图片尺寸
                        targetWidth = maxWidth;
                        targetHeight = Math.round(maxWidth * (originHeight / originWidth));
                    } else {
                        targetHeight = maxHeight;
                        targetWidth = Math.round(maxHeight * (originWidth / originHeight));
                    }
                }
                console.log("压缩后的图片大小", targetWidth, targetHeight)
                var ctx = wx.createCanvasContext('mycanvas');
                ctx.clearRect(0, 0, targetWidth, targetHeight);
                ctx.drawImage(res.path, 0, 0, targetWidth, targetHeight);
                ctx.draw();
                //更新canvas大小
                that.setData({
                    cwidth: targetWidth,
                    cheight: targetHeight
                });
                setTimeout(function () {
                    wx.canvasToTempFilePath({
                        canvasId: 'mycanvas',
                        success: (res) => {
                            console.log("压缩后的临时路径:", res.tempFilePath)
                        },
                        fail: (err) => {
                            console.error(err)
                        }
                    }, this)
                }, 400); //延迟400毫秒为了等canvas画上
            }
        })
    },
 

 

 以上就是直播电商平台开发,实现图片压缩上传(base64格式), 更多内容欢迎关注之后的文章

 

标签:originWidth,canvas,originHeight,res,base64,电商,上传,图片
From: https://www.cnblogs.com/yunbaomengnan/p/16857554.html

相关文章