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>

相关推荐
百思可瑞教育5 小时前
uni-app 根据用户不同身份显示不同的tabBar
vue.js·uni-app·北京百思可瑞教育·北京百思教育
Q_Q196328847512 小时前
python+springboot+uniapp微信小程序题库系统 在线答题 题目分类 错题本管理 学习记录查询系统
spring boot·python·django·uni-app·node.js·php
百思可瑞教育13 小时前
使用UniApp实现一个AI对话页面
javascript·vue.js·人工智能·uni-app·xcode·北京百思可瑞教育·百思可瑞教育
不想吃饭e14 小时前
在uniapp/vue项目中全局挂载component
前端·vue.js·uni-app
00后程序员张15 小时前
iOS App 混淆与资源保护:iOS配置文件加密、ipa文件安全、代码与多媒体资源防护全流程指南
android·安全·ios·小程序·uni-app·cocoa·iphone
不知名的前端专家19 小时前
uniapp原生插件 TCP Socket 使用文档
网络·tcp/ip·uni-app·netty
fakaifa20 小时前
【独立版】智创云享知识付费小程序 v5.0.23+小程序 搭建教程
小程序·uni-app·知识付费·源码下载·智创云享独立版
2501_9160074721 小时前
Transporter App 使用全流程详解:iOS 应用 ipa 上传工具、 uni-app 应用发布指南
android·ios·小程序·https·uni-app·iphone·webview
fakaifa1 天前
CRMEB多门店 v3.3源码 无授权限制+PC端+uniapp前端
小程序·uni-app·商城小程序·技术教程·源码下载·crmeb多门店
编程迪1 天前
小说阅读系统Java源码 小说阅读软件开发 小说app小程序
小程序·uni-app·小说源码·小说系统·小说阅读app