uniapp保存图片到本地(APP和微信小程序端)

uniapp实现app端和微信小程序端图片保存到本地,其它平台未测过,原理类似。

微信小程序端主要是权限需要使用button的开放能力来反复调起,代码如下:

首先是条件编译两个平台的按钮组件:

        <!-- #ifndef MP-WEIXIN -->
        <view class="purple_btn btn_box" @click="saveImgToLocal">
            保存到相册
        </view>
        <!-- #endif -->
        
        <!-- #ifdef MP-WEIXIN -->
        <view v-if="openSettingBtnHidden" class="purple_btn btn_box" @click="saveEwm">
            保存到相册
        </view>
        
        <button v-else class="purple_btn btn_box" hover-class="none" open-type="openSetting" @opensetting='handleSetting'>保存到相册</button>
        <!-- #endif -->

js部分如下(base64格式的图片请看最文章末尾):

var _self;
export default{
    data(){
        return {
            openSettingBtnHidden: true,//是否授权
            ewmImg:""//这是要保存的图片
        }
    },
    onLoad(opt) {
        _self = this;
    },
    components:{
    },
    methods:{
        //微信小程序保存到相册
        handleSetting(e){
            if (!e.detail.authSetting['scope.writePhotosAlbum']) {
                  _self.openSettingBtnHidden = false;
            } else {
                 _self.openSettingBtnHidden = true;
            }
        },
        saveEwm:function(e){
            //获取相册授权
               uni.getSetting({
                 success(res) {
                   if (!res.authSetting['scope.writePhotosAlbum']) {
                     uni.authorize({
                       scope: 'scope.writePhotosAlbum',
                       success() {
                         //这里是用户同意授权后的回调
                         _self.saveImgToLocal();
                       },
                       fail() {//这里是用户拒绝授权后的回调
                           _self.openSettingBtnHidden=false
                       }
                     })
                   } else {//用户已经授权过了
                     _self.saveImgToLocal();
                   }
                 }
               })
        },
        saveImgToLocal:function(e){
            
            uni.showModal({
                title: '提示',
                content: '确定保存到相册吗',
                success: function (res) {
                    if (res.confirm) {
                        
                        uni.downloadFile({
                                url: _self.ewmImg,//图片地址
                                success: (res) =>{
                                    if (res.statusCode === 200){
                                        uni.saveImageToPhotosAlbum({
                                            filePath: res.tempFilePath,
                                            success: function() {
                                                uni.showToast({
                                                    title: "保存成功",
                                                    icon: "none"
                                                });
                                            },
                                            fail: function() {
                                                uni.showToast({
                                                    title: "保存失败",
                                                    icon: "none"
                                                });
                                            }
                                        });
                                    } 
                                }
                            })
                        
                        
                    } else if (res.cancel) {
                        
                    }
                }
            });
            
        }
    }
}

 

app端如果图片是base64,则使用如下脚本

saveBase64Img(base64) {
    const bitmap = new plus.nativeObj.Bitmap('test');
    bitmap.loadBase64Data(
        base64,
        function() {
            const url = '_doc/' + new Date() + '.png'; // url建议用时间戳命名方式
            console.log('url:', url);
            bitmap.save(
                url,
                {
                    overwrite: true // 是否覆盖
                    // quality: 'quality'  // 图片清晰度
                },
                i => {
                    uni.saveImageToPhotosAlbum({
                        filePath: url,
                        success: function() {
                            console.log('保存成功');
                            bitmap.clear();
                        }
                    });
                },
                e => {
                    console.log('保存失败', e);
                    bitmap.clear();
                }
            );
        },
        e => {
            console.log('保存失败', e);
            bitmap.clear();
        }
    );
}
posted @ 2019-12-24 09:48  南之骄阳  阅读(22641)  评论(0编辑  收藏  举报