Canvas - 获取画布中像素点的 RGBA

文章目录


在这里插入图片描述

在这里插入图片描述

<!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>
        </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)
                    }
                }
                
                image.src = "img/0.png"
            }
        </script>
    </body>
</html>

参考

Web technology for developers > Web APIs > Canvas API > Canvas tutorial > Using images

Web technology for developers > Web APIs > Canvas API > Canvas tutorial > Pixel manipulation with canvas

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值