Commit 8b7ff472 by 李嘉林

画海报

parent b32ebd1c
{ {
"pages": [ "pages": [
"pages/index/main", "pages/index/main",
"pages/testCanvasPoster/main", "pages/livedPoster/main",
"pages/lived/main", "pages/lived/main",
"pages/login/main", "pages/login/main",
"pages/wxPay/main", "pages/wxPay/main",
......
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
<p class="tit">微信分享</p> <p class="tit">微信分享</p>
</button> </button>
</div> </div>
<div class="createPoster"> <div class="createPoster" @click="isLogin">
<img <img
src="" src=""
alt alt
...@@ -36,10 +36,10 @@ export default { ...@@ -36,10 +36,10 @@ export default {
name: "", name: "",
data() { data() {
return { return {
liveId:"", liveId: "",
shopName: "", shopName: "",
shopLogo: "", shopLogo: "",
backPath: "", backPath: ""
}; };
}, },
components: {}, components: {},
...@@ -62,6 +62,41 @@ export default { ...@@ -62,6 +62,41 @@ export default {
// 关闭 // 关闭
closeDia() { closeDia() {
this.$emit("closeShareDia"); this.$emit("closeShareDia");
},
// 是否登录
isLogin(val) {
let _this = this;
wx.getStorage({
key: "sessionid",
success(res) {
_this.toCreatePoster();
},
fail(res) {
console.log("未登录------150");
// 跳转登录页
let backUrl = "/lived/main";
let query = {
liveId: _this.liveId,
fromType: "mini"
};
let url = `/pages/login/main?back=${backUrl}&params=${JSON.stringify(
query
)}`;
wx.navigateTo({
url: url
});
}
});
},
// 去海报页面
toCreatePoster() {
let query = {
liveId: this.liveId
};
let url = `/pages/livedPoster/main?params=${JSON.stringify(query)}`;
wx.navigateTo({
url: url
});
} }
} }
}; };
...@@ -96,7 +131,7 @@ img { ...@@ -96,7 +131,7 @@ img {
} }
} }
.wxShare { .wxShare {
button{ button {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;
......
<template> <template>
<div class="test"> <div class="livedPoster">
<!--index.wxml--> <div class="posterWrap">
<view class="posterWrap"> <canvas canvas-id="posterCanvas" class="myCanvas" @click="getImg"></canvas>
<canvas canvas-id="posterCanvas" class="myCanvas"></canvas>
<div class="fixed_container">
<div class="fixed_inner">
<div @click="handleShowImg">
<img src="../../../static/images/lived/goodsImg.png" alt />
<span>发送给朋友</span>
</div> </div>
<div @click="handleSave">
<img src="../../../static/images/lived/goodsImg.png" alt />
<span>保存名片</span>
</div>
</div>
</div>
</view>
</div> </div>
</template> </template>
<script type="text/ecmascript-6"> <script type="text/ecmascript-6">
import { serialize, getQueryVariable, DFSImg } from "@/utils/index";
import live from "@/api/live";
export default { export default {
name: "", name: "",
data() { data() {
return { return {
InfoSync: {}, InfoSync: {},
liveId: 0,
params: {},
// 海报中信息 // 海报中信息
info: { info: {
coverUrl: "", coverUrl: "",
livedStatus: 1, //直播状态 0未开播 1一开播 livedStatus: 1, //直播状态 0未开播 1一开播
livedTime: "3月21日 20:20", livedTime: "3月21日 20:20",
livedTitle: "",
nickName: "", nickName: "",
avatarUrl: "" avatarUrl: "",
miniCode: ""
} }
}; };
}, },
components: {}, onLoad(options) {
computed: {}, this.params = JSON.parse(options.params);
onLoad() { this.liveId = this.params.liveId;
this.init();
},
onUnload() {},
methods: {
back() {
wx.navigateBack({
delta: 1
});
},
init() {
let liveBroadcastId = this.liveId;
let _this = this;
live.getLiveInfo(liveBroadcastId).then(res => {
if (res.data.code == 200) {
let resData = res.data.data;
this.info.livedTitle = resData.title;
this.info.livedStatus = resData.liveBroadcastState;
this.info.coverUrl = DFSImg(resData.coverUrl);
let newTime = new Date(resData.startTime.replace(/-/g, "/"));
this.info.livedTime = `${newTime.getMonth() +
1}${newTime.getDate() -
1}${newTime.getHours()}:${newTime.getMinutes()}`;
wx.getUserInfo({ wx.getUserInfo({
//获取微信用户信息 //获取微信用户信息
success: function(res) { success: function(res) {
console.log(res, "----------------108"); (_this.info.nickName = res.userInfo.nickName),
(_this.info.avatarUrl = res.userInfo.avatarUrl),
_this.initPoster(_this.info);
},
fail: function(res) {
_this.initPoster(_this.info);
}
});
} }
}); });
this.initPoster(this.info);
}, },
created() {},
mounted() {},
methods: {
initPoster(info) { initPoster(info) {
const InfoSync = wx.getSystemInfoSync(); const InfoSync = wx.getSystemInfoSync();
this.InfoSync = InfoSync; this.InfoSync = InfoSync;
let bili = InfoSync.windowWidth / 375 * 1; let bili = InfoSync.windowWidth / 375 * 1;
const ctx = wx.createCanvasContext("posterCanvas"); const ctx = wx.createCanvasContext("posterCanvas");
ctx.setTextAlign("center"); // 文字居中 ctx.fillText(显示文字,距离画布左边/基准点/文字以这个点居中或左对齐,距离画布顶部) ctx.setFillStyle("#fff");
ctx.setFillStyle("#111"); // 文字颜色:fff ctx.fillRect(0, 0, 310 * bili, 520 * bili);
ctx.setFontSize(16); // 文字字号
ctx.fillText(info.livedTime, 155 * bili, 164 * bili); //名字 ctx.fillText(显示文字,距离画布左边/基准点/文字以这个点居中或左对齐,距离画布顶部
ctx.setFontSize(14); // 文字字号 //封面
ctx.setTextAlign("left"); // 文字居中 this.saveThe(info.coverUrl, path => {
ctx.setFillStyle("#111"); // 文字颜色:fff ctx.drawImage(path, 0, 0, 310 * bili, 370 * bili);
ctx.fillText("生日:1990-01-01", 90 * bili, 256 * bili);
ctx.fillText("电话:9090980", 90 * bili, 284 * bili);
ctx.setFillStyle("#111"); // 文字颜色:111
ctx.setTextAlign("left"); // 文字居中
ctx.setFontSize(17); // 文字字号
ctx.fillText("写两次让字体加粗", 140 * bili, 346 * bili);
ctx.fillText("写两次让字体加粗", 140 * bili, 346 * bili);
ctx.setFillStyle("#828282"); // 文字颜色:828282
ctx.setFontSize(14); // 文字字号
ctx.fillText("写一次不加粗", 140 * bili, 376.5 * bili);
ctx.setFillStyle("#B0B0B0"); // 文字颜色:B0B0B0
ctx.setFontSize(11); // 文字字号
ctx.fillText("小字体", 140 * bili, 398 * bili);
ctx.save(); ctx.save();
// 微信昵称
ctx.setTextAlign("left");
ctx.setFillStyle("#3F2F00");
ctx.setFontSize(15);
ctx.fillText(info.nickName, 80 * bili, 420 * bili);
ctx.setTextAlign("left");
ctx.setFillStyle("#3F2F00");
ctx.setFontSize(14);
ctx.fillText("邀你一起看直播", 10 * bili, 460 * bili);
// 直播名
ctx.setTextAlign("left");
ctx.setFillStyle("#3F2F00");
ctx.setFontSize(18);
ctx.fillText(info.livedTitle, 10 * bili, 500 * bili);
//圆形头像框 //圆形头像框
ctx.setStrokeStyle("rgba(0,0,0,0)"); ctx.setStrokeStyle("rgba(0,0,0,0)");
ctx.arc(155 * bili, 94 * bili, 45 * bili, 0, 2 * Math.PI); ctx.arc(40 * bili, 410 * bili, 30 * bili, 0, 2 * Math.PI);
ctx.fill(); ctx.fill();
//二维码
this.saveThe(
"http://test-bucket-ant.oss-cn-shanghai.aliyuncs.com/product/png/08af1c1f-b7a8-4bac-b85d-36e3cfc5cd05.png",
path => {
ctx.drawImage(path, 30.5 * bili, 320 * bili, 93 * bili, 93 * bili);
ctx.save();
//头像 //头像
this.saveThe( this.saveThe(info.avatarUrl, path => {
"http://test-bucket-ant.oss-cn-shanghai.aliyuncs.com/product/png/08af1c1f-b7a8-4bac-b85d-36e3cfc5cd05.png",
path => {
ctx.clip(); ctx.clip();
ctx.drawImage( ctx.drawImage(path, 10 * bili, 380 * bili, 70 * bili, 70 * bili);
path,
110 * bili,
47.5 * bili,
90 * bili,
90 * bili
);
ctx.save(); ctx.save();
ctx.stroke(); ctx.stroke();
ctx.draw(); ctx.draw();
} });
); });
}
);
}, },
// 小程序需要将图片下载下来,然后才能绘制到画布上 // 小程序需要将图片下载下来,然后才能绘制到画布上
saveThe(url, callback) { saveThe(url, callback) {
...@@ -118,6 +118,9 @@ export default { ...@@ -118,6 +118,9 @@ export default {
fail: function(res) {} fail: function(res) {}
}); });
}, },
getImg() {
this.handleSave();
},
// 点击保存时,将画布生成海报 // 点击保存时,将画布生成海报
handleSave() { handleSave() {
var that = this; var that = this;
...@@ -246,59 +249,20 @@ export default { ...@@ -246,59 +249,20 @@ export default {
}; };
</script> </script>
<style scoped> <style scoped lang="scss">
.livedPoster {
position: relative;
}
.posterWrap { .posterWrap {
min-height: calc(100vh - 40px); min-height: calc(100vh - 20px);
padding-top: 40px; padding-top: 20px;
background-color: #f1f1f1; background-color: #f1f1f1;
} }
.myCanvas { .myCanvas {
width: 310px; width: 310px;
height: 435px; height: 520px;
margin: 0 auto; margin: 0 auto;
background: #fff; background: #fff;
} }
.fixed_container {
position: fixed;
bottom: 0;
width: 100%;
z-index: 1000;
}
.fixed_inner {
display: flex;
justify-content: space-between;
border-top: 1rpx solid #e5e5e5;
padding: 20rpx 32rpx;
background: #ffffff;
align-items: center;
}
.fixed_inner div {
display: flex;
align-items: center;
justify-content: center;
color: #fff;
border-radius: 5rpx;
width: 330rpx;
height: 76rpx;
line-height: 76rpx;
text-align: center;
background: -webkit-linear-gradient(left, #27caac, #02ba8e);
background: -o-linear-gradient(right, #27caac, #02ba8e);
background: -moz-linear-gradient(right, #27caac, #02ba8e);
background: linear-gradient(to right, #27caac, #02ba8e); /* 标准的语法 */
}
.fixed_inner div:last-child {
background: -webkit-linear-gradient(left, #ff7179, #ff6459);
background: -o-linear-gradient(right, #ff7179, #ff6459);
background: -moz-linear-gradient(right, #ff7179, #ff6459);
background: linear-gradient(to right, #ff7179, #ff6459);
}
.fixed_inner div img {
width: 42rpx;
height: 32rpx;
margin-right: 11rpx;
}
</style> </style>
{ {
"navigationBarTitleText": "测试canvas绘制海报" "navigationBarTitleText": "点击保存图片"
} }
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment