使用canvas怎么生成帶二維碼的海報(bào)

今天就跟大家聊聊有關(guān)使用canvas怎么生成帶二維碼的海報(bào),可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

為南芬等地區(qū)用戶(hù)提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及南芬網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、南芬網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專(zhuān)業(yè)、用心的態(tài)度為用戶(hù)提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶(hù)的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

圖片不顯示

  • 繪制渲染的時(shí)候圖像不顯示:是因?yàn)閳D片異步加載,所以canvas的操作需要放在onload事件中,否則圖片會(huì)不顯示,因?yàn)閳D片不止一張,建議放在promise中,用async,await調(diào)用

  • canvas最終生成圖片分享出去,生成的圖片不顯示:是因?yàn)閳D像跨域問(wèn)題,設(shè)置img的attr,‘crossOrigin'為'Anonymous'就好了,但是要注意,如果不小心為base64也設(shè)置了這個(gè)參數(shù),在低版本的安卓(我出現(xiàn)問(wèn)題是在華為安卓4.4.2中)base64就不會(huì)顯示。

圖像模糊

一開(kāi)始對(duì)安卓機(jī)型統(tǒng)一做了dpr=1的處理,結(jié)果安卓機(jī)上圖片非常的模糊,圓角頭像鋸齒嚴(yán)重,網(wǎng)上的解決方法無(wú)一成功,后來(lái)還是將dpr設(shè)為window.devicePixelRatio就好了,只是圖片的寬高最好設(shè)置為固定值,根據(jù)flexble自適應(yīng)

部分代碼示例

// 頭像;
const imgAvadar = await promiseLoadImg(this.userInfoExternal.headUrl);
const imgSize = 40 * this.dpr;
const imgPos = 24 * this.dpr;

ctx.arc((this.canvas.width / 2), (imgPos + (imgSize / 2)), (imgSize / 2), 0, 2 * Math.PI);
ctx.clip();
ctx.drawImage(imgAvadar, ((this.canvas.width / 2) - (imgSize / 2)), imgPos, imgSize, imgSize);
new Promise(resolve => {
    const img = new Image();
    // base64添加了以下跨域配置,在低版本安卓中會(huì)不顯示圖片
    if (src.indexOf('base64,') === -1) {
        img.setAttribute('crossOrigin', 'Anonymous');
    }
    img.onload = function () {
        resolve(img);
    };
    img.src = src;
});

看完上述內(nèi)容,你們對(duì)使用canvas怎么生成帶二維碼的海報(bào)有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

本文名稱(chēng):使用canvas怎么生成帶二維碼的海報(bào)
網(wǎng)頁(yè)網(wǎng)址:http://muchs.cn/article0/jopgio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、云服務(wù)器軟件開(kāi)發(fā)、網(wǎng)站策劃、關(guān)鍵詞優(yōu)化、全網(wǎng)營(yíng)銷(xiāo)推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)