mirror of
https://github.com/bspeice/speice.io
synced 2025-01-10 17:50:03 -05:00
21 lines
737 B
TypeScript
21 lines
737 B
TypeScript
|
export function paintLogarithmic(width: number, histogram: Uint32Array): ImageData {
|
||
|
const image = new ImageData(width, histogram.length / width);
|
||
|
|
||
|
const histogramLog = new Array<number>();
|
||
|
histogram.forEach(value => histogramLog.push(Math.log(value)));
|
||
|
|
||
|
let histogramLogMax = -Infinity;
|
||
|
for (let value of histogramLog) {
|
||
|
histogramLogMax = Math.max(histogramLogMax, value);
|
||
|
}
|
||
|
|
||
|
for (let i = 0; i < histogram.length; i++) {
|
||
|
const pixelIndex = i * 4;
|
||
|
image.data[pixelIndex] = 0; // red
|
||
|
image.data[pixelIndex + 1] = 0; // green
|
||
|
image.data[pixelIndex + 2] = 0; // blue
|
||
|
image.data[pixelIndex + 3] = histogramLog[i] / histogramLogMax * 0xff;
|
||
|
}
|
||
|
|
||
|
return image;
|
||
|
}
|