成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

前端圖像處理指南

Anshiii / 1762人閱讀

摘要:本文會介紹位圖處理,矢量圖和圖像處理,重點(diǎn)是,并且最后會附上一個(gè)小應(yīng)用。以上列舉部分,更多備胎在此矢量圖處理講完位圖再說矢量圖。矢量圖在繪制圖標(biāo)商業(yè)動畫元素上應(yīng)用非常廣范。

計(jì)算機(jī)圖像處理是一門很成熟的技術(shù),任何一門可操作系統(tǒng)接口的語言都能很輕易的實(shí)現(xiàn)各種處理操作。但是前端限于瀏覽器環(huán)境和接口限制,處理起來會有諸多不便,這里所說的前端圖像處理,是真的指不借助任何后端服務(wù)純前端實(shí)現(xiàn)的圖像處理。本文會介紹canvas位圖處理,SVG矢量圖和CSS3圖像處理,重點(diǎn)是canvas,并且最后會附上一個(gè)TrimPNG小應(yīng)用。

canvas位圖處理

HTML5 canvas為我們提供了一塊畫布,讓前端也有了操作位圖的功能:圖片旋轉(zhuǎn)、縮放、濾鏡、壓縮等都可以通過JS來實(shí)現(xiàn)。

圖像基本處理

通過設(shè)置drawImage參數(shù)可以實(shí)現(xiàn)圖片繪制、縮放、拉伸和裁剪等操作(注意canvas無法繪制體積過大圖片,否則會卡甚至崩掉,大圖可以分塊讀取繪制):

詳細(xì)用法參考 drawImage(),DEMO源碼戳這里 JS Bin.

只需要drawImage一個(gè)方法,就可以實(shí)現(xiàn)基本圖形處理功能,再結(jié)合鼠標(biāo)或滾輪事件,就可以實(shí)現(xiàn)更復(fù)雜的局部放大預(yù)覽,縮放等功能了。

圖像濾鏡處理

現(xiàn)在的朋友圈發(fā)個(gè)圖都要用濾鏡美一下,復(fù)古清純膠片LOMO各種風(fēng)格應(yīng)有盡有。canvas提供了getImageData方法來獲取圖像上每一個(gè)像素點(diǎn)的RGBA信息,這樣我們就能對圖片進(jìn)行像素級處理了。通過特定算法來重寫imageData中的像素信息,然后用setImageData方法把新的數(shù)據(jù)重新繪制在canvas上,這樣就可以實(shí)現(xiàn)圖像濾鏡打碼加特效等一系列功能。

比如我們現(xiàn)在要實(shí)現(xiàn)一個(gè)復(fù)古濾鏡:

// 復(fù)古濾鏡處理算法:獲取每個(gè)像素的RGB信息,并按特定權(quán)重返回其加權(quán)平均值
let sepiaFilter = function(imgData) {
  let d = imgData.data
  for (let i = 0; i < d.length; i += 4) {
    let r = d[i]
    let g = d[i + 1]
    let b = d[i + 2]
    d[i] = (r * 0.393) + (g * 0.769) + (b * 0.189) // red
    d[i + 1] = (r * 0.349) + (g * 0.686) + (b * 0.168) // green
    d[i + 2] = (r * 0.272) + (g * 0.534) + (b * 0.131) // blue
  }
  return imgData
}
//圖像地址必須和當(dāng)前頁面同域,否則會報(bào)cross-origin錯(cuò)誤 
img.src = "/img/[email protected]" 
img.onload = () => {
  ctx.drawImage(img, 0, 0) // 繪制原圖
  let imgData = ctx.getImageData(0, 0, img.width, img.height) // 獲取圖片信息
  ctx.putImageData(sepiaFilter(imgData), 100, 0) // 繪制處理后圖片
}

詳細(xì)用法參考 getImageData() 和 putImageData(),DEMO源碼戳這里 JSFiddle.

濾鏡處理關(guān)鍵在于濾鏡算法,要想寫出更高級的特效需要有計(jì)算機(jī)圖形學(xué)基礎(chǔ),對卷積矩陣、拉普拉斯變換、傅里葉變換等數(shù)學(xué)知識也要了解,這個(gè)坑很大我就不挖了。

圖像base64存儲

加完特效后如果我們想把圖像保存下來,就可以用toDataURL方法來對圖片進(jìn)行格式轉(zhuǎn)換、壓縮存儲了。

// 支持三種文件類型:image/png(默認(rèn)) | image/jpeg | image/webp(僅Chrome)
canvas.toDataURL() // 默認(rèn)存儲為png
// 僅jpeg/webp支持質(zhì)量參數(shù)(0~1,默認(rèn)0.92)
canvas.toDataURL("image/jpeg", 0.1) // 存儲為質(zhì)量為0.1的jpeg

