123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474 |
- // component/shar-dialog/shar-dialog.js
- import httpRequestApi from '../../utils/APIClient';
- const app = getApp();
- Component({
- /**
- * 组件的属性列表
- */
- properties: {
- shareType: {
- type: 'String',
- value: ''
- },
- shareId: {
- type: 'String',
- value: ''
- }
- },
- /**
- * 组件的初始数据
- */
- data: {
- shareFlag: false,
- imgUrls: '',
- avatar: '',
- author: '',
- iconImg: '',
- title: '',
- path: '',
- QRCodeImagePath: '',
- QRCodeImageLocalPath: '',
- activityImg: '',
- groupPurchaseInfo: {},
- groupType: '',
- animationData: {},
- touchMove: true,
- randomSologan: [
- '开发右脑最简单的方式就是大声朗读',
- '大声朗读 有利于建立自信心',
- '大声朗读 能帮助孩子提高写作能力',
- '朗读是感知世界的一种重要方式',
- '增强记忆力的方法之一大声朗读',
- '大声朗读是语感形成的最佳途径',
- '大声朗读 还原课文的诗性美',
- '在朗读中 提升孩子的思辨能力',
- '重温经典课文 享受亲子美好时光',
- '大声朗读 能帮助孩子提高写作能力'
- ],
- shareStep: 'firend',
- activity: ''
- },
- /**
- * 组件的方法列表
- */
- methods: {
- touchMove: function () {
- return false
- },
- poster: function () {
- const that = this;
- wx.showLoading({
- title: '专属海报生成中',
- // mask: true
- })
- if (this.data.shareType === 'readActivity') {
- httpRequestApi.getqrCodeShare(this.data.QRData).success(res => {
- console.log('----------------->分享二维码222',res.data.data)
- // 下载二维码
- wx.downloadFile({
- url: res.data.data,
- success: res => {
- console.log('----------------->分享二维码',res.tempFilePath)
- this.setData({
- QRCodeImagePath: res.tempFilePath
- }, () => {
- this.saveAvatar();
- })
- }
- });
- })
- } else {
- httpRequestApi.createQRCode(this.data.QRData).success(res => {
- console.log('----------------->分享二维码222',res.data.data)
- // 下载二维码
- wx.downloadFile({
- url: res.data.data,
- success: res => {
- console.log('----------------->分享二维码',res.tempFilePath)
- this.setData({
- QRCodeImagePath: res.tempFilePath
- }, () => {
- this.saveAvatar();
- })
- }
- });
- })
- }
- },
- makeImage: function () {
- const ctx = wx.createCanvasContext('myCanvas');
- // 画出背景和相同内容
- if(this.data.activity || this.data.shareType === 'readActivity') {
- ctx.drawImage(this.data.activityImg, 0, 0, 1200, 2100, 0, 0, 600, 1050); //插入图片
- } else {
- if (this.data.shareType === 'works') {
- ctx.drawImage('../../static/image/works_poster.jpg', 0, 0, 1200, 2100, 0, 0, 600, 1050); //插入图片
- } else {
- ctx.drawImage('../../static/image/group_poster.jpg', 0, 0, 1200, 2100, 0, 0, 600, 1050); //插入图片
- }
- }
- if (this.data.activity) {
- ctx.save()
- ctx.arc(49, 50, 29, 0, 2 * Math.PI, true)
- ctx.clip(); //剪切头像区域
- ctx.drawImage(this.data.avatar, 20, 20, 61, 61);
- ctx.clip(); //剪切头像区域
- ctx.restore();
- ctx.font = 'normal bold 14px'
- // ctx.setFontSize(14)
- // ctx.setFontWeight(500)
- ctx.setFillStyle('#198165')
- ctx.fillText(this.data.author, 82, 49)
- ctx.restore();
- ctx.setFontSize(16)
- ctx.setFillStyle('#434343')
- ctx.fillText(`《${this.data.title}》`, (300 - ctx.measureText(`《${this.data.title}》`).width) / 2, 285)
- // 二维码
- ctx.drawImage(this.data.QRCodeImagePath, 104, 299, 92, 92);
- ctx.draw();
- }else if(this.data.shareType === 'readActivity') {
- ctx.save()
- ctx.arc(49, 50, 29, 0, 2 * Math.PI, true)
- ctx.clip(); //剪切头像区域
- ctx.drawImage(this.data.avatar, 20, 20, 61, 61);
- ctx.clip(); //剪切头像区域
- ctx.restore();
- ctx.font = 'normal bold 14px'
- ctx.setFontSize(14)
- ctx.setFillStyle('#fff')
- ctx.fillText(this.data.name, 85, 59)
- ctx.restore();
- // 二维码
- ctx.drawImage(this.data.QRCodeImagePath, 11, 409, 92, 92);
- ctx.draw();
- } else {
- ctx.save()
- ctx.beginPath()
- ctx.fill()
- ctx.setFontSize(25)
- ctx.setFillStyle('#fff')
- ctx.fillText('课文朗读 每天5分钟', (300 - ctx.measureText('课文朗读 每天5分钟').width) / 2, 54.5)
- ctx.setFontSize(16)
- let randomSologan = this.data.randomSologan[Math.floor(Math.random() * 10)];
- ctx.fillText(randomSologan, (300 - ctx.measureText(randomSologan).width) / 2, 75.5)
- ctx.setFontSize(15)
- ctx.setFillStyle('#838383')
- ctx.fillText('长按识别二维码', 130.5, 391)
- ctx.setFontSize(12)
- ctx.setFillStyle('#838383')
- ctx.fillText('接收邀请,获得你的课程吧', 130.5, 409.5) /* */
- // 头像
- console.log('画头像')
- if (this.data.shareType === 'works') {
- ctx.arc(150, 160, 36, 0, 2 * Math.PI, true)
- ctx.clip(); //剪切头像区域
- ctx.drawImage(this.data.avatar, 116, 126, 68, 68);
- ctx.arc(150, 160, 34, 0, 2 * Math.PI, false)
- ctx.setFillStyle('#ff6f42')
- ctx.fill();
- ctx.clip(); //剪切头像区域
- ctx.restore(); //恢复之前保存的绘图上下文 恢复之前保存的绘图上下午即状态 可以继续绘制
- ctx.setFontSize(15)
- ctx.setFillStyle('#ff6f42')
- ctx.fillText(this.data.author, (300 - ctx.measureText(this.data.author).width) / 2, 220)
- ctx.setFillStyle('#434343')
- ctx.fillText('播音主持特长生', (300 - ctx.measureText('播音主持特长生').width) / 2, 243)
- ctx.setFontSize(15)
- ctx.setFillStyle('#434343')
- ctx.fillText('使出洪荒之力,声情并茂地朗诵了', (300 - ctx.measureText('使出洪荒之力,声情并茂地朗诵了').width) / 2, 262)
- ctx.fillText(`《${this.data.title}》`, (300 - ctx.measureText(`《${this.data.title}》`).width) / 2, 284)
- } else {
- ctx.arc(64, 146, 29, 0, 2 * Math.PI, true)
- ctx.clip(); //剪切头像区域
- ctx.drawImage(this.data.avatar, 37, 119, 54, 54);
- ctx.arc(64, 146, 27, 0, 2 * Math.PI, false)
- ctx.setFillStyle('#ff6f42')
- ctx.fill();
- ctx.clip(); //剪切头像区域
- //插入图片
- ctx.restore(); //恢复之前保存的绘图上下文 恢复之前保存的绘图上下午即状态 可以继续绘制
- ctx.setFontSize(18)
- ctx.setFillStyle('#ff6f42')
- ctx.fillText(this.data.author, 100, 143.5)
- ctx.setFontSize(16)
- ctx.setFillStyle('#434343')
- ctx.fillText('邀您和我一起大声朗读', 100, 167.5)
- ctx.drawImage(this.data.iconImg, 27, 194, 247, 103.5);
- ctx.setFontSize(15)
- ctx.setFillStyle('#434343')
- ctx.fillText('朗朗读书声,是世界上最美妙的声音', (300 - ctx.measureText('朗朗读书声,是世界上最美妙的声音').width) / 2, 327.5)
- }
- console.log('花二维码')
- console.log(this.data)
- console.log(this.data.avatar)
- ctx.drawImage(this.data.QRCodeImagePath, 35, 351, 90, 90);
- ctx.draw();
- }
- setTimeout(() => {
- wx.canvasToTempFilePath({
- x: 0,
- y: 0,
- width: 300,
- height: 525,
- destWidth: 1200,
- destHeight: 2100,
- canvasId: 'myCanvas',
- success: (res) => {
- this.setData({
- imgUrls: res.tempFilePath
- })
- wx.hideLoading()
- },
- fail: (res) => {
- console.log('史称失败', res)
- wx.hideLoading();
- }
- })
- }, 400)
- },
- saveIcon: function () {
- wx.downloadFile({
- url: this.data.iconImg,
- success: res => {
- this.setData({
- iconImg: res.tempFilePath
- }, () => {
- console.log(this.data.iconImg)
- this.makeImage();
- })
- }
- });
- },
- /** 需要优化 */
- saveAvatar: function () {
- wx.downloadFile({
- url: this.data.avatar,
- success: res => {
- this.setData({
- avatar: res.tempFilePath
- }, () => {
- const imgName = this.data.shareType === 'readActivity' ? 'pay/share.png' : 'activity/activity_bg.jpg'
- wx.downloadFile({
- url: `https://reader-wx.ai160.com/images/reader/${imgName}`,
- success: res => {
- this.setData({
- activityImg: res.tempFilePath
- }, () => {
- if (this.data.shareType === 'group') {
- this.saveIcon();
- } else {
- this.makeImage();
- }
- })
- }
- })
- })
- }
- });
- },
- share: function (data) {
- console.log('分享内容', data)
- if (this.data.shareType === 'works') {
- this.setData({
- shareFlag: !this.data.shareFlag,
- avatar: data.avatar,
- author: data.author,
- iconImg: data.iconImg,
- title: data.title,
- productId: data.productId,
- id: data.scene,
- type: data.type,
- grade: data.grade,
- shareImg: data.shareImg,
- shareStep: 'firend',
- shareIndex: data.index,
- activity: data.activity,
- QRData: {
- page: data.path,
- scene: data.scene
- }
- })
- }
- if (this.data.shareType === 'group') {
- console.log(data)
- console.log('团购分享')
- this.setData({
- shareFlag: !this.data.shareFlag,
- avatar: data.avatar,
- author: data.author,
- iconImg: data.iconImg,
- title: data.title,
- // path: data.path,
- QRData: {
- page: data.path,
- scene: data.scene
- },
- groupPurchaseInfo: data.groupPurchaseInfo,
- groupType: data.groupType
- })
- }
- /**添加团购分享海报为了进度代码越写越乱项目可重构 */
- if (this.data.shareType === 'readActivity') {
- console.log(data)
- this.setData({
- shareFlag: !this.data.shareFlag,
- avatar: data.avatar,
- name: data.name,
- QRData: {
- page: data.path,
- type: `${data.type}`
- }
- })
- this.poster();
- }
- if (this.data.shareType === 'class') {
- console.log('课程分享')
- this.setData({
- shareFlag: !this.data.shareFlag
- })
- }
- // 动画测试
- this.animation = wx.createAnimation({
- duration: 700,
- timingFunction: 'ease',
- })
- this.animation.bottom(0).step();
- this.setData({
- animationData: this.animation.export()
- })
- // 动画测试
- // this.poster();
- },
- //关闭弹框
- close: function (e) {
- this.animation = wx.createAnimation({
- duration: 400,
- timingFunction: 'ease',
- })
- this.animation.bottom(-300).step();
- this.setData({
- animationData: this.animation.export()
- }, () => {
- setTimeout(() => {
- this.setData({
- shareFlag: !this.data.shareFlag,
- imgUrls: ''
- })
- this.triggerEvent('ShareDialogClose', {})
- }, 200)
- })
- wx.hideLoading()
- },
- nothing: function (e) {
- return
- },
- // 保存最终图片
- PreservationImg: function () {
- // this.getImgAuthorize()
- wx.saveImageToPhotosAlbum({
- filePath: this.data.imgUrls,
- success: (res) => {
- wx.showModal({
- title: '海报已保存至相册',
- content: '快去分享给小伙伴吧',
- confirmText: '我知道了',
- showCancel: false,
- success: (res) => {
- console.log('用户点击确定')
- this.close();
- httpRequestApi.shareImgLog({
- readId: this.data.id,
- }).success((oRes) => {
- this.triggerEvent('addShareAmount', {
- index:this.data.shareIndex
- })
- setTimeout(() => {
- if (oRes.data.count > 0) {
- this.setData({
- flowerNum: oRes.data.count
- })
- this.flowerAnimationHandler();
- }
- }, 500)
- })
- }
- })
- this.setData({
- imgUrls: false
- })
- },
- fail: res => {
- wx.getSetting({
- success(res) {
- if (!res.authSetting['scope.writePhotosAlbum']) {
- // wx.showToast({
- // title: '无权限操作',
- // icon: 'fail',
- // duration: 800
- // })
- wx.showModal({
- title: '无法保存分享图片到相册',
- content: '点击右上角浮点按钮->设置,进行授权',
- confirmText: '我知道了',
- showCancel: false,
- success(res) {
- console.log('用户点击确定')
- }
- })
- }
- }
- })
- }
- })
- },
- shareFriend: function () {
- this.setData({
- shareStep: 'circle'
- })
- if (this.data.shareType !== 'readActivity') {
- this.poster();
- }
-
- httpRequestApi.shareLog({
- readId: this.data.id.replace('&activity=true',''),
- type: this.data.type,
- grade: this.data.grade
- }).success((res) => {
- console.log('分享记录', res)
- if (res.data.count > 0) {
- this.setData({
- flowerNum: res.data.count,
- }, () => {
- // this.flowerAnimationHandler();
- })
- }
- this.triggerEvent('addShareAmount', {
- index:this.data.shareIndex
- })
- })
- },
- flowerAnimationHandler: function () {
- this.flowerBox = this.selectComponent("#flower-toast");
- console.log('this.flower', this.flowerBox)
- this.flowerBox.comeOut();
- },
- },
- onShareAppMessage: (e) => {
- console.log('点击分享按钮', e)
- if (res.from === 'button') {
- // 来自页面内转发按钮
- console.log(res.target)
- } else {
- return {
- title: '课文朗读,从未如此有趣。',
- path: '/pages/index/index'
- }
- }
- }
- })
|