<!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校正)