You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
284 lines
6.6 KiB
284 lines
6.6 KiB
<template>
|
|
<!-- 推广海报 -->
|
|
<view>
|
|
<view class="myextension">
|
|
<canvas class="mycanvas" canvas-id="mycanvas" :style="'width:' + (windowWidth-30) + 'px;height:560px'"></canvas>
|
|
<!-- #ifdef H5 -->
|
|
<block>
|
|
<image class="imgs" :style="'width:' + (windowWidth-30) + 'px;height:560px'" :src="imgUrl" mode=""></image>
|
|
</block>
|
|
<!-- #endif -->
|
|
<!-- #ifndef H5 -->
|
|
<view class="saveImg" @longtap="saveImg" :style="'background:' + colors">保存海报</view>
|
|
<!-- #endif -->
|
|
<!-- #ifdef H5 -->
|
|
<p class="tips">长按图片进行保存</p>
|
|
<!-- #endif -->
|
|
</view>
|
|
<loading v-if="isShow == true"></loading>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
var app = getApp();
|
|
import loading from "../../commponent/public/loading";
|
|
export default {
|
|
data() {
|
|
return {
|
|
isShow: true,
|
|
colors: '',
|
|
windowHeight: '',
|
|
windowWidth: '',
|
|
imgUrl: ''
|
|
};
|
|
},
|
|
|
|
components: {
|
|
loading
|
|
},
|
|
props: {},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面加载
|
|
*/
|
|
onLoad: function(options) {
|
|
this.setData({
|
|
colors: app.globalData.newColor
|
|
});
|
|
this.getSystem()
|
|
setTimeout(() => {
|
|
this.setData({
|
|
isShow: false
|
|
});
|
|
}, 600);
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面初次渲染完成
|
|
*/
|
|
onReady: function() {},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面显示
|
|
*/
|
|
onShow: function() {},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面隐藏
|
|
*/
|
|
onHide: function() {},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面卸载
|
|
*/
|
|
onUnload: function() {},
|
|
|
|
/**
|
|
* 页面相关事件处理函数--监听用户下拉动作
|
|
*/
|
|
onPullDownRefresh: function() {},
|
|
|
|
/**
|
|
* 页面上拉触底事件的处理函数
|
|
*/
|
|
onReachBottom: function() {},
|
|
|
|
/**
|
|
* 用户点击右上角分享
|
|
*/
|
|
onShareAppMessage: function() {},
|
|
methods: {
|
|
getSystem() {
|
|
let that = this;
|
|
uni.getSystemInfo({
|
|
success: function(res) {
|
|
that.setData({
|
|
windowHeight: res.windowHeight,
|
|
windowWidth: res.windowWidth
|
|
});
|
|
that.createPoster()
|
|
}
|
|
});
|
|
},
|
|
createPoster() { //生成海报
|
|
// 0.76
|
|
var ctx = uni.createCanvasContext('mycanvas', this)
|
|
ctx.fillStyle = '#FFFFFF'
|
|
ctx.fillRect(0, 0, this.windowWidth - 30, 560)
|
|
//绘制背景图片
|
|
ctx.drawImage('/static/images/user/shop.png', 0, 0, this.windowWidth - 30, 560)
|
|
ctx.save()
|
|
// 绘制圆角二维码
|
|
// let avatar_width = 60; //头像宽度
|
|
// let avatar_height = 60; //头像高度
|
|
// let avatar_x = 15; //头像的x坐标
|
|
// let avatar_y = 15; //头像的y坐标
|
|
// let radius = 8 //头像的圆角弧度
|
|
// this.setRadius(ctx, avatar_width, avatar_height, avatar_x, avatar_y, radius)
|
|
// #ifndef H5
|
|
setTimeout(() => { //必须延时执行 不然h5不显示
|
|
ctx.save();
|
|
ctx.draw()
|
|
}, 200)
|
|
// #endif
|
|
// #ifdef H5
|
|
setTimeout(() => { //必须延时执行 不然h5不显示
|
|
ctx.save();
|
|
ctx.draw(true, () => {
|
|
uni.canvasToTempFilePath({
|
|
canvasId: 'mycanvas',
|
|
success: (res) => {
|
|
this.imgUrl = res.tempFilePath
|
|
}
|
|
})
|
|
})
|
|
}, 500)
|
|
// #endif
|
|
},
|
|
setRadius(ctx, avatar_width, avatar_height, avatar_x, avatar_y, radius) {
|
|
/**
|
|
* 绘制圆角
|
|
*/
|
|
ctx.arc(avatar_x + radius, avatar_y + radius, radius, Math.PI, Math.PI * 3 / 2);
|
|
ctx.lineTo(avatar_width - radius + avatar_x, avatar_y);
|
|
ctx.arc(avatar_width - radius + avatar_x, radius + avatar_y, radius, Math.PI * 3 / 2, Math.PI * 2);
|
|
ctx.lineTo(avatar_width + avatar_x, avatar_height + avatar_y - radius);
|
|
ctx.arc(avatar_width - radius + avatar_x, avatar_height - radius + avatar_y, radius, 0, Math.PI * 1 / 2);
|
|
ctx.lineTo(radius + avatar_x, avatar_height + avatar_y);
|
|
ctx.arc(radius + avatar_x, avatar_height - radius + avatar_y, radius, Math.PI * 1 / 2, Math.PI);
|
|
// 开始填充
|
|
ctx.strokeStyle = "#fff";
|
|
ctx.fill() //保证图片无bug填充
|
|
ctx.clip(); //画了圆 再剪切 原始画布中剪切任意形状和尺寸。一旦剪切了某个区域,则所有之后的绘图都会被限制在被剪切的区域内
|
|
|
|
ctx.drawImage('/static/images/ewm.png', avatar_x, avatar_y, avatar_width, avatar_height);
|
|
ctx.closePath()
|
|
ctx.restore();
|
|
},
|
|
saveImg() {
|
|
console.log(123)
|
|
//保存图片
|
|
uni.showLoading({
|
|
title: '保存中...'
|
|
});
|
|
let that = this;
|
|
// #ifdef MP
|
|
uni.getSetting({
|
|
success(res) {
|
|
if (!res.authSetting['scope.writePhotosAlbum']) {
|
|
uni.hideLoading();
|
|
uni.openSetting({
|
|
success(res) { //拒绝授权后重新提示授权,并授权成功
|
|
}
|
|
});
|
|
} else {
|
|
setTimeout(() => {
|
|
uni.canvasToTempFilePath({
|
|
canvasId: 'mycanvas',
|
|
success: function(res) {
|
|
console.log(res);
|
|
uni.saveImageToPhotosAlbum({
|
|
filePath: res.tempFilePath,
|
|
success(re) {
|
|
uni.hideLoading();
|
|
uni.showToast({
|
|
title: '保存成功',
|
|
icon: 'success'
|
|
});
|
|
},
|
|
fail(err) {
|
|
uni.showToast({
|
|
title: '保存失败',
|
|
icon: 'none'
|
|
});
|
|
}
|
|
|
|
});
|
|
}
|
|
});
|
|
}, 1000);
|
|
}
|
|
}
|
|
|
|
});
|
|
// #endif
|
|
// #ifdef APP-PLUS
|
|
setTimeout(() => {
|
|
uni.canvasToTempFilePath({
|
|
canvasId: 'mycanvas',
|
|
success: function(res) {
|
|
console.log(res);
|
|
uni.saveImageToPhotosAlbum({
|
|
filePath: res.tempFilePath,
|
|
success(re) {
|
|
uni.hideLoading();
|
|
uni.showToast({
|
|
title: '保存成功',
|
|
icon: 'success'
|
|
});
|
|
},
|
|
fail(err) {
|
|
uni.showToast({
|
|
title: '保存失败',
|
|
icon: 'none'
|
|
});
|
|
}
|
|
|
|
});
|
|
}
|
|
});
|
|
}, 1000);
|
|
// #endif
|
|
}
|
|
}
|
|
};
|
|
</script>
|
|
<style lang="scss" scoped>
|
|
.myextension {
|
|
background-color: #FFFFFF;
|
|
overflow: hidden;
|
|
padding-bottom: 100upx;
|
|
}
|
|
|
|
.myextension image {
|
|
width: 100%;
|
|
height: 100%;
|
|
display: block;
|
|
}
|
|
|
|
.saveImg {
|
|
width: 300upx;
|
|
height: 80upx;
|
|
border-radius: 40upx;
|
|
box-shadow: 0 10upx 10upx #ddd;
|
|
background-color: pink;
|
|
line-height: 80upx;
|
|
text-align: center;
|
|
color: #fff;
|
|
margin: 0 auto;
|
|
margin-top: 60upx;
|
|
}
|
|
|
|
.mycanvas {
|
|
margin: 0 auto;
|
|
transform: translateY(30upx);
|
|
border-radius: 10upx;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.imgs {
|
|
position: absolute;
|
|
top: 30upx;
|
|
left: 50%;
|
|
transform: translateX(-50%);
|
|
border-radius: 10upx;
|
|
overflow: hidden;
|
|
}
|
|
.tips{
|
|
text-align: center;
|
|
color: #999;
|
|
font-size: 24upx;
|
|
margin-top: 50upx;
|
|
}
|
|
</style>
|