由于存儲形式是base64編碼,原來圖片的每三個(gè)字節(jié)都會被擴(kuò)展成4字節(jié),所以整體上編碼后數(shù)據(jù)會比原來多約1/3。以下是通過toDataURL存儲后的圖片和原圖大小相關(guān)對比數(shù)據(jù)(數(shù)據(jù)僅供參考,不具通用性):

可見存儲后圖片體積并不是原來的4/3,實(shí)際上處理后的圖片都會比原圖大好幾倍,并且不同的圖片增大的體積也是不確定的。如果是要上傳圖片到服務(wù)器,可以把base64轉(zhuǎn)化成Blob二進(jìn)制數(shù)據(jù)壓縮上傳;如果要直接在前端顯示或供用戶下載,jpg還好可以設(shè)置質(zhì)量參數(shù),要是png就沒法壓縮了。

只是用toDataURL還不夠,用戶需要通過手動點(diǎn)擊圖片-右鍵圖片存儲為來保存圖片,如果要實(shí)現(xiàn)點(diǎn)擊下載按鈕自動下載圖片還需要修改圖片類型為octet-stream,然后利用HTML5的download屬性強(qiáng)制讓瀏覽器下載。

詳細(xì)用法參考toDataURL(). 自動下載圖片DEMO源碼快戳我 JSFiddle.

程序員的備胎

有了以上基礎(chǔ),再結(jié)合成熟的圖形處理算法,我們可以完成日常工作中大部分圖像處理需求,以下列出了一些相關(guān)輪子可做備胎。備胎這種東西多多益善,萬一以后用到了呢?

注意:本人很專一。

html2canvas

將web頁面通過canvas來實(shí)現(xiàn)截屏,其原理就是遍歷DOM結(jié)構(gòu)和樣式,然后在canvas中繪制出來,通過toDataURL輸出圖片。但由于canvas圖片的同源策略限制,如果圖片和網(wǎng)站不同源的話會截取不出來的。另外在微信中測試時(shí),即使用同源的圖片截取出來的圖片也有問題,所以要想將其用于生產(chǎn)環(huán)境,還是得看場景,有很多坑要踩。

code-to-image

代碼轉(zhuǎn)圖片工具。有時(shí)候你在不同的平臺寫文章貼代碼,由于不同平臺代碼格式化規(guī)范不一,所以經(jīng)常會出現(xiàn)代碼排版問題,通過這個(gè)工具將代碼轉(zhuǎn)成圖片就可以避免排版問題了。

Cropper

一個(gè)專門用來做圖片裁剪的應(yīng)用。

tracking.js

這是一個(gè)專業(yè)的計(jì)算機(jī)視覺處理JS庫,包含了大量圖形處理算法,可用來做人臉識別,色彩追蹤等酷炫功能。

qrcode2

用JS動態(tài)生成二維碼,這個(gè)庫還是很實(shí)用的,原理就是qrcode算法+canvas繪圖,不支持canvas的用table兼容。

AlloyImage

騰訊出的基于HTML5的專業(yè)級圖像處理開源引擎,功能很強(qiáng)大,簡直就是Web版的PS。

以上列舉部分,更多備胎在此: https://github.com/0326/canvas

SVG矢量圖處理

講完位圖再說矢量圖。矢量圖在繪制圖標(biāo)、商業(yè)LOGO、動畫元素上應(yīng)用非常廣范。Web最開始支持的矢量圖形并不是現(xiàn)在的SVG,而是微軟主推的VML,所以在低版本IE下面只支持VML而不支持SVG,直到后來SVG成為W3C標(biāo)準(zhǔn)并被普及,微軟才在IE9中支持SVG。

SVG遵循XML規(guī)范,可以很好的集成在HTML里面,同時(shí)支持JS腳本控制,還有基于SMIL標(biāo)準(zhǔn)的動態(tài)內(nèi)容支持,做起動畫來也是非常方便。目前基于SVG的JS圖形庫輪子也是非常多,如svg.js, Snap.svg, Velocity.js, D3.js等等,目前暫無SVG應(yīng)用需求,等用的時(shí)候再翻牌子吧。

CSS圖像處理

如果你的圖像特效只是用來給用戶展示,并不需要存儲的話,可以直接用CSS處理,基本的調(diào)整圖片大小、拉伸、旋轉(zhuǎn)、裁切等操作直接幾個(gè)CSS屬性width/height/skew/rotate/clip-path等就能搞定了。如果想加特效,使用CSS濾鏡Duang的一下就出來了,不需要任何圖形學(xué)基礎(chǔ)和數(shù)學(xué)知識:

詳細(xì)說明見 CSS filter - MDN, DEMO 源碼見JS Bin.

總結(jié)

最后介紹個(gè)小工具TrimPNG。大家都知道TinyPNG可以壓縮PNG, TrimPNG顧名思義就是去除圖片空白和白邊的,實(shí)現(xiàn)了自動摳圖和切圖的功能(logo我是直接抄的TinyPNG,都是熊貓,應(yīng)該不要緊?)

