<main>
<h1>Image Energy Calculator</h1>
<p>
			Each pixel in an image consist of three “lamps”: red, green and blue.<br />
		If all “lamps” are fully on, the pixel is white – if they're off, it's black.<br />
		This tool shows the intensity of each “lamp” in an image.<br />
		High values equals high energy-cost (on OLED).<br />
		Darker images and “dark mode” saves electricity.
</p>
<div>Red: <strong id="R"></strong></div>
<div>Green: <strong id="G"></strong></div>
<div>Blue: <strong id="B"></strong></div>
<h2>Average: <span id="A"></span></h2>
<label>
	<input type="file" id="F" />
	Choose a file
</label>
</main>

<img id="I" src="" />
body {
	background-color: #222;
	color: #FEFEFE;
	display: flex;
  flex-direction: column;
	font-family: ui-sans-serif, system-ui, sans-serif;
	gap: 1rem;
  justify-content: space-between;
	line-height: 1.5;
	padding: 1rem 2rem;
}
img {
	border: 2px solid #FEFEFE;
	max-width: 20rem;
	object-fit: cover;
	width: 100%;
}
input {
	display: none;
}
label {
	border: 1px solid #FEFEFE;
	cursor: pointer;
	display: inline-flex;
	padding: 0.75rem 1.5rem;
}
@media (min-width: 768px) {
  body { flex-direction: row; }
}
I.onload = () => {
	const [r,g,b] = pixel2percent(I);
	const avg = Math.ceil((r+g+b) / 3);
	R.innerText = `${r}%`;
	G.innerText =`${g}%`;
	B.innerText = `${b}%`;
	A.innerText = `${avg}%`
}

function loadImg() {
	const reader = new FileReader();
		reader.onload = (e) => {
			I.setAttribute("src", e.target.result);
		};
		reader.readAsDataURL(event.target.files[0]);
}

function pixel2percent(img) {
	const width = img.width;
	const height = img.height;
	const canvas = document.createElement('canvas');
	canvas.width = width;
	canvas.height = height;
	const ctx = canvas.getContext('2d');
	ctx.drawImage(img, 0, 0, width, height);
	const imgData = ctx.getImageData(0, 0, width, height);
	
	const len = imgData.data.length / 4;

  let r = 0, g = 0, b = 0, a = 0;
	for (let i = 0; i < imgData.data.length; i += 4) {
		a = 255 / imgData.data[i + 3];
		r+= imgData.data[i] / 255 / a;
		g+= imgData.data[i + 1] / 255 / a;
		b+= imgData.data[i + 2] / 255 / a;
	}
	r = Math.floor((r/len) * 100);
	g = Math.floor((g/len) * 100);
	b = Math.floor((b/len) * 100);

	return [r, g, b];
}

F.addEventListener('change', loadImg);

/* Demo Init */
I.src = '';

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.