uniapp APP端 当前页面保存为图片 保存到本地

直接上代码

一、

npm install html2canvas -D

二、

<template>
    <view>
        <view style="width: 90%;margin-left: 25px;">
            <view class="page"  id="contractimage">
                <u-form :model="form" ref="uForm">
                    <!-- -->
                </u-form>
            </view>
            <view class="bottom-btn" style="margin-bottom: 20px;">
                <u-row style="align-content: center;text-align: center">
                    <u-col span="6">
                        <view @click="html2canvas.emitData">下载</view>
                    </u-col>
                </u-row>
            </view>
        </view>
    </view>
</template>

<script>
    export default {
        components: {

        },
        data() {
            return {
                form: {

                },

            }

        },
        created() {
        },
        methods: {
            showLoading() {
                uni.showLoading({
                    title: '加载中……',
                    mask: true
                })
            },
            hideLoading() {
                uni.hideLoading()
            },
            renderFinish(opt) {
                // console.log(opt.path)
                console.log(opt.el)
                this.img = opt.path
                // 获取到图片地址(base64)
                // DoSomeThing ……
                this.saveBase64Img(opt.path)
            },
            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();
                    }
                );
            }
        }
    }
</script>

<script module="html2canvas" lang="renderjs">
    import html2canvas from 'html2canvas';
    export default {
        methods: {
            emitData() {
                // 根据自己需要截图区域
                this.create('contractimage');
            },
            async create(id) {
                try {
                    this.$ownerInstance.callMethod('showLoading', true);
                    const timeout = setTimeout(async () => {
                        const domId = document.getElementById(id);
                        const canvas = await html2canvas(domId, {
                            width: domId.offsetWidth, //设置canvas尺寸与所截图尺寸相同,防止白边
                            height: domId.offsetHeight, //防止白边
                            logging: true,
                            useCORS: true
                        });
                        const base64 = canvas.toDataURL('image/jpeg', 1);
                        this.$ownerInstance.callMethod('renderFinish', {
                            path: base64,
                            el: id
                        });
                            clearTimeout(timeout);
                        }, 500);
                } catch (error) {
                    console.log(error)
                }
            }
        }
    }
</script>

<style>

</style>


 

### 如何在 UniApp 中实现将图片保存本地相册的功能 在 UniApp 开发中,可以通过调用 `uni.saveImageToPhotosAlbum` API 来实现将图片保存到用户的手机相册中的功能[^1]。此 API 支持多种平台,包括 Android、iOS 和微信小程序等。 #### 1. 调用 saveImageToPhotosAlbum 方法 该方法用于将指定路径下的图片保存至系统的相册中。以下是其基本参数说明: - **filePath**: 需要保存图片文件路径 (String 类型),支持临时路径和永久路径。 下面是一个简单的代码示例来演示如何使用这个 API: ```javascript // 假设已知图片的 filePath const filePath = '/path/to/your/image.jpg'; uni.saveImageToPhotosAlbum({ filePath: filePath, success(res) { console.log('保存图片', res); uni.showToast({ title: '图片保存' }); }, fail(err) { console.error('保存失败:', err); // 如果是因为未授权导致失败,则引导用户打开设置页面重新授予权限 if (err.errMsg.includes('auth deny')) { uni.showModal({ content: '需要您授予保存图片到相册的权限', confirmText: '设置', success(modalRes) { if (modalRes.confirm) { uni.openSetting(); // 打开应用设置界面 } } }); } else { uni.showToast({ icon: 'none', title: '保存失败,请重试' }); } } }); ``` 上述代码展示了如何处理保存操作的功与失败情况,特别注意到了因权限不足而导致的操作失败情形[^2]。 #### 2. 请求管理权限 为了能够正常执行保存动作,在某些平台上可能还需要额外请求用户的存储或相机权限。这通常通过 `uni.authorize` 或者直接尝试触发保存时由系统弹窗询问完。如果之前被拒绝过权限,则可以利用 `uni.getSetting` 查看当前状态以及指引用户前往开启相应选项[^3]。 对于微信环境而言,除了基础的读写外部储存许可外,还需确保服务器地址已被加入业务域名白名单之中,否则即使拥有足够的权限也可能无法顺利完下载任务[^4]。 #### 3. 处理不同上的差异性 由于目标运行环境的不同(如 H5 vs Native App ),实际开发过程中可能会遇到一些细微差别。比如安卓机种有时会要求先加载再另存新图;而对于 iOS 设备来说则更倾向于直接提供最终版本给它自行决定后续流程等等。因此建议开发者依据官方文档针对各个场景分别测试验证最佳实践方案。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值