generate() {
this.gener().then(res => {
this.setData({ imgshare: res })
})
},
gener() {
//二维码
return new Promise((reslove, sej) => {
wx.showLoading({
title: '正在加载中...',
icon: 'none'
})
let that = this;
let qrcode = new Promise((reslove, sej) => {
_http.request({
url: "/api/qrcode/news",
method: "GET",
data: {
id: that.data.id
}
}).then(res => {
console.log(res)
wx.getImageInfo({
src: res.data.path,
success(res) {
reslove(res.path)
},
fail(err) {
console.log(err);
},
});
})
// reslove('https://www.redxibao.com/activity/20191024/undefined.png')
});
//背景
let avatar = new Promise((reslove, sej) => {
console.log(that.data.details.cover)
wx.getImageInfo({
src: that.data.details.cover,
success(res) {
reslove(res.path)
},
fail(err) {
console.log(err);
},
});
});
Promise.all([qrcode, avatar]).then((res) => {
const ctx = wx.createCanvasContext('myCanvas');
let rpx = that.data.rpx, heightrpx = that.data.rpxheight;
ctx.fillStyle = "#FFFFFF";
ctx.fillRect(0, 0, 345 * rpx, 520 * heightrpx);
ctx.drawImage(res[1], 0, 0, 345 * rpx, 200);
ctx.drawImage(res[0], ((345 * rpx) - 110) / 2, 300, 110 * rpx, 110);
ctx.setFontSize(16 * rpx);
ctx.setFillStyle("#333");
var text = that.data.details.title //这是要绘制的文本
var chr = text.split("");//这个方法是将一个字符串分割成字符串数组
var temp = "";
var row = [];
for (var a = 0; a < chr.length; a++) {
if (ctx.measureText(temp).width < 250) {
temp += chr[a];
}
else {
a--; //这里添加了a-- 是为了防止字符丢失,效果图中有对比
row.push(temp);
temp = "";
}
}
row.push(temp);
//如果数组长度大于2 则截取前两个
if (row.length > 2) {
var rowCut = row.slice(0, 2);
var rowPart = rowCut[1];
var test = "";
var empty = [];
for (var a = 0; a < rowPart.length; a++) {
if (ctx.measureText(test).width < 220) {
test += rowPart[a];
}
else {
break;
}
}
empty.push(test);
var group = empty[0] + "..."//这里只显示两行,超出的用...表示
rowCut.splice(1, 1, group);
row = rowCut;
}
for (var b = 0; b < row.length; b++) {
ctx.fillText(row[b], 30 * rpx, 230 + b * 20 * rpx);
}
ctx.setFontSize(14 * rpx);
ctx.setFillStyle("#999");
ctx.setFontSize(18 * rpx);
ctx.setFillStyle("#d11515");
ctx.setFontSize(16 * rpx);
// if (that.data.limit_text) {
// ctx.fillText(that.data.limit_text, 30 * rpx, 290 + b * 20 * rpx);
// }
ctx.setFillStyle("#666666");
ctx.fillText(that.data.details.street_title, 30 * rpx, 235 + b * 20 * rpx);
ctx.fillText(that.data.details.create_time, 30 * rpx, 255 + b * 20 * rpx);
that.setData({ imgshareBut: true })
wx.hideLoading();
ctx.draw(true, setTimeout(function () { //为什么要延迟100毫秒?大家测试一下
wx.canvasToTempFilePath({
x: 0,
y: 0,
width: 646 * rpx,
height: 966 * rpx,
destWidth: 646 * rpx,
destHeight: 966 * rpx,
canvasId: 'myCanvas',
success: res => {
wx.hideLoading();
reslove(res.tempFilePath)
}
}, that)
}, 1000))
})
})
},
//下载海报
saveImageToPhoto() {
var that = this
wx.saveImageToPhotosAlbum({
filePath: that.data.imgshare,
success(res) {
console.log(res)
wx.showModal({
content: '图片已保存到相册,赶紧晒一下吧~',
showCancel: false,
confirmText: '好的',
confirmColor: '#333',
success: function (res) {
if (res.confirm) {
/* 该隐藏的隐藏 */
that.setData({
curtain: "curtains"
})
}
}, fail: function (res) {
console.log(11111)
}
})
},
fail: res => {
console.log(res)
}
})
},
网友评论