摘要:海報生成示例最近智酷君在做小程序生成海報的項目中遇到一些棘手的問題,在網上查閱了各種資料,也踩扁了各種坑,智酷君希望把這些填坑經驗整理一下分享出來,避免后來的兄弟重復掉坑。
海報生成示例
最近智酷君在做[小程序]canvas生成海報的項目中遇到一些棘手的問題,在網上查閱了各種資料,也踩扁了各種坑,智酷君希望把這些“填坑”經驗整理一下分享出來,避免后來的兄弟重復“掉坑”。
原型圖
這是一個大致的原型圖,下面來看下如何制作這個海報,以及整體的思路。
海報生成流程
### [代碼片段]Canvas生成海報實戰demo
demo的微信路徑:https://developers.weixin.qq....
demo的ID:Q74OU3m57c9x
如果你裝了IDE工具,可以直接訪問上面的demo路徑
通過代碼片段將demo的ID輸入進去也可添加:
下面分享下主要的代碼內容和“填坑現場”:一、添加字體
https://developers.weixin.qq.com/miniprogram/dev/api/canvas/font.html
canvasContext.font = value //示例 ctx.font = `normal bold 20px sans-serif`//設置字體大小,默認10 ctx.setTextAlign("left"); ctx.setTextBaseline("top"); ctx.fillText("《智酷方程式》專注研究和分享前端技術", 50, 15, 250)//繪制文本
符合 CSS font 語法的 DOMString 字符串,至少需要提供字體大小和字體族名。默認值為 10px sans-serif
文字過長在canvas下換行問題處理(最多兩行,超過“...”代替)ctx.setTextAlign("left"); ctx.setFillStyle("#000");//文字顏色:默認黑色 ctx.font = `normal bold 18px sans-serif`//設置字體大小,默認10 let canvasTitleArray = canvasTitle.split(""); let firstTitle = ""; //第一行字 let secondTitle = ""; //第二行字 for (let i = 0; i < canvasTitleArray.length; i++) { let element = canvasTitleArray[i]; let firstWidth = ctx.measureText(firstTitle).width; //console.log(ctx.measureText(firstTitle).width); if (firstWidth > 260) { let secondWidth = ctx.measureText(secondTitle).width; //第二行字數超過,變為... if (secondWidth > 260) { secondTitle += "..."; break; } else { secondTitle += element; } } else { firstTitle += element; } } //第一行文字 ctx.fillText(firstTitle, 20, 278, 280)//繪制文本 //第二行問題 if (secondTitle) { ctx.fillText(secondTitle, 20, 300, 280)//繪制文本 }
通過 ctx.measureText 這個方法可以判斷文字的寬度,然后進行切割。
(一行字允許寬度為280時,判斷需要寫小點,比如260)
let mainImg = "https://demo.com/url.jpg"; wx.getImageInfo({ src: mainImg,//服務器返回的圖片地址 success: function (res) { //處理圖片縱橫比例過大或者過小的問題!!! let h = res.height; let w = res.width; let setHeight = 280, //默認源圖截取的區域 setWidth = 220; //默認源圖截取的區域 if (w / h > 1.5) { setHeight = h; setWidth = parseInt(280 / 220 * h); } else if (w / h < 1) { setWidth = w; setHeight = parseInt(220 / 280 * w); } else { setHeight = h; setWidth = w; }; console.log(setWidth, setHeight) ctx.drawImage(res.path, 0, 0, setWidth, setHeight, 20, 50, 280, 220); ctx.draw(true); }, fail: function (res) { //失敗回調 } });
在開發過程中如果封面圖無法按照約定的比例(280x220)給到:
那么我們就需要處理默認封面圖過大或者過小的問題,大致思路是:代碼中通過比較縱橫比(280/220=1.27)正比例放大或者縮小原圖,然后從左上切割,竟可能保證過高的圖是寬度100%,過寬的圖是高度100%。
在canvas中draw圖片,必須是一個(相對)本地路徑,我們可以通過將圖片保存在本地后生成的臨時路徑。
微信官方提供兩個API:
wx.downloadFile(OBJECT)和wx.getImageInfo(OBJECT)。都需先配置download域名才能生效。
ctx.save(); //保存畫圖板 ctx.beginPath()//開始創建一個路徑 ctx.arc(35, 25, 15, 0, 2 * Math.PI, false)//畫一個圓形裁剪區域 ctx.clip()//裁剪 ctx.closePath(); ctx.drawImage(headImageLocal, 20, 10, 30, 30); ctx.draw(true); ctx.restore()//恢復之前保存的繪圖上下文
使用圖形上下文的不帶參數的clip()方法來實現Canvas的圖像裁剪功能。該方法使用路徑來對Canvas話不設置一個裁剪區域。因此,必須先創建好路徑。創建完整后,調用clip()方法來設置裁剪區域。
需要注意的是裁剪是對畫布進行的,裁切后的畫布不能恢復到原來的大小,也就是說畫布是越切越小的,要想保證最后仍然能在canvas最初定義的大小下繪圖需要注意save()和restore()。畫布是先裁切完了再進行繪圖。并不一定非要是圖片,路徑也可以放進去~
ctx.setFillStyle("#fff"); ctx.fillRect(0, 0, 320, 500); //第一個填充矩形 wx.downloadFile({ url: headUri, success(res) { ctx.beginPath() ctx.arc(50, 50, 25, 0, 2 * Math.PI) ctx.clip() ctx.drawImage(res.tempFilePath, 25, 25); //第二個填充圖片 ctx.draw() ctx.restore() ctx.setFillStyle("#fff"); ctx.fillRect(0, 0, 320, 500); ctx.draw(true) ctx.restore() } })
clip裁切這個功能,如果有超過一張圖片/背景疊加,則裁切效果失效。
錯誤參考:http://html51.com/info-38753-1/
wx.canvasToTempFilePath({ fileType: "jpg", canvasId: "customCanvas", success: (res) => { console.log(res.tempFilePath) //為canvas的虛擬地址 } }) res: { errMsg: "canvasToTempFilePath:ok", tempFilePath: "http://tmp/wx02935bb29080a7b4.o6zAJswFAuZuKQ5NZfPr….cGnD1a02PlVC0b3284be3a41d08986c2477579a5fd8e.jpg" }
這里需要把canvas里面的內容,導出成一個臨時地址才能保存在相冊,比如:
http://tmp/wx02935bb29080a7b4...
wx.getSetting({ success(res) { console.log(res) if (!res.authSetting["scope.writePhotosAlbum"]) { //判斷權限 wx.authorize({ //獲取權限 scope: "scope.writePhotosAlbum", success() { console.log("授權成功") //轉化路徑 self.saveImg(); } }) } else { self.saveImg(); } } })
判斷是否有訪問相冊的權限,如果沒有,則請求權限。
六、保存到用戶手機本地相冊wx.saveImageToPhotosAlbum({ filePath: res.tempFilePath, success: function (data) { wx.showToast({ title: "保存到系統相冊成功", icon: "success", duration: 2000 }) }, fail: function (err) { console.log(err); if (err.errMsg === "saveImageToPhotosAlbum:fail auth deny") { console.log("當初用戶拒絕,再次發起授權") wx.openSetting({ success(settingdata) { console.log(settingdata) if (settingdata.authSetting["scope.writePhotosAlbum"]) { console.log("獲取權限成功,給出再次點擊圖片保存到相冊的提示。") } else { console.log("獲取權限失敗,給出不給權限就無法正常使用的提示") } } }) } else { wx.showToast({ title: "保存失敗", icon: "none" }); } }, complete(res) { console.log(res); } })
保存到本地需要一定的時間,需要加一個loading的狀態。
七、關于組件中引用canvaslet ctx = wx.createCanvasContext("posterCanvas",this); //需要加this
在components中canvas無法選中的問題:
在components自定義組件下,當前組件實例的this,表示在這個自定義組件下查找擁有 canvas-id 的
如果有什么疑問或者糾錯可以在下面給智酷君留言。
如果智酷君的分享能夠幫助到你,或者想持續獲得最新的全棧攻略
可以在segmentfault關注我,或在VX搜索“ Geek_Club ”或者“ 智酷方程式 ”
掃描關注公眾號
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/109772.html
摘要:組件模板與組件數據結合后生成的節點樹,將被插入到組件的引用位置上。事件用于子組件向父組件傳遞數據,可以傳遞任意數據。官方文檔往期回顧填坑手冊小程序生成海報一拆彈時刻小程序生成海報二 showImg(https://user-gold-cdn.xitu.io/2019/6/19/16b6e94bcde767a1?w=1069&h=652&f=jpeg&s=120912); 小程序目錄結構...
摘要:發帖的功能只要理清思路,其實并不復雜,利用機器做內容審查是關鍵,直接關系到小程序的整體安全。內容檢查重點由于內容安全對于小程序運營至關重要,稍有不慎就容易導致小程序被封,所以在這塊的校驗除了常規人工檢查外,我們還可以用到微信的內容安全。 showImg(https://segmentfault.com/img/remote/1460000019955210?w=658&h=440); ...
摘要:往期回顧打怪升級小程序評論回復和發貼功能實戰二填坑手冊小程序生成海報一拆彈時刻小程序生成海報二填坑手冊小程序目錄結構和組件使用心得 showImg(https://segmentfault.com/img/remote/1460000019733090?w=818&h=516); 在學習成長的過程中,常常會遇到一些自己從未接觸的事物,這就好比是打怪升級,每次打倒一只怪,都會獲得經驗,讓...
摘要:注意如果用戶一開始沒有微信授權,生成海報時又必須要用戶頭像不能使用默認的話,那就只能老老實實走之前的流程了。組件名稱終端類型微信版本觸發方法關于的調用方法相冊權限需要你提供保存相冊權限獲取相冊權限成功,給出再次點擊圖片保存到相冊的提示。 showImg(https://segmentfault.com/img/bVbs5V8?w=343&h=517);海報生成示例 海報生成速度緩慢...
摘要:全屏蒙版彈窗遮不住的層級還是很高的,當出現全屏蒙版彈窗時,是無法蓋住的,可以調用微信的,不過需要注意兼容低版本在類設置的顏色并沒有變化。 從6月份開始到現在,寫小程序將近4個月了開發時給自己埋了不少坑~給大家分享下我的填坑經驗~~ 開發部分 1.小程序的組件修改不能觸發頁面刷新?需要在父級文件上保存下才會觸發(使用wepy開發) 2.接口請求出現的問題?記得勾選調試開發工具上 不校驗...
閱讀 2721·2021-11-17 17:01
閱讀 2098·2021-09-28 09:35
閱讀 3606·2021-09-01 11:04
閱讀 874·2020-06-22 14:41
閱讀 2990·2019-08-30 15:55
閱讀 2600·2019-08-30 15:43
閱讀 2328·2019-08-26 13:54
閱讀 2522·2019-08-26 13:48