精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

有趣的6種圖片灰度轉換算法

開發 算法
這是一篇很有趣的文章,不僅僅是介紹灰度算法,對了解圖片的處理過程也很有幫助。

 6種圖片灰度轉換算法

【引自楊敬卓的博客】前言

黑白照片的時代雖然已經過去,但現在看到以前的照片,是不是有一種回到過去的感覺,很cool有木有~

看完這篇文章,就可以把彩色照片變成各種各樣的黑白的照片啦。

本文完整的在線例子圖片灰度算法例子,例子的圖片有點多,可能有些慢。

例子的源碼位于blog/demo

三原色與灰度

原色是指不能透過其他顏色的混合調配而得出的“基本色”。一般來說疊加型的三原色是紅色、綠色、藍色,以不同比例將原色混合,可以產生出其他的新顏色。這套原色系統常被稱為“RGB色彩空間”,亦即由紅(R)綠(G)藍(B)所組合出的色彩系統。

當這三種原色以等比例疊加在一起時,會變成灰色;若將此三原色的強度均調至***并且等量重疊時,則會呈現白色。灰度就是沒有色彩,RGB色彩分量全部相等。

獲取圖片的像素數據

算法不區分語言,這里以前端舉例。可以使用canvas取得圖片某個區域的像素數據

  1. //偽代碼 
  2. var img = new Image(); 
  3. img.src = 'xxx.jpg'
  4. var myCanvas = document.querySelector(canvasId); 
  5. var canvasCtx = myCanvas.getContext("2d"); 
  6. canvasCtx.drawImage(img, 0, 0, img.width, img.height); 
  7. //圖片的像素數據 
  8. var data = canvasCtx.getImageData(0, 0, img.width, img.height);  

使用getImageData()返回一個ImageData對象,此對象有個data屬性就是我們要的數據了,數據是以Uint8ClampedArray 描述的一個一維數組,包含以 RGBA 順序的數據,數據使用 0 至 255(包含)的整數表示。 所以,一個像素會有4個數據(RGBA),RGB是紅綠藍,A指的是透明度。

舉個例子:本文720*480的水果圖片,一共有720 * 480 = 259200像素,每個像素又有4個數據,所以數據數組的總長度為259200 * 4 = 1036800。

可以看到圖片的數據很長,如果一次性處理很多圖片的時候,計算量相當可觀,所以例子中會使用worker,把繁重的計算任務交給后臺線程。

算法的基本步驟

  1. 取得每一個像素的red,green,blue值。
  2. 使用灰度算法,算出一個灰度值。
  3. 用這個灰度值代替像素原始的red,green,blue值。

比如我們的灰度算法是:

  1. Gray = (Red + Green + Blue) / 3 

