javascript - canvas畫圖
問題描述
寫了一個函數,第一次調用canvas的drawImage將本地的一張圖片的一部分給畫下來(能夠成功),然后將canvas畫好的這張圖調用toDataURL轉化為image對象的src屬性,然后對這張canvas畫的圖調用同樣的方法進行二次繪畫為什么不能成功?
function paint(img) {var canvas = document.createElement(’canvas’)canvas.width = 400canvas.height = 400var ctx = canvas.getContext(’2d’)ctx.drawImage(img, 0, 0, img.width, img.height, 0, 0, 400, 400)document.body.appendChild(canvas)//畫好的第一個canvas對象可以正常顯示var newImg = new Image()newImg.src = canvas.toDataURL()newImg.onload = function() { var canvas2 = document.createElement(’canvas’) canvas2.width = 200 canvas2.height = 200 var ctx2 = canvas2.getContext(’2d’) ctx2.drawImage(newImg, 0, 0, Math.abs(posX), Math.abs(posY), 0, 0, 200, 200)//這里之所以把第一次的canvas作圖加載成一張圖片,是因為不知道canvas可不可以繪制canvas document.body.appendChild(newImg)//這張圖片能正常顯示 document.body.appendChild(canvas2)//canvas元素加上了,但是繪圖不成功} }
問題解答
回答1:你是不是用的外站圖片? 如果是,需要給圖片加上 crossOrigin='Anonymous' 屬性。
html方式
<img src='http://www.aoyou183.cn/wenda/...' crossOrigin='Anonymous' />
js方式
var image = new Image();image.src = 'http://www.aoyou183.cn/wenda/...';image.crossOrigin = 'Anonymous';
你可以在線把玩一下我用你的代碼修改的可運行的版本:https://jsfiddle.net/5g9n9esk/
相關文章:
1. java - 阿里的開發手冊中為什么禁用map來作為查詢的接受類?2. apache - 想把之前寫的單機版 windows 軟件改成網絡版,讓每個用戶可以注冊并登錄。類似 qq 的登陸,怎么架設服務器呢?3. 創建mysqli對象與數據庫連接 - 出錯4. 用Html5怎么實現簡單選擇排序?5. node.js - win7下,npm 無法下載依賴包,淘寶鏡像也裝不上,求幫忙???6. mysql 的datadir設置的文件夾不存在,啟動了mysql服務后創建的數據庫存在哪里?7. mysql 使用group_concat后 順序改變是怎么回事?8. python - uwsgi+django的搭建問題9. php多任務倒計時求助10. 如何合并兩張具有相同結構的mysql表
