微信小程序图片保存相册

保存图片前需要授权,因此我们先授权

wx.getSetting({
    success(res) {
        if (!res.authSetting['scope.writePhotosAlbum']) {
            wx.authorize({
                scope: 'scope.writePhotosAlbum',
                success() {
                    console.log('授权成功')
                }
            })
        }
    }
})

第一种方法,网络图片保存:

var imgSrc = "http://yijiao.oss-cn-qingdao.aliyuncs.com/images/http://tmp/wx1b4e5e756cd48af1.o6zAJsws4grEQvYrWTjBigy-6QaU.0llhudiKSF2V955a1c48350d9328ef064b4d36d12746.jpg"
wx.downloadFile({
    url: imgSrc,
    success: function (res) {
        console.log(res);
        //图片保存到本地
        wx.saveImageToPhotosAlbum({
            filePath: res.tempFilePath,
            success: function (data) {
                wx.showToast({
                    title: '保存成功',
                    icon: 'success',
                    duration: 2000
                })
            },
            fail: function (err) {
                console.log(err);
                if (err.errMsg === "saveImageToPhotosAlbum:fail auth deny") {
                    console.log("当初用户拒绝,再次发起授权")
                    wx.openSetting({
                        success(settingdata) {
                            console.log(settingdata)
                            if (settingdata.authSetting['scope.writePhotosAlbum']) {
                                console.log('获取权限成功,给出再次点击图片保存到相册的提示。')
                            } else {
                                console.log('获取权限失败,给出不给权限就无法正常使用的提示')
                            }
                        }
                    })
                }
            },
            complete(res) {
                console.log(res);
            }
        })
    }
})

第二种方法:选择相册图片存入本地

wx.chooseImage({
    count: 1,// 默认9
    sizeType: ['original', 'compressed'],// 可以指定是原图还是压缩图,默认二者都有
    sourceType: ['album', 'camera'],// 可以指定来源是相册还是相机,默认二者都有
    success: function (res) {
        // 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
        console.log("choose image")
        console.log(res)
        var tempFilePath = res.tempFilePaths[0]
        wx.getImageInfo({
            src: tempFilePath,
            success: function (res) {
                console.log("get image info")
                console.log(res)
                wx.saveImageToPhotosAlbum({
                    filePath: res.path,
                    success(res) {
                        console.log("保存图片成功")
                        console.log(res)
                        wx.showToast({
                            title: '保存成功',
                            icon: 'success',
                            duration: 2000
                        })
                    },
                    fail(err) {
                        console.log('失败')
                        console.log(err)

                        if (err.errMsg == "saveImageToPhotosAlbum:fail cancel") {
                            wx.openSetting({
                                success(settingdata) {
                                    console.log(settingdata)
                                    if (settingdata.authSetting["scope.writePhotosAlbum"]) {
                                        console.log('获取权限成功,给出再次点击图片保存到相册的提示。')
                                    } else {
                                        console.log('获取权限失败,给出不给权限就无法正常使用的提示')
                                    }
                                }
                            })
                        }
                    }
                })
            }
        })
    }
})

有帮助到大家的关注我

会一直更新小程序常用技术及新玩法。

 

喜欢上方小程序,需要源码的,添加博主微信私信小编.

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

前端_李嘉豪

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

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

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

打赏作者

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

抵扣说明:

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

余额充值