計算過程:

  1. //偽代碼 
  2. for(var Pixel in Image){ 
  3.   var Red = Image[Pixel].Red 
  4.   var Green = Image[Pixel].Green 
  5.   var Blue = Image[Pixel].Blue 
  6.  
  7.   var Gray = (Red + Green + Blue) / 3 
  8.  
  9.   Image[Pixel].Red = Gray 
  10.   Image[Pixel].Green = Gray 
  11.   Image[Pixel].Blue = Gray 
  12.  

很簡單對吧。

很多好吃的鮮艷水果,但是它們馬上要變灰了!!   

 

算法1 - 平均法

使用算法1:   

 

這是最常見的灰度算法,簡單暴力,把它放到***位。公式是:

  1. Gray = (Red + Green + Blue) / 3 

這個算法可以生成不錯灰度值,因為公式簡單,所以易于維護和優化。然而它也不是沒有缺點,因為簡單快速,從人眼的感知角度看,圖片的灰度陰影和亮度方面做的還不夠好。所以,我們需要更復雜的運算。

算法2 - 基于人眼感知

使用算法2:   

 

算法1與算法2生成的圖片似乎沒太大差別,所以增加一個例子,將圖片上半部分用算法1,下半部分用算法2。

上半部分是算法1,下半部分是算法2:   

 

仔細看的話,中間有一根黑線。上半部分(算法1)比下半部分(算法2)更蒼白一些。如果還是看不出來,注意最右邊的檸檬,算法1的檸檬反光更強烈,算法2的檸檬更柔和。

第二種算法考慮到了人眼對不同光感知程度不同。人的眼睛內有幾種辨別顏色的錐形感光細胞,分別對黃綠色、綠色和藍紫色的光最敏感。雖然眼球中的椎狀細胞并非對紅、綠、藍三色的感受度***,但是由肉眼的椎狀細胞所能感受的光的帶寬很大,紅、綠、藍也能夠獨立刺激這三種顏色的受光體。

人類對紅綠藍三色的感知程度依次是: 綠>紅>藍,所以平均算法從這個角度看是不科學的。應該按照人類對光的感知程度為每個顏色設定一個權重,它們的之間的地位不應該是平等的。

一個圖像處理通用的公式是:

  1. Gray = (Red * 0.3 + Green * 0.59 + Blue * 0.11) 

可以看到,每個顏色的系數相差很大。

現在對圖像灰度處理的***公式還存在爭議,有一些類似的公式:

  1. Gray = (Red * 0.2126 + Green * 0.7152 + Blue * 0.0722)  

or 

  1. Gray = (Red * 0.299 + Green * 0.587 + Blue * 0.114)  

它們只是在系數上存在一些偏差,大體的比值差不多。

算法3 - 去飽和

使用算法3:   

 

在說這個算法之前,先說說RGB,大多數程序員都使用RGB模型,每一種顏色都可以由紅綠藍組成,RGB對計算機來說可以很好的描述顏色,但對于人類而言就很難理解了。如果升國旗的時候說,“五星紅旗多么RGB(255, 0, 42)”,可能會被暴打一頓。但我說鮮紅的五星紅旗,老師可能會點頭稱贊。

所以為了更通俗易懂,有時我們選擇HLS模型描述顏色,這三個字母分別表示Hue(色調)、Saturation(飽和度)、Lightness(亮度)。色調,取值為:0 - 360,0(或360)表示紅色,120表示綠色,240表示藍色,也可取其他數值來指定顏色。飽和度,取值為:0.0% - 100.0%,它通常指顏色的鮮艷程度。亮度,取值為:0.0% - 100.0%,黑色的亮度為0。

去飽和的過程就是把RGB轉換為HLS,然后將飽和度設為0。因此,我們需要取一種顏色,轉換它為最不飽和的值。這個數學公式比本文介紹的更復雜,這里提供一個簡單的公式,一個像素可以被去飽和通過計算RGB中的***值和最小值的中間值:

  1. Gray = ( Math.max(Red, Green, Blue) + Math.min(Red, Green, Blue) ) / 2 

去飽和后,圖片立體感減弱,但是更柔和。對比算法2,可以很明顯的看出差異,從效果上看,可能大多數人都喜歡算法2,算法3是目前為止,處理的圖片立體感最弱,最黑暗的。

算法4 - 分解

取***值  

 

取最小值   

 

分解算法可以認為是去飽和更簡單一種的方式。分解是基于每一個像素的,只取RGB的***值或者最小值。

***值分解:

  1. Gray = Math.max(Red, Green, Blue) 

最小值分解:

  1. Gray = Math.min(Red, Green, Blue) 

正如上面展現的,***值分解提供了更明亮的圖,而最小值分解提供了更黑暗的圖。

算法5 - 單一通道

取紅色通道  

 

取綠色通道   

 

取藍色通道  

 

圖片變灰更快捷的方法,這個方法不用做任何計算,取一個通道的值直接作為灰度值。

  1. Gray = Red 

or

  1. Gray = Green 

or

  1. Gray = Blue 

不管相不相信,大多數數碼相機都用這個算法生成灰度圖片。很難預測這種轉換的結果,所以這種算法多用于藝術效果。

算法6 - 自定義灰度陰影

NumberOfShades = 4    

 

這是到目前為止最有趣的算法,允許用戶提供一個灰色陰影值,值的范圍在2-256。2的結果是一張全白的圖片,256的結果和算法1一樣。

NumberOfShades = 16   

 

該算法通過選擇陰影值來工作,它的公式有點復雜

  1. ConversionFactor = 255 / (NumberOfShades - 1) 
  2.  
  3. AverageValue = (Red + Green + Blue) / 3 
  4.  
  5. Gray = Math.round((AverageValue / ConversionFactor) + 0.5) * ConversionFactor  
  • NumberOfShades 的范圍在2-256。
  • 從技術上說,任何灰度算法都可以計算AverageValue,它僅僅提供一個初始灰度的估計值。
  • “+ 0.5” 是一個可選參數,用于模擬四舍五入。

小節

這是一篇很有趣的文章,不僅僅是介紹灰度算法,對了解圖片的處理過程也很有幫助。

責任編輯:龐桂玉 來源: github.com
相關推薦

2020-11-04 09:52:16

Python讀取圖片開發

2024-03-18 09:44:02

HashMap算法Java

2021-05-10 11:53:13

頁面替換算法

2021-09-28 10:32:53

循環類型useEffect

2012-05-28 09:16:12

Java設計模式

2021-06-11 00:11:23

GPS數據協議

2021-11-26 11:07:14

cowsay命令Linux

2021-10-14 06:52:47

算法校驗碼結構

2022-03-10 08:59:59

傅里葉變換算法系統

2019-11-25 14:24:24

機器學習算法數據

2022-07-13 11:49:18

接口遷移方案

2022-03-12 20:12:08

希爾排序數組插入排序

2023-03-26 12:41:46

2024-03-12 12:49:17

Python算法

2014-12-01 09:54:40

JavaScript

2011-05-18 14:33:20

MySQL

2025-04-07 04:20:00

Linux操作系統內存管理

2021-12-03 11:30:58

Python圖片像素風

2014-10-31 10:50:28

Linux命令行工具

2010-08-04 14:17:54

白領
點贊
收藏

51CTO技術棧公眾號

亚洲免费中文字幕| 亚洲国产va精品久久久不卡综合| 国产精品久久久久久久久影视| 午夜激情福利电影| 欧美专区视频| 色综合激情五月| 天天操天天干天天玩| 天堂а√在线8种子蜜桃视频| 日韩av一区二区三区四区| 毛片精品免费在线观看| 国产精品一区二区入口九绯色| 黄色精品视频网站| 欧美日韩国产在线看| 中文字幕av导航| 人成免费电影一二三区在线观看| 激情综合五月婷婷| 情事1991在线| 久久久综合久久久| 久久裸体网站| 亚洲男子天堂网| 亚洲妇女无套内射精| 艳妇乳肉豪妇荡乳av无码福利| 一本到12不卡视频在线dvd| 精品视频一区在线视频| 波多野结衣在线免费观看| 韩国久久久久久| 亚洲线精品一区二区三区| 亚洲欧美日韩综合一区| 日本啊v在线| www.av精品| 99久久精品无码一区二区毛片 | 亚洲精品第二页| 国产日韩在线观看视频| 欧美亚洲动漫另类| 人禽交欧美网站免费| 亚洲精品成人电影| 国产一区二区电影| 91在线直播亚洲| 亚洲中文一区二区三区| 日本视频一区二区三区| 国产91精品久| 国产一区二区99| 99成人在线| 韩剧1988在线观看免费完整版| 69亚洲乱人伦| 2023国产精华国产精品| 日韩精品一区二区三区在线| www.五月天色| 成人综合日日夜夜| 91精品黄色片免费大全| 国产欧美一区二| 91精品麻豆| 欧美一区午夜精品| 女人扒开腿免费视频app| 懂色av色香蕉一区二区蜜桃| 欧美精品一二三| 九一精品久久久| 国产精品一区二区三区四区在线观看| 欧美年轻男男videosbes| 毛片毛片毛片毛片毛片毛片毛片毛片毛片 | 国产无一区二区| 日韩精品久久一区二区三区| 国产粉嫩一区二区三区在线观看| 欧美经典三级视频一区二区三区| 日韩精品一区二区三区丰满| 1024免费在线视频| 成人欧美一区二区三区| 热这里只有精品| 欧美午夜大胆人体| 欧美日韩免费在线| 韩国中文字幕av| 欧美xxxx网站| 日韩欧美电影在线| 亚洲黄色在线网站| 狠狠综合久久av一区二区蜜桃| 日韩中文在线中文网三级| 国产探花在线视频| 黄色另类av| 日本欧美爱爱爱| 亚洲熟女乱色一区二区三区久久久| 久久99精品久久久久久久久久久久| 91丝袜美腿美女视频网站| 成人乱码一区二区三区 | 日韩一区二区视频| 欧美大喷水吹潮合集在线观看| 小嫩嫩12欧美| yw.139尤物在线精品视频| 免费毛片在线播放免费| 亚洲欧美日本日韩| 成人福利网站在线观看11| 亚洲精品福利网站| 亚洲国产成人在线| 欧美日韩激情四射| 日本福利午夜视频在线| 国产精品女主播av| 成人性生活视频免费看| 国产精品亚洲d| 欧美成人aa大片| 少妇愉情理伦三级| 国内精品久久久久久久97牛牛| 国产91色在线播放| 亚洲av无码乱码在线观看性色| 久久久久久久电影| 久久亚洲国产成人精品无码区| 亚洲www.| 337p日本欧洲亚洲大胆精品 | 三级理论午夜在线观看| 亚洲欧洲精品天堂一级| 久久久久狠狠高潮亚洲精品| 嫩呦国产一区二区三区av| 亚洲天堂av在线免费| 久久免费视频播放| 理论片日本一区| 久久久com| 波多野结衣精品| 91精品视频网| 嘿嘿视频在线观看| 亚洲欧美激情诱惑| 好看的日韩精品视频在线| 精品51国产黑色丝袜高跟鞋| 91成人在线精品| 亚洲制服丝袜在线播放| 午夜天堂精品久久久久| 国产欧美精品va在线观看| 男人的天堂在线视频| 偷窥国产亚洲免费视频| 亚洲天堂免费看| 日韩精品中文字幕在线| 午夜精品一区二区三区视频| 日日摸夜夜添夜夜添精品视频| av免费观看久久| 成人ww免费完整版在线观看| 婷婷开心久久网| 中文字幕人妻一区二区三区 | 国产制服91一区二区三区制服| 成人四虎影院| 中国china体内裑精亚洲片| 日韩一区二区视频在线| 99在线视频精品| 国产日本在线播放| 91精品国产自产在线丝袜啪| 欧美激情a在线| 国产高清免费av| 亚洲美女免费在线| 色欲欲www成人网站| 亚洲一区色图| 97久久精品午夜一区二区| 中文字幕免费高清电视剧网站在线观看 | 成人另类视频| 欧美极品美女视频网站在线观看免费| av男人天堂网| 亚洲一区中文在线| 先锋资源av在线| 国产精品三上| 日韩电影免费观看在| jizzyou欧美16| 最新中文字幕亚洲| 国产精品特级毛片一区二区三区| 亚洲女同ⅹxx女同tv| 亚洲妇女无套内射精| 欧美先锋影音| 久久精品国产一区二区三区不卡| 福利影院在线看| 亚洲视频999| 黄色av一区二区| 综合久久久久综合| 毛茸茸free性熟hd| 免费久久99精品国产自在现线| 日韩电影免费观看高清完整| 综合久久av| 亚州成人av在线| 黄上黄在线观看| 在线成人av影院| 国产香蕉在线视频| 老司机久久99久久精品播放免费| 久久久久久国产精品mv| 免费高清视频在线一区| 久久成人18免费网站| 国产18精品乱码免费看| 91久久精品日日躁夜夜躁欧美| 2014亚洲天堂| 不卡的av在线| 国产又大又黄又猛| 在线欧美亚洲| 偷拍视频一区二区| 99re8这里有精品热视频免费| 欧美中文字幕在线观看| 色综合久久影院| 亚洲精品一区二区三区福利| 无码视频在线观看| 亚洲激情一二三区| 亚洲国产天堂av| 国产成人精品1024| 中文字幕永久视频| 国内精品久久久久久久97牛牛 | av漫画在线观看| 秋霞av亚洲一区二区三| av在线观看地址| 日韩黄色大片网站| 国产丝袜不卡| 免费一区二区三区在线视频| 国产mv免费观看入口亚洲| 日本成人不卡| 色哟哟入口国产精品| 天堂网av在线播放| 欧美乱妇20p| 国产原创视频在线| 亚洲一卡二卡三卡四卡无卡久久| 国产一区二区三区四区在线| 99在线视频精品| 一级全黄裸体片| 久久国产综合精品| 亚洲成熟丰满熟妇高潮xxxxx| 欧美涩涩视频| 亚洲欧美一二三| 成人6969www免费视频| 久久久久久欧美精品色一二三四| 亚洲人成777| 国产精品入口福利| 依依综合在线| 国外成人性视频| 国产精品69xx| 欧美另类在线观看| 久久77777| 日韩中文字幕av| 一区二区三区视频网站| 亚洲欧洲中文天堂| 日韩精品视频无播放器在线看| 精品国产在天天线2019| 国产视频一区二区三区四区五区| 欧美视频一区二区三区| 亚洲欧美一二三区| 91九色02白丝porn| 天天爽夜夜爽人人爽| 欧美日韩国产麻豆| 黄网在线观看视频| 黄色成人在线播放| 久久夜色精品亚洲| 欧美日韩精品在线播放| 国产精品免费av一区二区| 亚洲成a人在线观看| 精品无码黑人又粗又大又长| 日韩美女久久久| 国语对白在线播放| 一区二区视频在线| 久久久久久久久久91| 亚洲一区中文在线| 日韩男人的天堂| 日韩欧美在线网址 | 视频一区二区不卡| 国产精品人人妻人人爽人人牛| 久久伊人亚洲| 色悠悠久久综合网| 九一九一国产精品| 亚洲一区二区中文字幕在线观看| 国产一区二区成人久久免费影院| 91丝袜超薄交口足| 高潮精品一区videoshd| 中文字幕在线永久| 久久久久亚洲蜜桃| 国产又黄又粗又猛又爽的| 亚洲麻豆国产自偷在线| 免费三片在线播放| 高跟丝袜欧美一区| 樱花视频在线免费观看 | 人妻无码中文字幕| 日韩精品中文字幕在线| a天堂在线资源| 久久精视频免费在线久久完整在线看| 最爽无遮挡行房视频在线| 国内精品久久久久伊人av| 欧美成人免费电影| 91精品在线观| 狼人精品一区二区三区在线| 日本高清不卡一区二区三| 99久久99热这里只有精品| 先锋影音男人资源| 国产精品综合| 999久久久精品视频| bt欧美亚洲午夜电影天堂| 337人体粉嫩噜噜噜| 一区二区三区不卡视频| 中文字幕黄色片| 91精品国产色综合久久ai换脸| 欧美天堂在线视频| 中文字幕精品在线视频| 啦啦啦中文在线观看日本| 国产精品高潮呻吟久久av黑人| 欧美2区3区4区| 亚洲 国产 欧美一区| 黄色成人av网站| gogogo高清免费观看在线视频| www.66久久| 国产一区二区精彩视频| 日韩欧美高清在线视频| www.亚洲黄色| 中文字幕av一区中文字幕天堂 | 色中色一区二区| a级片在线播放| 一区二区成人av| av成人 com a| 91精品在线观看视频| 国产成人精品免费视| 欧美成人精品免费| 久久aⅴ国产欧美74aaa| 午夜理伦三级做爰电影| 一区二区三区中文在线观看| 国产在线观看第一页| 日韩av中文在线| 色www永久免费视频首页在线| 国产精品视频公开费视频| 日韩av系列| 91黄色在线看| 国产一区二区在线视频| 刘亦菲国产毛片bd| 日韩欧美中文字幕在线观看| 亚洲国产福利视频| 久久精品国产欧美激情| 日本欧美不卡| 欧美亚洲精品日韩| 性8sex亚洲区入口| 精品久久久久久无码人妻| 亚洲欧美电影一区二区| 在线观看毛片视频| 国产性色av一区二区| 综合日韩av| 久久综合久久久| a91a精品视频在线观看| 久久久久无码国产精品一区李宗瑞| ...xxx性欧美| 91丨九色丨丰满| 日韩网站在线观看| 日韩毛片网站| 亚洲一卡二卡三卡四卡无卡网站在线看| 久久精品免费| 性高潮久久久久久久| 色综合天天综合色综合av | 久久综合色之久久综合| 福利一区二区三区四区| 亚洲国产美女久久久久| 99re6在线精品视频免费播放| 99久久精品久久久久久ai换脸| 欧美日本不卡| 最新日本中文字幕| 亚洲国产aⅴ成人精品无吗| 丰满熟妇乱又伦| 91av视频在线免费观看| 欧美日韩一本| 日本女优爱爱视频| 国产精品色哟哟| 国产精品伊人久久| 久精品免费视频| 国产精品色呦| 国产资源在线视频| 久久久久久亚洲综合影院红桃| 天堂网一区二区| 视频在线观看99| 日韩综合一区二区三区| 黄色一级片在线看| 26uuu国产一区二区三区| 波多野结衣视频观看| 综合久久五月天| www.久久热| 免费观看国产精品视频| 国产亚洲精品资源在线26u| 亚洲永久精品视频| 久久久久久欧美| 亚洲品质自拍| 在线不卡一区二区三区| 亚洲制服丝袜在线| 四虎精品在永久在线观看| 国产精品一区av| 欧美日韩精品免费观看视频完整| 精品少妇人妻av一区二区三区| 色综合天天综合给合国产| 免费网站成人| 国产一区二区不卡视频| 天堂精品中文字幕在线| 久久高清内射无套| 日韩黄色高清视频| 色综合视频一区二区三区44| 成人黄色大片网站| 欧美韩国日本不卡| 性一交一乱一精一晶| 国产成人极品视频| 欧美永久精品| 日韩av在线看免费观看| 日韩区在线观看| 精品91久久| 福利在线一区二区| 中文字幕免费不卡在线| 欧美一级淫片aaaaaa| 国产精品人成电影在线观看| 欧美特黄一级| 国产aaaaaaaaa| 日韩精品极品在线观看播放免费视频| 国产精品诱惑| 国产日韩一区二区在线观看| 一个色综合网站| 天堂中文а√在线|