uniapp APP端 DOM生成图片保存到相册

<template>

<view class="container" style="padding-bottom: 30rpx;">

<view class="hdbg pr w100 " style="height: 150rpx;">

<top-bar content='分享' @Back="Back"></top-bar>

</view>

<view id="capture" class="page-body">

<view class="fx">

<image :src="list.image_base" mode="" crossorigin="anonymous"></image>

</view>

<view class="cred-arr">

<view class="cred">

<view class="erweim">

<image :src="list.qrcode" mode=""></image>

</view>

<!-- <view class="fs28 smwb smt">扫码下载APP</view> -->

</view>

</view>

</view>

<view class="page-foot flex justify-center pt30">

<view class="butten_left mr30" @click="generateImage">分享海报</view>

<view class="butten_right" @click="onshare">分享链接</view>

</view>

<canvas canvas-id="shareCanvas"

style="width: 750rpx; height: 1334rpx; position: fixed; left: -9999rpx;"></canvas>

</view>

</template>

<script>

import html2canvas from 'html2canvas';

export default {

data() {

return {

list: {},

canvasWidth: 355,

canvasHeight: 600

}

},

onLoad() {

this.getlist()

},

methods: {

Back() {

uni.navigateBack()

},

getlist() {

this.https('xxxxxxx', 'Post').then((res) => {

console.log(res)

this.list = res

})

},

onshare() {

uni.setClipboardData({

data: this.list.url,

success: function() {

uni.showToast({

title: '复制链接成功',

icon: 'none',

duration: 2000

});

},

fail: function() {

console.log('复制失败');

}

});

},

async generateImage() {

// #ifdef APP

const ctx = uni.createCanvasContext('shareCanvas', this);

// 绘制背景

ctx.save();

ctx.drawImage(this.list.image_base, 0, 0, this.canvasWidth, this.canvasHeight);

ctx.restore();

// 绘制二维码

ctx.save();

const qrCodeSize = 160;

const qrCodeX = (this.canvasWidth - qrCodeSize) / 2;

const qrCodeY = this.canvasHeight - 240;

ctx.drawImage(this.list.qrcode, qrCodeX, qrCodeY, qrCodeSize, qrCodeSize);

ctx.restore();

// 绘制完成

ctx.draw(false, () => {

// 将canvas转换为图片

uni.canvasToTempFilePath({

canvasId: 'shareCanvas',

success: (res) => {

// 保存图片到相册

uni.saveImageToPhotosAlbum({

filePath: res.tempFilePath,

success: () => {

uni.showToast({

title: '保存成功',

icon: 'success'

});

},

fail: () => {

uni.showToast({

title: '保存失败',

icon: 'none'

});

}

});

},

fail: (err) => {

console.log('生成图片失败', err);

uni.showToast({

title: '生成图片失败',

icon: 'none'

});

}

}, this);

});

// #endif

// #ifndef APP

const element = document.getElementById('capture')

console.log(element)

html2canvas(element).then((canvas) => {

console.log(canvas)

const imagedata = canvas.toDataURL('image/png')

const link = document.createElement('a');

link.href = imagedata;

link.download = 'filename.png'; // 设置下载文件名

link.click(); // 触发下载

uni.showToast({

title: '下载海报成功',

icon: 'none',

duration: 2000

});

})

// #endif

}

}

}

</script>

<style>

.container {

width: 100%;

min-height: 100vh;

background-color: #f5f5f5;

}

.page-body {

width: 100%;

padding: 30rpx;

box-sizing: border-box;

position: relative;

}

.fx {

width: 100%;

margin-bottom: 30rpx;

}

.fx image {

width: 100%;

height: 1226rpx;

}

.cred-arr {

width: calc(100% - 60rpx);

display: flex;

justify-content: center;

position: absolute;

bottom: 260rpx;

}

.cred {

text-align: center;

}

.erweim {

width: 300rpx;

height: 300rpx;

margin: 0 auto;

}

.erweim image {

width: 100%;

height: 100%;

}

.page-foot {

width: 100%;

height: 158rpx;

background-color: #fff;

box-shadow: 0rpx 2rpx 14rpx 6rpx rgba(0,0,0,0.08);

margin-top: 30rpx;

}

.butten_left,

.butten_right {

width: 300rpx;

height: 80rpx;

line-height: 80rpx;

text-align: center;

border-radius: 40rpx;

font-size: 28rpx;

}

.butten_left {

background-color: #ff6b6b;

color: #fff;

}

.butten_right {

background-color: #4CAF50;

color: #fff;

}

</style>

相关推荐
monika_yu7 分钟前
uniapp 开发ios, xcode 提交app store connect 和 testflight内测
uni-app
大阳光男孩2 小时前
Vue3 + UniApp 蓝牙连接与数据发送(稳定版)
uni-app
八月林城17 小时前
echarts在uniapp中使用安卓真机运行时无法显示的问题
android·uni-app·echarts
哈贝#17 小时前
vue和uniapp聊天页面右侧滚动条自动到底部
javascript·vue.js·uni-app
iOS阿玮19 小时前
苹果2024透明报告看似更加严格的背后是利好!
uni-app·app·apple
邹荣乐1 天前
微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合
前端·微信小程序·uni-app
不吃糖葫芦31 天前
App使用webview套壳引入h5(三)——解决打包为app后在安卓机可物理返回但是在苹果手机无法测滑返回的问题
uni-app·webview
半兽先生1 天前
uniapp微信小程序视频实时流+pc端预览方案
微信小程序·uni-app·音视频
胡斌附体1 天前
uniapp路由跳转toolbar页面
小程序·uni-app·switch·路由·type·uview-ui
阿諪諪2 天前
在VSCode中开发一个uni-app项目
ide·vscode·uni-app