主頁 > 知識(shí)庫 > Canvas實(shí)現(xiàn)保存圖片到本地的示例代碼

Canvas實(shí)現(xiàn)保存圖片到本地的示例代碼

熱門標(biāo)簽:南寧點(diǎn)撥外呼系統(tǒng)哪家公司做的好 成都智能外呼系統(tǒng)平臺(tái) 黃島區(qū)地圖標(biāo)注 鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 四川點(diǎn)撥外呼系統(tǒng) 電銷機(jī)器人電話用什么卡 當(dāng)涂高德地圖標(biāo)注 江蘇智能電銷機(jī)器人哪家好 云南大理400電話申請(qǐng)官方

一、簡介

需求: 將HTML5的內(nèi)容保存為圖片
思路: 通過Canvas繪圖生成base64圖片,長按即可保存到本地
問題: canvas禁止跨域、安卓微信長按不能保存base64圖片、服務(wù)器拉取的圖片被壓縮

二、具體問題

問題1:canvas是禁止跨域的,如果圖像來自其他域,調(diào)用toDataURL()會(huì)拋出一個(gè)錯(cuò)誤

解決:<img>標(biāo)簽通過引入 crossorigin 屬性能解決跨域, 即crossOrigin="Anonymous" 或 crossOrigin="*"  請(qǐng)注意手q環(huán)境下設(shè)置 ‘Anonymous’不支持,需要設(shè)置為 '*',如果使用 crossorigin="anonymous",則相當(dāng)于匿名 CORS

問題2:設(shè)置了”crossOrigin”的<img>標(biāo)簽不能拉下跨域的圖片,無法觸發(fā)img.onload

解決: 后臺(tái)轉(zhuǎn)發(fā)或nigix代理,設(shè)置Access-Control-Allow-Origin:“wx.qlogo.cn”,允許靜態(tài)資源服務(wù)器圖片跨域這種設(shè)置 解決獲取圖片跨域的問題。(此處圖片為用戶頭像域名wx.qlogo.cn,存在跨域問題)

問題3:安卓手機(jī)微信h5長按不能保存base64圖片

解決:將canvas繪制的base64圖片上傳到服務(wù)器上,再從服務(wù)器上獲取到png(jpg)圖片。這種做法較麻煩,后面還需要找方法改進(jìn)。

問題4:上傳到服務(wù)器的圖片壓縮嚴(yán)重

解決:上傳的圖片會(huì)在服務(wù)器有幾個(gè)資源,壓縮度不一,從目錄 'http://img10.360buyimg.com/promotepic/' 可拿到像素較清晰的圖片。

問題5:繪制的二維碼鏈接(//wqs.jd.com/xxx)長按不能直接進(jìn)入頁面

解決:指定要繪制的二維碼鏈接一定要加上http: 否則二維碼將識(shí)別為文字

//canvas繪制部分代碼:

var picurl = "http://wx.qlogo.cn/mmopen/OicsrgN57fqDxImI3icnMeSXRfVUQRueHcxRRuWG0O1Ea1bNyBPKKKLeq5FiaXFWOdsltVe1R1PtJ2EtsDHYDjHgQ/0";
   var img = new Image,
    canvas = document.createElement("canvas"),
    ctx = canvas.getContext("2d"),
      //后臺(tái)nigix代理 參見問題2
      src = picurl.replace("http://wx.qlogo.cn","//wq.jd.com");
      //解決 canvas 跨域 toDataURL不能讀取問題 參見問題1
      img.crossOrigin = "Anonymous";
      //圖片資源的預(yù)加載
       img.onload = function() {
             canvas.width = img.width;
            canvas.height = img.height;
             ctx.drawImage( img, 0, 0 );
            //將畫好的base64圖片
             localStorage.setItem( "savedImageData", canvas.toDataURL("image/png") );
      }
       img.src = src;

上傳圖片部分代碼:

// 上傳圖片 參見問題3
$.ajax({
    type: 'POST',
    url:  loadJs.addToken('http://wq.jd.com/activetmp/promotepic/promoteaddpic', "j132"),
    data: {
        filename: new Date().getTime()+''+Math.floor(Math.random()*10000) + '.jpg',
        content: base64pic,
        active: "shotpic20160901"
    },
    dataType: 'json',
    xhrFields: { withCredentials: true },
    success: function(data) {
                           if (picdata.id == 1 && picdata.msg) {
                                    //圖片路徑 此前綴路徑的圖片最清晰 參見問題4
                                    var imgPre = 'http://img10.360buyimg.com/promotepic/';
                                    //圖片地址拼接的完整地址鏈接
                                    var photo = imgPre + picdata.msg;
                                    $("#cardImg")[0].onload = function() {
                                             //to do 業(yè)務(wù)邏輯
                                    };
                                    $("#cardImg").attr("src",photo);
                           }
    },
    error:function(data){
    }
});

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:西寧 佳木斯 十堰 淮安 廣西 咸寧 酒泉 南京

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Canvas實(shí)現(xiàn)保存圖片到本地的示例代碼》,本文關(guān)鍵詞  Canvas,實(shí)現(xiàn),保存,圖片,到,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Canvas實(shí)現(xiàn)保存圖片到本地的示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于Canvas實(shí)現(xiàn)保存圖片到本地的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章