用到的技術(shù)點(diǎn)上面都說到了,裁切實(shí)現(xiàn)原理就是橫向縱向分別掃描兩次像素點(diǎn)陣,找出上下左右最外面的非透明點(diǎn),然后定位出有效圖像區(qū)域。去除白邊算法目前還比較傻逼,只要是接近白色的點(diǎn)都被我干掉了,后面再完善好了 去白邊算法優(yōu)化了一下,采用標(biāo)記清除策略(聽著耳熟吧,其實(shí)就是從GC受的啟發(fā)...),先掃描一遍標(biāo)記出可疑白點(diǎn),然后再掃描一遍,凡是與透明區(qū)域相鄰的可疑白點(diǎn)就清除,當(dāng)然這個(gè)算法也比較死,如果有更專業(yè)更智能的請務(wù)必告訴我。

體驗(yàn)地址:http://quanfeng.tech/trimpng/

本文只拋磚,作為工作時(shí)技能儲備,如有任何補(bǔ)充歡迎留言交流~,另外,你們這幫人吶,都收藏了就順便點(diǎn)個(gè)推薦尼!⊙ o ⊙

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/115494.html

相關(guān)文章

  • 前端芝士樹】IE 靜態(tài)頁兼容指南

    摘要:靜態(tài)頁兼容指南下的網(wǎng)頁字符亂碼問題原因這個(gè)可能是網(wǎng)頁沒有設(shè)置編碼造成。圖標(biāo)會瞬間顯示出來,但是卻沒有動畫或者過渡效果。問題解析暫時(shí)理解為的不支持的改變,直接操作會破壞動畫。如果在兩個(gè)屬性的操作中間插入操作,線程在處理的時(shí)候?qū)错樞驁?zhí)行。 IE 靜態(tài)頁兼容指南 1. IE 下的網(wǎng)頁字符亂碼 問題原因: 這個(gè)可能是網(wǎng)頁沒有設(shè)置 meta charset 編碼造成。 解決方法: 添加如下代...

    beita 評論0 收藏0
  • 前端芝士樹】IE 靜態(tài)頁兼容指南

    摘要:靜態(tài)頁兼容指南下的網(wǎng)頁字符亂碼問題原因這個(gè)可能是網(wǎng)頁沒有設(shè)置編碼造成。圖標(biāo)會瞬間顯示出來,但是卻沒有動畫或者過渡效果。問題解析暫時(shí)理解為的不支持的改變,直接操作會破壞動畫。如果在兩個(gè)屬性的操作中間插入操作,線程在處理的時(shí)候?qū)错樞驁?zhí)行。 IE 靜態(tài)頁兼容指南 1. IE 下的網(wǎng)頁字符亂碼 問題原因: 這個(gè)可能是網(wǎng)頁沒有設(shè)置 meta charset 編碼造成。 解決方法: 添加如下代...

    SwordFly 評論0 收藏0
  • 【譯】前端練級攻略

    摘要:由于系統(tǒng)變得越來越復(fù)雜,人們提出了稱為預(yù)處理器和后處理器的工具來管理復(fù)雜性。后處理器在由預(yù)處理器手寫或編譯后對應(yīng)用更改。我之前建議的文章,,也涵蓋了預(yù)處理器相關(guān)的知識。 譯者:前端小智 原文:medium.freecodecamp.org/from-zero-t… medium.freecodecamp.org/from-zero-t… 我記得我剛開始學(xué)習(xí)前端開發(fā)的時(shí)候。我看到了很多文章及...

    wuyumin 評論0 收藏0
  • 庫&插件&框架&工具

    摘要:一些有用的一些有用的,包括轉(zhuǎn)換小箭頭三角形媒體查詢等中文指南是當(dāng)下最熱門的前端資源模塊化管理和打包工具。 nodejs 入門 nodejs 入門教程,大家可以在 github 上提交錯(cuò)誤 2016 年最好用的表單驗(yàn)證庫 SMValidator.js 前端表單驗(yàn)證工具分享 淺談前端線上部署與運(yùn)維 說到前端部署,可能大多數(shù)前端工程師在工作中都是使用的公司現(xiàn)成的部署系統(tǒng),與SRE對接、一起完...

    Codeing_ls 評論0 收藏0
  • 庫&插件&框架&工具

    摘要:一些有用的一些有用的,包括轉(zhuǎn)換小箭頭三角形媒體查詢等中文指南是當(dāng)下最熱門的前端資源模塊化管理和打包工具。 nodejs 入門 nodejs 入門教程,大家可以在 github 上提交錯(cuò)誤 2016 年最好用的表單驗(yàn)證庫 SMValidator.js 前端表單驗(yàn)證工具分享 淺談前端線上部署與運(yùn)維 說到前端部署,可能大多數(shù)前端工程師在工作中都是使用的公司現(xiàn)成的部署系統(tǒng),與SRE對接、一起完...

    xiaowugui666 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<