摘要:圖片數(shù)據(jù)繪制到先構(gòu)造對象,為,圖片之后繪制到的圖片文件數(shù)據(jù)繪制到還是先轉(zhuǎn)換成一個,然后構(gòu)造對象,為,圖片之后繪制到利用上面的函數(shù),由對象得到格式的,再參考圖片數(shù)據(jù)繪制到轉(zhuǎn)換為對象并使用發(fā)送轉(zhuǎn)換為對象后,可以使用上傳圖像文件。
實現(xiàn)功能和適用業(yè)務(wù)
采集本地攝像頭獲取攝像頭畫面,拍照保存,上傳服務(wù)器;
前端上傳圖片處理,展示,縮小,裁剪,上傳服務(wù)器
實現(xiàn)步驟調(diào)取本地攝像頭(getUserMedia)/上傳圖片,將圖片/視頻顯示在瀏覽器上
拍照/轉(zhuǎn)換 將視頻拍照或是將圖片展示在canvas中
將canvas中的圖像,轉(zhuǎn)換成圖片格式(png,jpg等)上傳到服務(wù)器
上述兩種方式涉及到的格式轉(zhuǎn)換分別為:
獲取攝像頭: 攝像頭視頻流(blob)-> canvas 圖像 -> blob 圖片 上傳服務(wù)器
圖片上傳: 上傳的圖片(file) -> base64圖片 -> canvas 圖像 -> blob 圖片 上傳服務(wù)器
具體獲取攝像頭的方法可以參考:https://segmentfault.com/a/11...
var dataurl = canvas.toDataURL("image/png"); var dataurl2 = canvas.toDataURL("image/jpeg", 0.8);File對象轉(zhuǎn)換為dataURL、Blob對象轉(zhuǎn)換為dataURL
File對象也是一個Blob對象,二者的處理相同。
function readBlobAsDataURL(blob, callback) { var a = new FileReader(); a.onload = function(e) {callback(e.target.result);}; a.readAsDataURL(blob); } //example: readBlobAsDataURL(blob, function (dataurl){ console.log(dataurl); }); readBlobAsDataURL(file, function (dataurl){ console.log(dataurl); });dataURL圖片數(shù)據(jù)繪制到canvas
先構(gòu)造Image對象,src為dataURL,圖片onload之后繪制到canvas
var img = new Image(); img.onload = function(){ canvas.drawImage(img); }; img.src = dataurl;File,Blob的圖片文件數(shù)據(jù)繪制到canvas
還是先轉(zhuǎn)換成一個url,然后構(gòu)造Image對象,src為dataURL,圖片onload之后繪制到canvas
利用上面的 readBlobAsDataURL 函數(shù),由File,Blob對象得到dataURL格式的url,再參考 dataURL圖片數(shù)據(jù)繪制到canvas
readBlobAsDataURL(file, function (dataurl){ var img = new Image(); img.onload = function(){ canvas.drawImage(img); }; img.src = dataurl; });Canvas轉(zhuǎn)換為Blob對象并使用Ajax發(fā)送
轉(zhuǎn)換為Blob對象后,可以使用Ajax上傳圖像文件。
先從canvas獲取dataurl, 再將dataurl轉(zhuǎn)換為Blob對象
var dataurl = canvas.toDataURL("image/png"); var blob = dataURLtoBlob(dataurl); //使用ajax發(fā)送 var fd = new FormData(); fd.append("image", blob, "image.png"); var xhr = new XMLHttpRequest(); xhr.open("POST", "/server", true); xhr.send(fd);Canvas 轉(zhuǎn)換成 Blob格式
可以通過 Canvas.toDataUrl 轉(zhuǎn)換成 DataUrl(base64) 再轉(zhuǎn)成 blob
可以直接轉(zhuǎn)成blob,可以通過canvas.toBlob轉(zhuǎn)換。然toBlob方法的瀏覽器兼容性不是很好,存在兼容性問題,幸運的是已有前人封裝好了toblob方法,直接拿來用就好了,適用于pc端和移動端
地址:https://github.com/qiyubu/Jav...
具體過程和相關(guān)參考資料:
http://www.zhangxinxu.com/wor...
http://blog.csdn.net/cuixipin...
https://segmentfault.com/a/11...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90449.html
摘要:圖片數(shù)據(jù)繪制到先構(gòu)造對象,為,圖片之后繪制到的圖片文件數(shù)據(jù)繪制到還是先轉(zhuǎn)換成一個,然后構(gòu)造對象,為,圖片之后繪制到利用上面的函數(shù),由對象得到格式的,再參考圖片數(shù)據(jù)繪制到轉(zhuǎn)換為對象并使用發(fā)送轉(zhuǎn)換為對象后,可以使用上傳圖像文件。 實現(xiàn)功能和適用業(yè)務(wù) 采集本地攝像頭獲取攝像頭畫面,拍照保存,上傳服務(wù)器; 前端上傳圖片處理,展示,縮小,裁剪,上傳服務(wù)器 實現(xiàn)步驟 調(diào)取本地攝像頭(get...
摘要:主要部分如下瀏覽器調(diào)用攝像頭拍照瀏覽器調(diào)用攝像頭需要全新的對象,,通過此接口,可以調(diào)用攝像頭和麥克風(fēng),調(diào)用時需要用戶授權(quán)方可開啟。該方法參數(shù)為,返回值為一個標準對象。 標題為最近遇到的一個實際要求,題目很簡單,做起來挺費心費力。因為兼容性及潛在問題,目前單純做到desktop chrome only。參考資料多見于 http://www.html5rocks.com/zh/tutori...
摘要:失敗回調(diào)函數(shù)的參數(shù),可能的異常有硬件問題用戶拒絕了當前的瀏覽器實例的訪問請求或者用戶拒絕了當前會話的訪問或者用戶在全局范圍內(nèi)拒絕了所有媒體訪問請求。 getUserMedia API簡介 HTML5的getUserMedia API為用戶提供訪問硬件設(shè)備媒體(攝像頭、視頻、音頻、地理位置等)的接口,基于該接口,開發(fā)者可以在不依賴任何瀏覽器插件的條件下訪問硬件媒體設(shè)備。 getUserM...
摘要:失敗回調(diào)函數(shù)的參數(shù),可能的異常有硬件問題用戶拒絕了當前的瀏覽器實例的訪問請求或者用戶拒絕了當前會話的訪問或者用戶在全局范圍內(nèi)拒絕了所有媒體訪問請求。 getUserMedia API簡介 HTML5的getUserMedia API為用戶提供訪問硬件設(shè)備媒體(攝像頭、視頻、音頻、地理位置等)的接口,基于該接口,開發(fā)者可以在不依賴任何瀏覽器插件的條件下訪問硬件媒體設(shè)備。 getUserM...
閱讀 2134·2019-08-29 16:53
閱讀 2709·2019-08-29 16:07
閱讀 2052·2019-08-29 13:13
閱讀 3274·2019-08-26 13:57
閱讀 1340·2019-08-26 13:31
閱讀 2444·2019-08-26 13:22
閱讀 1231·2019-08-26 11:43
閱讀 2094·2019-08-23 17:14