From 7452e9ba0f242ac8b7bf7fabdafa1753ac793f84 Mon Sep 17 00:00:00 2001 From: richard <51844712@qq.com> Date: Mon, 14 May 2018 10:09:44 +0800 Subject: [PATCH] =?UTF-8?q?canvas=E6=96=87=E6=9C=AC=20=E8=87=AA=E5=8A=A8?= =?UTF-8?q?=E6=8D=A2=E8=A1=8C=20=E8=87=AA=E9=80=82=E5=BA=94?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pages/contentShare/contentShare.js | 117 +++++++++++++++++---------- pages/contentShare/contentShare.wxss | 2 +- project.config.json | 2 +- utils/util.js | 9 ++- 4 files changed, 84 insertions(+), 46 deletions(-) diff --git a/pages/contentShare/contentShare.js b/pages/contentShare/contentShare.js index 32a7d8a..bfa58f0 100644 --- a/pages/contentShare/contentShare.js +++ b/pages/contentShare/contentShare.js @@ -1,8 +1,8 @@ // pages/contentShare/contentShare.js +var apiHelper = require("../../utils/api.js"); function findBreakPoint(text, width, context) { var min = 0; var max = text.length - 1; - while (min <= max) { var middle = Math.floor((min + max) / 2); var middleWidth = context.measureText(text.substr(0, middle)).width; @@ -19,8 +19,7 @@ function findBreakPoint(text, width, context) { return -1; } -function breakLinesForCanvas(text, width, font) { - var context = wx.createCanvasContext('secondCanvas') +function breakLinesForCanvas(context, text, width, font) { var result = []; var breakPoint = 0; @@ -69,76 +68,108 @@ Page({ * 生命周期函数--监听页面初次渲染完成 */ onReady: function (e) { + var contentTitle = "2018年QS排名最新出炉,悉尼大学的毕业生就业能力在全澳大利亚排名第1"; + var contentStr = "2018年QS全球毕业生就业能力排名榜于近期公布,其中,悉尼大学发挥稳定,与去年排名同为第4,超过麻省理工、剑桥、牛津等国内大学生心中的梦想大学。而墨尔本大学紧随其后屈居第7,新南威尔士大学排名36,昆士兰大学排名49、悉尼科技大学排名69,美国斯坦福大学毫无意外地占据榜首。值得一提的是,在本次的榜单中。2018年QS全球毕业生就业能力排名榜于近期公布,其中,悉尼大学发挥稳定,与去年排名同为第4,超过麻省理工、剑桥、牛津等国内大学生心中的梦想大学。而墨尔本大学紧随其后屈居第7,新南威尔士大学排名36,昆士兰大学排名49、悉尼科技大学排名69,美国斯坦福大学毫无意外地占据榜首。值得一提的是,在本次的榜单中。2018年QS全球毕业生就业能力排名榜于近期公布,其中,悉尼大学发挥稳定,与去年排名同为第4,超过麻省理工、剑桥、牛津等国内大学生心中的梦想大学。而墨尔本大学紧随其后屈居第7,新南威尔士大学排名36,昆士兰大学排名49、悉尼科技大学排名69,美国斯坦福大学毫无意外地占据榜首。值得一提的是,在本次的榜单中。"; + this.drawInit({ + title: contentTitle, + intro: contentStr + }); + }, + saveImg: function () { + var that = this; + wx.canvasToTempFilePath({ + canvasId: 'secondCanvas', + fileType: 'jpg', + success: function (res) { + console.log(res.tempFilePath) // 返回图片路径 + + wx.showLoading({ + title: '保存中...', + mask: true + }); + wx.saveImageToPhotosAlbum({ + filePath: res.tempFilePath, + success: function (res) { + wx.showToast({ + title: '保存成功', + icon: 'success', + duration: 2000 + }) + }, fail: function (res) { + wx.hideLoading() + console.log(res) + } + }) + } + }) + }, + /** + * 绘制图片 + */ + drawInit: function (info) { + var contentTitle = info.title; + var contentStr = info.intro; var that = this var res = wx.getSystemInfoSync(); var canvasHeight = res.windowHeight; var canvasWidth = res.windowWidth; - - + // 获取canvas的的宽 自适应宽(设备宽/750) px + var Rpx = canvasWidth / 375; // 使用 wx.createContext 获取绘图上下文 context var context = wx.createCanvasContext('secondCanvas') //设置行高 - var lineHeight = 30; + var lineHeight = Rpx * 30; //左边距 - var paddingLeft = 20; + var paddingLeft = Rpx * 20; //右边距 - var padingRight = 20; + var padingRight = Rpx * 20; //当前行高 - var currentLineHeight = 0; + var currentLineHeight = Rpx * 20; //设置标题 - var resultTitle = breakLinesForCanvas('2018年QS排名最新出炉,悉尼大学的毕业生就业能力在全澳大利亚排名第1', canvasWidth - paddingLeft - padingRight, '20px PingFangSC-Regular'); - context.font = "20px PingFangSC-Regular"; + var resultTitle = breakLinesForCanvas(context, contentTitle, canvasWidth - paddingLeft - padingRight, `${(Rpx * 20).toFixed(0)}px PingFangSC-Regular`); resultTitle.forEach(function (line, index) { - currentLineHeight = lineHeight * index + 30; + currentLineHeight += Rpx * 30; context.fillText(line, paddingLeft, currentLineHeight); }); //画分割线 - currentLineHeight += 30; - context.setLineDash([6, 3.75]); + currentLineHeight += Rpx * 30; + context.setLineDash([Rpx * 6, Rpx * 3.75]); context.moveTo(paddingLeft, currentLineHeight); context.lineTo(canvasWidth - padingRight, currentLineHeight); context.strokeStyle = '#cccccc'; context.stroke(); //设置内容 - var result = breakLinesForCanvas('2018年QS全球毕业生就业能力排名榜于近期公布,其中,悉尼大学发挥稳定,与去年排名同为第4,超过麻省理工、剑桥、牛津等国内大学生心中的梦想大学。而墨尔本大学紧随其后屈居第7,新南威尔士大学排名36,昆士兰大学排名49、悉尼科技大学排名69,美国斯坦福大学毫无意外地占据榜首。值得一提的是,在本次的榜单中。2018年QS全球毕业生就业能力排名榜于近期公布,其中,悉尼大学发挥稳定,与去年排名同为第4,超过麻省理工、剑桥、牛津等国内大学生心中的梦想大学。而墨尔本大学紧随其后屈居第7,新南威尔士大学排名36,昆士兰大学排名49、悉尼科技大学排名69,美国斯坦福大学毫无意外地占据榜首。值得一提的是,在本次的榜单中。2018年QS全球毕业生就业能力排名榜于近期公布,其中,悉尼大学发挥稳定,与去年排名同为第4,超过麻省理工、剑桥、牛津等国内大学生心中的梦想大学。而墨尔本大学紧随其后屈居第7,新南威尔士大学排名36,昆士兰大学排名49、悉尼科技大学排名69,美国斯坦福大学毫无意外地占据榜首。值得一提的是,在本次的榜单中。', canvasWidth - paddingLeft - padingRight, '16px PingFangSC-Regular'); - //字体大小 - context.font = "16px PingFangSC-Regular"; + var result = breakLinesForCanvas(context, contentStr || '无内容', canvasWidth - paddingLeft - padingRight, `${(Rpx * 16).toFixed(0)}px PingFangSC-Regular`); //字体颜色 context.fillStyle = '#666666'; result.forEach(function (line, index) { - context.fillText(line, paddingLeft, lineHeight * index + currentLineHeight + 30); + currentLineHeight += Rpx * 30; + context.fillText(line, paddingLeft, currentLineHeight); }); - context.draw(); - }, - saveImg: function () { - var that = this; - wx.canvasToTempFilePath({ - canvasId: 'secondCanvas', - fileType: 'jpg', - success: function (res) { - console.log(res.tempFilePath) // 返回图片路径 - - wx.showLoading({ - title: '保存中...', - mask: true - }); - wx.saveImageToPhotosAlbum({ - filePath: res.tempFilePath, + //查看是否 有广告位 需绘制 + apiHelper.paramData.cmd = "studyAbroadNews/getNewsAdvertising"; //cmd + apiHelper.paramData.param = { + pageCode: "introPage" + }; + apiHelper.post((res) => { + if (res.State == 0 && res.Value) { + let imgUrl = res.Value.img; + wx.downloadFile({ + url: imgUrl, //仅为示例,并非真实的资源 success: function (res) { - wx.showToast({ - title: '保存成功', - icon: 'success', - duration: 2000 - }) - }, fail: function (res) { - wx.hideLoading() - console.log(res) + // 只要服务器有响应数据,就会把响应内容写入文件并进入 success 回调,业务需要自行判断是否下载到了想要的内容 + if (res.statusCode === 200) { + context.drawImage(res.tempFilePath, paddingLeft, currentLineHeight + Rpx * 30, canvasWidth - paddingLeft - padingRight, Rpx * 200); + context.draw(); + } } }) + } else { + context.draw(); } - }) + }); }, /** * 生命周期函数--监听页面显示 diff --git a/pages/contentShare/contentShare.wxss b/pages/contentShare/contentShare.wxss index 514be88..543eec2 100644 --- a/pages/contentShare/contentShare.wxss +++ b/pages/contentShare/contentShare.wxss @@ -9,7 +9,7 @@ } canvas { - border: 1px solid red; + /* border: 1px solid red; */ box-sizing: border-box; } diff --git a/project.config.json b/project.config.json index bce3c4a..03cbd1d 100644 --- a/project.config.json +++ b/project.config.json @@ -10,7 +10,7 @@ "compileType": "miniprogram", "libVersion": "1.9.94", "appid": "wx1df3848032df8f34", - "projectname": "StudyNews", + "projectname": "GitHubNews", "isGameTourist": false, "condition": { "search": { diff --git a/utils/util.js b/utils/util.js index dbadbb8..d65d7a9 100644 --- a/utils/util.js +++ b/utils/util.js @@ -14,6 +14,13 @@ const formatNumber = n => { return n[1] ? n : '0' + n } +function getLocalTime(days = 0, date = new Date()) { + var d = new Date(date); + d.setDate(d.getDate() + days); + var m = d.getMonth() + 1; + return d.getFullYear() + '-' + m + '-' + d.getDate(); +} module.exports = { - formatTime: formatTime + formatTime: formatTime, + getLocalTime: getLocalTime }