speice.io/blog/2024-11-15-playing-with-fire/3-log-density/FlameHistogram.tsx
2024-12-08 16:17:21 -05:00

27 lines
782 B
TypeScript

import React, {useContext, useEffect} from "react";
import {xforms as transforms, xformFinal as final} from "../src/params";
import {PainterContext} from "../src/Canvas";
import {chaosGameHistogram} from "./chaosGameHistogram";
type Props = {
quality?: number;
paint: (width: number, histogram: Uint32Array) => ImageData;
children?: React.ReactElement;
}
export default function FlameHistogram({quality, paint, children}: Props) {
const {width, height, setPainter} = useContext(PainterContext);
useEffect(() => {
const gameParams = {
width,
height,
transforms,
final,
quality,
paint
}
setPainter(chaosGameHistogram(gameParams));
}, []);
return children;
}