<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Javascript圖像處理—亮度對比度應用案例_基礎知識

        來源:懂視網 責編:小采 時間:2020-11-27 21:06:31
        文檔

        Javascript圖像處理—亮度對比度應用案例_基礎知識

        Javascript圖像處理—亮度對比度應用案例_基礎知識:前言 上一篇文章,我們講解了圖像處理中的卷積操作和平滑(也就是模糊)處理,這篇文章我們進行亮度和對比度的變化。 其實,亮度是啥玩意? 亮度就是比較亮眼咯…… 實際上對于RGBA顏色空間,變亮其實就等于R、G、B三個通道同時加大,那么變暗就等于同時減小
        推薦度:
        導讀Javascript圖像處理—亮度對比度應用案例_基礎知識:前言 上一篇文章,我們講解了圖像處理中的卷積操作和平滑(也就是模糊)處理,這篇文章我們進行亮度和對比度的變化。 其實,亮度是啥玩意? 亮度就是比較亮眼咯…… 實際上對于RGBA顏色空間,變亮其實就等于R、G、B三個通道同時加大,那么變暗就等于同時減小

        前言

        上一篇文章,我們講解了圖像處理中的卷積操作和平滑(也就是模糊)處理,這篇文章我們進行亮度和對比度的變化。

        其實,亮度是啥玩意?

        亮度就是比較亮眼咯……

        實際上對于RGBA顏色空間,變亮其實就等于R、G、B三個通道同時加大,那么變暗就等于同時減小咯。

        這比較好理解,因為最暗的黑色是RGB(0,0,0),而最亮的白色是RGB(255,255,255)。所以變亮應該RGB各通道都要增大。

        那么,對比度呢?

        對比度,其實就是顏色差啦。

        那么對于RGBA顏色空間,對比度變大其實就等于R、G、B三個通道同時乘以一個比例,因為這樣相近的顏色之間的差距就變大了,那么減小就是同時除以咯。

        舉個例子,原來RGB(23,44,55)和RGB(33,44,55)相差只有10,但是一起乘以2以后,就變成了RGB(46,88,110)和RGB(66,88,110)

        ,相差變成了20了,也就是“顏色差”變大了。

        線性模型

        newRGB = Contrast * RGB + Brightness

        線性模型滿足上述公式,其中 Contrast表示對比度系數,Brightness表示亮度系數。

        線性模型實現比較簡單,但是很容易就調出全白或者全黑的圖片,對于普通用戶來說ContrastBrightness選多少比較好也比較難確定。

        所以,實際上在Photoshop里面使用的并不是線性模型,而是非線性模型。

        非線性模型

        非線性模型中對比度增大和閾值Threshold有關:

        當Contrast >= 0時:

        newRGB = RGB + (RGB - Threshold) * (1 / (1 - Contrast / 255) - 1)

        當Contrast < 0時:

        newRGB = RGB + (RGB - Threshold) * Contrast / 255

        那么當對比度和亮度同時調整時候呢?

        如果對比度大于0,先調整亮度,再調整對比度;當對比度小于0時,則相反,先調整對比度,再調整亮度。

        最后一個問題,閾值Threshold到底是什么,其實這個是圖片的灰度平均值。

        實現代碼
        代碼如下:
        var brightnessContrast = function(__src, __brightness, __contrast){
        __src || error(arguments.callee, IS_UNDEFINED_OR_NULL/* {line} */);
        if(__src.type === "CV_RGBA"){
        var sData = __src.data,
        width = __src.col,
        height = __src.row,
        dst = new Mat(height, width, CV_RGBA),
        dData = dst.data,
        brightness = Math.max(-255, Math.min(255, __brightness || 0)),
        contrast = Math.max(-255, Math.min(255, __contrast || 0));

        var gray = cvtColor(__src, CV_RGBA2GRAY),
        allValue = 0,
        gData = gray.data;
        var y, x, c;

        for(y = height; y--;){
        for(x = width; x--;){
        allValue += gData[y * width + x];
        }
        }

        var r, g, b, offset, gAverage = (allValue / (height * width)) | 0;

        for(y = height; y--;){
        for(x = width; x--;){
        offset = (y * width + x) * 4;
        dData[offset] = sData[offset] + brightness;
        dData[offset + 1] = sData[offset + 1] + brightness;
        dData[offset + 2] = sData[offset + 2] + brightness;

        if(contrast >= 0){
        for(c = 3; c--;){
        if(dData[offset + c] >= gAverage){
        dData[offset + c] = dData[offset + c] + (255 - gAverage) * contrast / 255;
        }else{
        dData[offset + c] = dData[offset + c] - (gAverage * contrast / 255);
        }
        }
        }else{
        dData[offset] = dData[offset] + (dData[offset] - gAverage) * contrast / 255;
        dData[offset + 1] = dData[offset + 1] + (dData[offset + 1] - gAverage) * contrast / 255;
        dData[offset + 2] = dData[offset + 2] + (dData[offset + 2] - gAverage) * contrast / 255;
        }

        dData[offset + 3] = 255;
        }
        }
        }else{
        error(arguments.callee, UNSPPORT_DATA_TYPE/* {line} */);
        }
        return dst;
        };

        效果

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Javascript圖像處理—亮度對比度應用案例_基礎知識

        Javascript圖像處理—亮度對比度應用案例_基礎知識:前言 上一篇文章,我們講解了圖像處理中的卷積操作和平滑(也就是模糊)處理,這篇文章我們進行亮度和對比度的變化。 其實,亮度是啥玩意? 亮度就是比較亮眼咯…… 實際上對于RGBA顏色空間,變亮其實就等于R、G、B三個通道同時加大,那么變暗就等于同時減小
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产卡一卡二卡三免费入口| 在线观看黄片免费入口不卡| 亚洲一区二区三区免费视频| 亚洲AV无码国产丝袜在线观看| 亚洲一区二区三区免费| 免费99精品国产自在现线| 亚洲AV综合色区无码一区| 免费精品视频在线| 99热精品在线免费观看| 亚洲色四在线视频观看| a级毛片无码免费真人久久| av在线亚洲欧洲日产一区二区| 免费人成在线观看播放a| 国产小视频在线观看免费| 亚洲欧美日本韩国| 免费精品无码AV片在线观看| 亚洲黑人嫩小videos| 日本一卡精品视频免费| 久久亚洲精精品中文字幕| 老汉精品免费AV在线播放| 亚洲黄色网站视频| 亚洲精品国产日韩无码AV永久免费网| 亚洲乱亚洲乱妇无码麻豆| 成人无码精品1区2区3区免费看 | 男女一边桶一边摸一边脱视频免费| 在线A亚洲老鸭窝天堂| 巨胸喷奶水www永久免费| 国产亚洲AV夜间福利香蕉149| 久久久国产精品福利免费| 亚洲欧洲日韩国产综合在线二区| 午夜国产精品免费观看| 久久国产亚洲精品| 亚洲精品在线免费观看视频| 亚洲av无码专区在线观看下载| 亚洲AV中文无码乱人伦在线视色| 免费无码又爽又刺激网站直播| 亚洲成aⅴ人片在线观| 免费观看男人免费桶女人视频| 中文字幕高清免费不卡视频| 亚洲一级毛片中文字幕| 国产一区二区视频免费|