图像灰度化

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>Canvas</title>
        <style type="text/css">
            * {
                /* margin: 0;
                padding: 0; */
                box-sizing: border-box;
            }
            canvas {
                /* border-width: 1px;
                border-color: #000000;
                border-style: solid; */
            }
            input, label {
                cursor: pointer;
            }
        </style>
    </head>
    <body>
        <canvas id="canvas"></canvas>
        <div>
            <input type="radio" id="original" name="color" checked />
            <label for="original">Original</label>
            <input type="radio" id="red" name="color" />
            <label for="red">Red</label>
            <input type="radio" id="green" name="color" />
            <label for="green">Green</label>
            <input type="radio" id="blue" name="color" />
            <label for="blue">Blue</label>
            
            <input type="radio" id="red-weight-method" name="color" />
            <label for="red-weight-method">Red Weight Method</label>
            <input type="radio" id="green-weight-method" name="color" />
            <label for="green-weight-method">Green Weight Method</label>
            <input type="radio" id="blue-weight-method" name="color" />
            <label for="blue-weight-method">Blue Weight Method</label>
            
            <input type="radio" id="mean-value-method" name="color" />
            <label for="mean-value-method">Mean Value Method</label>
            <input type="radio" id="max-value-method" name="color" />
            <label for="max-value-method">Max Value Method</label>
            <input type="radio" id="weighted-average-method" name="color" />
            <label for="weighted-average-method">Weighted Average Method</label>
        </div>
        
        <script type="text/javascript">
            window.onload = (event) => {
                console.log(event)
                
                main()
            }
            
            function main() {
                const canvas = document.getElementById("canvas")
                const ctx = canvas.getContext("2d")
                
                const image = new Image()
                image.onload = (event) => {
                    console.log(event, image.width, image.height)
                    
                    canvas.width = image.width
                    canvas.height = image.height
                    
                    ctx.drawImage(image, 0, 0)
                    
                    const originalImageData = ctx.getImageData(0, 0, image.width, image.height)

                    document.getElementById("original").onchange = (event) => {
                        ctx.putImageData(originalImageData, 0, 0)
                    }

                    document.getElementById("red").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            imageData.data[i] = originalImageData.data[i] // Red
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    document.getElementById("green").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            imageData.data[i + 1] = originalImageData.data[i + 1] // Green
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    document.getElementById("blue").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            imageData.data[i + 2] = originalImageData.data[i + 2] // Blue
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    // 分量法 - 红色
                    document.getElementById("red-weight-method").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        let gray = 0;
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            gray = originalImageData.data[i + 0] // Red Weight
                            imageData.data[i + 0] = gray // Red
                            imageData.data[i + 1] = gray // Green
                            imageData.data[i + 2] = gray // Blue
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    // 分量法 - 绿色
                    document.getElementById("green-weight-method").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        let gray = 0;
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            gray = originalImageData.data[i + 1] // Green Weight
                            imageData.data[i + 0] = gray // Red
                            imageData.data[i + 1] = gray // Green
                            imageData.data[i + 2] = gray // Blue
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    // 分量法 - 蓝色
                    document.getElementById("blue-weight-method").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        let gray = 0;
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            gray = originalImageData.data[i + 2] // Blue Weight
                            imageData.data[i + 0] = gray // Red
                            imageData.data[i + 1] = gray // Green
                            imageData.data[i + 2] = gray // Blue
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    // 平均值法
                    document.getElementById("mean-value-method").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        let gray = 0;
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            gray = (originalImageData.data[i + 0] + originalImageData.data[i + 1] + originalImageData.data[i + 2]) / 3
                            imageData.data[i + 0] = gray // Red
                            imageData.data[i + 1] = gray // Green
                            imageData.data[i + 2] = gray // Blue
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    // 最大值法
                    document.getElementById("max-value-method").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        let gray = 0;
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            gray = Math.max(originalImageData.data[i + 0], originalImageData.data[i + 1], originalImageData.data[i + 2])
                            imageData.data[i + 0] = gray // Red
                            imageData.data[i + 1] = gray // Green
                            imageData.data[i + 2] = gray // Blue
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                    
                    // 加权平均法
                    document.getElementById("weighted-average-method").onchange = (event) => {
                        const imageData = ctx.createImageData(originalImageData)
                        
                        let gray = 0;
                        for (let i = 0; i < originalImageData.data.length; i += 4) {
                            gray = 0.299 * originalImageData.data[i + 0] + 0.587 * originalImageData.data[i + 1] + 0.114 * originalImageData.data[i + 2]
                            imageData.data[i + 0] = gray // Red
                            imageData.data[i + 1] = gray // Green
                            imageData.data[i + 2] = gray // Blue
                            imageData.data[i + 3] = originalImageData.data[i + 3] // Alpha
                        }
                        
                        ctx.putImageData(imageData, 0, 0)
                    }
                }
                
                image.src = "img/transformers.jpg"
            }
        </script>
    </body>
</html>

参考

图像处理:图像灰度化
灰度处理与二值化的关系
【图像处理】——图像的灰度化处理(Python实现三种方法——最大值法、平均值法、加权均值法、gamma校正)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值