javascript 圖像二值化處理

代碼

<!DOCTYPE html>
<html>

<head>
    <title></title>
</head>

<body>
    <canvas id="canvas" onclick="showInfo()"></canvas>
    <img id="img" src="1.jpg" width="300" height="200" hidden>
    <script>
    window.onload = function() {
        var canvas = document.getElementById('canvas');
        var img = document.getElementById('img');
        var c = canvas.getContext('2d');
        canvas.width = img.width;
        canvas.height = img.height;

        c.drawImage(img, 0, 0, canvas.width, canvas.height);

        this.showInfo = function() {
            var imgData = c.getImageData(0, 0, canvas.width, canvas.height);
            var index = 255/2;//閾值
            for (var i = 0; i < imgData.data.length; i += 4) {
                var R = imgData.data[i]; //R(0-255)
                var G = imgData.data[i + 1]; //G(0-255)
                var B = imgData.data[i + 2]; //B(0-255)
                var Alpha = imgData.data[i + 3]; //Alpha(0-255)
                var sum = (R + G + B) / 3;
                if (sum > index) {
                    imgData.data[i] = 255;
                    imgData.data[i + 1] = 255;
                    imgData.data[i + 2] = 255;
                    imgData.data[i + 3] = Alpha;
                } else {
                    imgData.data[i] = 0;
                    imgData.data[i + 1] = 0;
                    imgData.data[i + 2] = 0;
                    imgData.data[i + 3] = Alpha;
                }
            }
            c.putImageData(imgData, 0, 0);
        }
    }
    </script>
</body>

</html>

處理前

處理前

處理后

處理后

記得在服務(wù)器端中運(yùn)行,不然會(huì)有跨域問(wèn)題,推薦使用Node的http-server,使用比較方便

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,697評(píng)論 19 139
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,351評(píng)論 25 708
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類相關(guān)的語(yǔ)法,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚_t_閱讀 34,853評(píng)論 18 399
  • 三千白發(fā)絲,白了少女頭,直到遇上汝麗多烏發(fā)粉,才從新讓我的白發(fā)轉(zhuǎn)黑發(fā),本以為今生不再奢望,然而黑發(fā)再次回到我的生活...
    怎樣去掉牙齒上的黃閱讀 980評(píng)論 0 0
  • 享樂(lè),極度的享樂(lè)。 李吉今年十九歲,他在十七歲時(shí),就已輟學(xué)了。說(shuō)來(lái)在外打工已經(jīng)兩年了。這個(gè)春節(jié),他例行回家。 李吉...
    南極的狗閱讀 570評(píng)論 0 0

友情鏈接更多精彩內(nèi)容